X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Funit_core_uri_for.t;h=612d0b06db3a1df95a43223cd36cdc229faf9c41;hb=a1e61a69b8d72cd548189571d75a09c3f7be4625;hp=dfeb95f5d7d937e056a5dea4e991fc2c920ec0b3;hpb=fbb513f774337d5b48768491f0479b2b24e7fc4c;p=catagits%2FCatalyst-Runtime.git diff --git a/t/unit_core_uri_for.t b/t/unit_core_uri_for.t index dfeb95f..612d0b0 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 => 13; 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, @@ -74,3 +83,12 @@ is( 'http://127.0.0.1/bar/baz', 'URI with no base or match' ); } +# 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" ); +} +