Avoid warning when path argument for uri_for is not defined
[catagits/Catalyst-Runtime.git] / t / aggregate / unit_core_uri_for.t
CommitLineData
fbcc39ad 1use strict;
2use warnings;
2689f8a4 3use FindBin qw/$Bin/;
4use lib "$FindBin::Bin/../lib";
62b64711 5use Test::More;
fbcc39ad 6use URI;
7
2689f8a4 8use_ok('TestApp');
fbcc39ad 9
fa32ac82 10my $request = Catalyst::Request->new( {
7c1c4dc6 11 _log => Catalyst::Log->new,
fa32ac82 12 base => URI->new('http://127.0.0.1/foo')
13 } );
2689f8a4 14my $dispatcher = TestApp->dispatcher;
15my $context = TestApp->new( {
fa32ac82 16 request => $request,
17 namespace => 'yada',
18 } );
fbcc39ad 19
20is(
21 Catalyst::uri_for( $context, '/bar/baz' )->as_string,
22 'http://127.0.0.1/foo/bar/baz',
23 'URI for absolute path'
24);
25
26is(
27 Catalyst::uri_for( $context, 'bar/baz' )->as_string,
28 'http://127.0.0.1/foo/yada/bar/baz',
29 'URI for relative path'
30);
31
d3e7a648 32is(
33 Catalyst::uri_for( $context, '', 'arg1', 'arg2' )->as_string,
34 'http://127.0.0.1/foo/yada/arg1/arg2',
35 'URI for undef action with args'
36);
37
38
fbcc39ad 39is( Catalyst::uri_for( $context, '../quux' )->as_string,
40 'http://127.0.0.1/foo/quux', 'URI for relative dot path' );
fdba7a9d 41
8327e2e2 42is(
43 Catalyst::uri_for( $context, 'quux', { param1 => 'value1' } )->as_string,
44 'http://127.0.0.1/foo/yada/quux?param1=value1',
45 'URI for undef action with query params'
46);
47
57e74a1e 48is (Catalyst::uri_for( $context, '/bar/wibble?' )->as_string,
49 'http://127.0.0.1/foo/bar/wibble%3F', 'Question Mark gets encoded'
50);
5d50f369 51
57e74a1e 52is( Catalyst::uri_for( $context, qw/bar wibble?/, 'with space' )->as_string,
53 'http://127.0.0.1/foo/yada/bar/wibble%3F/with%20space', 'Space gets encoded'
54);
55
f0417b32 56is(
57 Catalyst::uri_for( $context, '/bar', 'with+plus', { 'also' => 'with+plus' })->as_string,
58 'http://127.0.0.1/foo/bar/with+plus?also=with%2Bplus',
59 'Plus is not encoded'
60);
57e74a1e 61
3a6d7f15 62is(
63 Catalyst::uri_for( $context, '/bar#fragment', { param1 => 'value1' } )->as_string,
02336198 64 'http://127.0.0.1/foo/bar?param1=value1#fragment',
9d1f9508 65 'URI for path with fragment and query params 1'
3a6d7f15 66);
5a8e2ba0 67
9d1f9508 68is(
69 Catalyst::uri_for( $context, '/bar#fragment^%$', { param1 => 'value1' } )->as_string,
02336198 70 'http://127.0.0.1/foo/bar?param1=value1#fragment^%$',
9d1f9508 71 'URI for path with fragment and query params 3'
72);
73
6b9f9ef7 74is(
02336198 75 Catalyst::uri_for( $context, '/foo#bar/baz', { param1 => 'value1' } )->as_string,
76 'http://127.0.0.1/foo/foo?param1=value1#bar/baz',
77 'URI for path with fragment and query params 3'
6b9f9ef7 78);
79
5789a3d8 80# test with utf-8
81is(
82 Catalyst::uri_for( $context, 'quux', { param1 => "\x{2620}" } )->as_string,
83 'http://127.0.0.1/foo/yada/quux?param1=%E2%98%A0',
84 'URI for undef action with query params in unicode'
85);
2f381252 86is(
87 Catalyst::uri_for( $context, 'quux', { 'param:1' => "foo" } )->as_string,
88 'http://127.0.0.1/foo/yada/quux?param%3A1=foo',
89 'URI for undef action with query params in unicode'
90);
5789a3d8 91
fbb513f7 92# test with object
93is(
94 Catalyst::uri_for( $context, 'quux', { param1 => $request->base } )->as_string,
95 'http://127.0.0.1/foo/yada/quux?param1=http%3A%2F%2F127.0.0.1%2Ffoo',
96 'URI for undef action with query param as object'
a8020c62 97 );
98
99# test with empty arg
100{
101 my @warnings;
102 local $SIG{__WARN__} = sub { push @warnings, @_ };
103 is(
104 Catalyst::uri_for( $context )->as_string,
105 'http://127.0.0.1/foo/yada',
106 'URI with no action'
107 );
108 is_deeply(\@warnings, [], "No warnings with no path argument");
109}
fbb513f7 110
fa32ac82 111$request->base( URI->new('http://localhost:3000/') );
112$request->match( 'orderentry/contract' );
fdba7a9d 113is(
114 Catalyst::uri_for( $context, '/Orderentry/saveContract' )->as_string,
115 'http://localhost:3000/Orderentry/saveContract',
116 'URI for absolute path'
117);
bdcb95ef 118
119{
fa32ac82 120 $request->base( URI->new('http://127.0.0.1/') );
bdcb95ef 121
fa32ac82 122 $context->namespace('');
bdcb95ef 123
124 is( Catalyst::uri_for( $context, '/bar/baz' )->as_string,
125 'http://127.0.0.1/bar/baz', 'URI with no base or match' );
fcea752e 126
127 # test "0" as the path
128 is( Catalyst::uri_for( $context, qw/0 foo/ )->as_string,
129 'http://127.0.0.1/0/foo', '0 as path is ok'
130 );
131
bdcb95ef 132}
5789a3d8 133
d0f0fcf6 134# test with undef -- no warnings should be thrown
135{
136 my $warnings = 0;
137 local $SIG{__WARN__} = sub { $warnings++ };
138
139 Catalyst::uri_for( $context, '/bar/baz', { foo => undef } )->as_string,
140 is( $warnings, 0, "no warnings emitted" );
141}
142
7a2295bc 143# Test with parameters '/', 'foo', 'bar' - should not generate a //
144is( Catalyst::uri_for( $context, qw| / foo bar | )->as_string,
145 'http://127.0.0.1/foo/bar', 'uri is /foo/bar, not //foo/bar'
146);
147
6a99f9e6 148TODO: {
149 local $TODO = 'RFCs are for people who, erm - fix this test..';
1b5227a1 150 # Test rfc3986 reserved characters. These characters should all be escaped
151 # according to the RFC, but it is a very big feature change so I've removed it
6a99f9e6 152 no warnings; # Yes, everything in qw is sane
153 is(
154 Catalyst::uri_for( $context, qw|! * ' ( ) ; : @ & = $ / ? % # [ ] ,|, )->as_string,
1b5227a1 155 'http://127.0.0.1/%21/%2A/%27/%2B/%29/%3B/%3A/%40/%26/%3D/%24/%2C/%2F/%3F/%25/%23/%5B/%5D',
156 'rfc 3986 reserved characters'
157 );
1b5227a1 158
294773ca 159 # jshirley bug - why the hell does only one of these get encoded
160 # has been like this forever however.
161 is(
162 Catalyst::uri_for( $context, qw|{1} {2}| )->as_string,
163 'http://127.0.0.1/{1}/{2}',
164 'not-escaping unreserved characters'
165 );
166}
6a99f9e6 167
1f851263 168# make sure caller's query parameter hash isn't messed up
169{
170 my $query_params_base = {test => "one two",
171 bar => ["foo baz", "bar"]};
172 my $query_params_test = {test => "one two",
173 bar => ["foo baz", "bar"]};
174 Catalyst::uri_for($context, '/bar/baz', $query_params_test);
175 is_deeply($query_params_base, $query_params_test,
176 "uri_for() doesn't mess up query parameter hash in the caller");
177}
62b64711 178
2689f8a4 179
180{
181 my $path_action = $dispatcher->get_action_by_path(
182 '/action/path/six'
183 );
184
185 # 5.80018 is only encoding the first of the / in the arg.
186 is(
187 Catalyst::uri_for( $context, $path_action, 'foo/bar/baz' )->as_string,
188 'http://127.0.0.1/action/path/six/foo%2Fbar%2Fbaz',
189 'Escape all forward slashes in args as %2F'
190 );
191}
192
76cd735d 193{
194 my $index_not_private = $dispatcher->get_action_by_path(
195 '/action/chained/argsorder/index'
196 );
197
198 is(
199 Catalyst::uri_for( $context, $index_not_private )->as_string,
200 'http://127.0.0.1/argsorder',
201 'Return non-DispatchType::Index path for index action with args'
202 );
203}
62b64711 204
0ee04045 205{
206 package MyStringThing;
207
208 use overload '""' => sub { $_[0]->{string} }, fallback => 1;
209}
62b64711 210
0ee04045 211is(
212 Catalyst::uri_for( $context, bless( { string => 'test' }, 'MyStringThing' ) ),
213 'http://127.0.0.1/test',
214 'overloaded object handled correctly'
215);
216
217done_testing;