X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=t%2Funit_core_uri_for.t;h=0c61435b7709edf9fbc64df2b20618c63509f25b;hp=dfeb95f5d7d937e056a5dea4e991fc2c920ec0b3;hb=afb82794328ff8da1efc0a4c37f3f3703c262c31;hpb=fbb513f774337d5b48768491f0479b2b24e7fc4c diff --git a/t/unit_core_uri_for.t b/t/unit_core_uri_for.t index dfeb95f..0c61435 100644 --- a/t/unit_core_uri_for.t +++ b/t/unit_core_uri_for.t @@ -1,7 +1,7 @@ use strict; use warnings; -use Test::More tests => 10; +use Test::More tests => 14; use URI; use_ok('Catalyst'); @@ -43,6 +43,15 @@ is( 'URI for undef action with query params' ); +is (Catalyst::uri_for( $context, '/bar/wibble?' )->as_string, + 'http://127.0.0.1/foo/bar/wibble%3F', 'Question Mark gets encoded' +); + +is( Catalyst::uri_for( $context, qw/bar wibble?/, 'with space' )->as_string, + 'http://127.0.0.1/foo/yada/bar/wibble%3F/with%20space', 'Space gets encoded' +); + + # test with utf-8 is( Catalyst::uri_for( $context, 'quux', { param1 => "\x{2620}" } )->as_string, @@ -72,5 +81,20 @@ is( is( Catalyst::uri_for( $context, '/bar/baz' )->as_string, 'http://127.0.0.1/bar/baz', 'URI with no base or match' ); + + # test "0" as the path + is( Catalyst::uri_for( $context, qw/0 foo/ )->as_string, + 'http://127.0.0.1/0/foo', '0 as path is ok' + ); + +} + +# test with undef -- no warnings should be thrown +{ + my $warnings = 0; + local $SIG{__WARN__} = sub { $warnings++ }; + + Catalyst::uri_for( $context, '/bar/baz', { foo => undef } )->as_string, + is( $warnings, 0, "no warnings emitted" ); }