On Friday 10 May 2002 01:10, [EMAIL PROTECTED] wrote:

> Move these use() after the BEGIN (so you get the correct @INC).

> Shouldn't you mkdir ./lib/B before this ?

> Tests 7 and 8 will fail without perlio, thus you should
> skip them (see the BUGS section is O.pm's pod).

You guys are a lot pickier these days.  Isn't everybody's box just like mine? 
 :)

I've incorporated all of these suggestions.  Thank you.

-- c
--- MANIFEST~	Thu May  9 19:04:21 2002
+++ MANIFEST	Thu May  9 19:06:06 2002
@@ -88,6 +88,7 @@
 ext/B/Makefile.PL	Compiler backend makefile writer
 ext/B/NOTES		Compiler backend notes
 ext/B/O.pm		Compiler front-end module (-MO=...)
+ext/B/t/o.t		See if O works
 ext/B/ramblings/cc.notes	Compiler ramblings: notes on CC backend
 ext/B/ramblings/curcop.runtime	Compiler ramblings: notes on curcop use
 ext/B/ramblings/flip-flop	Compiler ramblings: notes on flip-flop
--- /dev/null	Thu Aug 30 02:54:37 2001
+++ ext/B/t/o.t	Fri May 10 07:37:41 2002
@@ -0,0 +1,76 @@
+#!./perl -w
+
+BEGIN {
+	chdir 't' if -d 't';
+	@INC = ('../lib', 'lib', '.');
+	require 'test.pl';
+}
+
+use strict;
+use Config;
+use File::Spec;
+use File::Path;
+
+my $path = File::Spec->catdir( 'lib', 'B' );
+unless (-d $path) {
+	mkpath( $path ) or skip_all( 'Cannot create fake module path' );
+}
+
+my $file = File::Spec->catfile( $path, 'success.pm' );
+local *OUT;
+open(OUT, '>', $file) or skip_all( 'Cannot write fake backend module');
+print OUT while <DATA>;
+close *OUT;
+
+plan( 9 ); # And someone's responsible.
+
+# use() makes it difficult to avoid O::import()
+require_ok( 'O' );
+
+my @args = ('-Ilib', '-MO=success,foo,bar', '-e', '1' );
+my @lines = get_lines( @args );
+
+is( $lines[0], '-e syntax OK', 'O.pm should not munge perl output without -qq');
+is( $lines[1], 'Compiling!', 'Output should not be saved without -q switch' );
+is( $lines[2], '(foo) <bar>', 'O.pm should call backend compile() method' );
+is( $lines[3], '[]', 'Nothing should be in $O::BEGIN_output without -q' );
+
+$args[1] = '-MO=-q,success,foo,bar';
+@lines = get_lines( @args );
+isnt( $lines[1], 'Compiling!', 'Output should not be printed with -q switch' );
+
+SKIP: {
+	skip( '-q redirection does not work without PerlIO', 2)
+		unless $Config{useperlio};
+	is( $lines[2], "[Compiling!", '... but should be in $O::BEGIN_output' );
+
+	$args[1] = '-MO=-qq,success,foo,bar';
+	@lines = get_lines( @args );
+	is( scalar @lines, 3, '-qq should suppress even the syntax OK message' );
+}
+
+$args[1] = '-MO=success,fail';
+@lines = get_lines( @args );
+like( $lines[0], qr/fail at .eval/,
+	'O.pm should die if backend compile() does not return a subref' );
+
+sub get_lines {
+	split(/[\r\n]+/, runperl( args => [ @_ ], stderr => 1 ));
+}
+
+END {
+	1 while unlink($file);
+}
+
+__END__
+package B::success;
+
+print "Compiling!\n";
+
+sub compile {
+	return 'fail' if ($_[0] eq 'fail');
+	print "($_[0]) <$_[1]>\n";
+	return sub { print "[$O::BEGIN_output]\n" };
+}
+
+1;

Reply via email to