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=fb5ea1e3224be5c9812ca7b12cf5200dee5ad961;hp=dfeb95f5d7d937e056a5dea4e991fc2c920ec0b3;hb=4ac0b9cb8e9043db8a95f44af685c782bf9426e7;hpb=fbb513f774337d5b48768491f0479b2b24e7fc4c diff --git a/t/unit_core_uri_for.t b/t/unit_core_uri_for.t index dfeb95f..fb5ea1e 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 => 16; use URI; use_ok('Catalyst'); @@ -43,12 +43,26 @@ 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, 'http://127.0.0.1/foo/yada/quux?param1=%E2%98%A0', 'URI for undef action with query params in unicode' ); +is( + Catalyst::uri_for( $context, 'quux', { 'param:1' => "foo" } )->as_string, + 'http://127.0.0.1/foo/yada/quux?param%3A1=foo', + 'URI for undef action with query params in unicode' +); # test with object is( @@ -72,5 +86,25 @@ 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" ); +} + +# Test with parameters '/', 'foo', 'bar' - should not generate a // +is( Catalyst::uri_for( $context, qw| / foo bar | )->as_string, + 'http://127.0.0.1/foo/bar', 'uri is /foo/bar, not //foo/bar' +); +