Fixed uri_for bug found by drewbie
[catagits/Catalyst-Runtime.git] / t / unit / core / uri_for.t
CommitLineData
fbcc39ad 1use strict;
2use warnings;
3
fdba7a9d 4use Test::More tests => 5;
fbcc39ad 5use Test::MockObject;
6use URI;
7
8my $request = Test::MockObject->new;
9$request->mock( 'base', sub { URI->new('http://127.0.0.1/foo') } );
10$request->mock( 'match', sub { '/yada' } );
11
12my $context = Test::MockObject->new;
13$context->mock( 'request', sub { $request } );
14
15use_ok('Catalyst');
16
17is(
18 Catalyst::uri_for( $context, '/bar/baz' )->as_string,
19 'http://127.0.0.1/foo/bar/baz',
20 'URI for absolute path'
21);
22
23is(
24 Catalyst::uri_for( $context, 'bar/baz' )->as_string,
25 'http://127.0.0.1/foo/yada/bar/baz',
26 'URI for relative path'
27);
28
29is( Catalyst::uri_for( $context, '../quux' )->as_string,
30 'http://127.0.0.1/foo/quux', 'URI for relative dot path' );
fdba7a9d 31
32# bug found by drewbie
33$request->mock('base', sub { URI->new('http://localhost:3000/') } );
34$request->mock('match', sub { 'orderentry/contract' } );
35is(
36 Catalyst::uri_for( $context, '/Orderentry/saveContract' )->as_string,
37 'http://localhost:3000/Orderentry/saveContract',
38 'URI for absolute path'
39);