view_sources sorter done? --AKB
[dbsrgits/DBIx-Class.git] / t / 105view_deps.t
CommitLineData
6ebf5cbb 1#!/usr/bin/perl
2
3use strict;
4use warnings;
5
6use Test::More;
7use Test::Exception;
8use lib qw(t/lib);
6ebf5cbb 9use ViewDeps;
e55d9d89 10use Devel::Dwarn;
6ebf5cbb 11
12BEGIN {
13 use_ok('DBIx::Class::ResultSource::View');
14}
15
d40f513f 16### SANITY
17
1e70d9dc 18my $view = DBIx::Class::ResultSource::View->new( { name => 'Quux' } );
66fb15b6 19
d40f513f 20isa_ok( $view, 'DBIx::Class::ResultSource', 'A new view');
21isa_ok( $view, 'DBIx::Class', 'A new view also');
6ebf5cbb 22
e55d9d89 23can_ok( $view, $_ ) for qw/new from deploy_depends_on/;
6ebf5cbb 24
d40f513f 25### DEPS
6ebf5cbb 26
27my $schema = ViewDeps->connect;
1e70d9dc 28ok( $schema, 'Connected to ViewDeps schema OK' );
e55d9d89 29my $bar_rs = $schema->resultset('Bar');
30#diag(DwarnS $bar_rs->result_source);
6ebf5cbb 31
e55d9d89 32my @bar_deps = keys %{ $schema->resultset('Bar')->result_source->deploy_depends_on };
6ebf5cbb 33
e55d9d89 34my @foo_deps = keys %{ $schema->resultset('Foo')->result_source->deploy_depends_on };
66fb15b6 35
1e70d9dc 36isa_ok( $schema->resultset('Bar')->result_source,
37 'DBIx::Class::ResultSource::View', 'Bar' );
66fb15b6 38
bf5c3a3f 39is( $bar_deps[0], 'baz', 'which is reported to depend on baz...' );
40is( $bar_deps[1], 'mixin', 'and on mixin.' );
1e70d9dc 41is( $foo_deps[0], undef, 'Foo has no dependencies...' );
42
43isa_ok(
44 $schema->resultset('Foo')->result_source,
45 'DBIx::Class::ResultSource::View',
46 'though Foo'
47);
d40f513f 48isa_ok(
49 $schema->resultset('Baz')->result_source,
50 'DBIx::Class::ResultSource::Table',
51 "Baz on the other hand"
52);
53dies_ok {
e55d9d89 54 ViewDeps::Result::Baz->result_source_instance->deploy_depends_on(
d40f513f 55 { ViewDeps::Result::Mixin->result_source_instance->name => 1 } );
56}
e55d9d89 57"...and you cannot use deploy_depends_on with that";
6ebf5cbb 58
bf5c3a3f 59diag("ViewDeps::Foo view definition: ", ViewDeps->source('Foo')->view_definition);
60diag("schema->rs(Bar) view definition: ", $schema->resultset('Bar')->result_source->view_definition);
61
62my $dir = "t/sql"; # tempdir(CLEANUP => 0);
63$schema->create_ddl_dir([ 'PostgreSQL' ], 0.1, $dir);
64
6ebf5cbb 65done_testing;