File: 22dump.t

package info (click to toggle)
libdbix-class-schema-loader-perl 0.07053-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,464 kB
  • sloc: perl: 11,520; sh: 544; makefile: 4
file content (94 lines) | stat: -rw-r--r-- 2,791 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
use strict;
use warnings;
use Test::More;
use Test::Exception;
use Test::Warn;
use lib qw(t/lib);
use File::Path;
use make_dbictest_db;
use dbixcsl_test_dir qw/$tdir/;

my $dump_path = "$tdir/dump";


{
    package DBICTest::Schema::1;
    use base qw/ DBIx::Class::Schema::Loader /;
    __PACKAGE__->loader_options(
        dump_directory => $dump_path,
    );
}

{
    package DBICTest::Schema::2;
    use base qw/ DBIx::Class::Schema::Loader /;
    __PACKAGE__->loader_options(
        dump_directory => $dump_path,
        really_erase_my_files => 1,
    );
}

rmtree($dump_path, 1, 1);

lives_ok {
    warnings_exist { DBICTest::Schema::1->connect($make_dbictest_db::dsn) }
        [ qr|^Dumping manual schema|, qr|^Schema dump completed| ];
} 'no death with dump_directory set' or diag "Dump failed: $@";

is_deeply(
    [ sort @{ DBICTest::Schema::1->loader->generated_classes } ],
    [ sort 'DBICTest::Schema::1', map "DBICTest::Schema::1::Result::$_", qw(Foo Bar) ],
    'generated_classes has schema and result classes'
);

DBICTest::Schema::1->_loader_invoked(undef);

SKIP: {
    skip "ActiveState perl produces additional warnings", 1
        if ($^O eq 'MSWin32');

    warnings_exist { DBICTest::Schema::1->connect($make_dbictest_db::dsn) }
        [ qr|^Dumping manual schema|, qr|^Schema dump completed| ];

    is_deeply(
        [ sort @{ DBICTest::Schema::1->loader->generated_classes } ],
        [ ],
        'no classes generated on second dump'
    );

    rmtree($dump_path, 1, 1);
}

lives_ok {
    warnings_exist { DBICTest::Schema::2->connect($make_dbictest_db::dsn) }
        [ qr|^Dumping manual schema|, qr|^Schema dump completed| ];
} 'no death with dump_directory set (overwrite1)' or diag "Dump failed: $@";

is_deeply(
    [ sort @{ DBICTest::Schema::2->loader->generated_classes } ],
    [ sort 'DBICTest::Schema::2', map "DBICTest::Schema::2::Result::$_", qw(Foo Bar) ],
    'generated_classes has schema and result classes'
);

DBICTest::Schema::2->_loader_invoked(undef);

lives_ok {
    warnings_exist { DBICTest::Schema::2->connect($make_dbictest_db::dsn) }
        [
            qr/^Dumping manual schema/,
            qr|^Deleting .+Schema/2.+ due to 'really_erase_my_files'|,
            qr|^Deleting .+Schema/2/Result/Foo.+ due to 'really_erase_my_files'|,
            qr|^Deleting .+Schema/2/Result/Bar.+ due to 'really_erase_my_files'|,
            qr/^Schema dump completed/
        ];
} 'no death with dump_directory set (overwrite2)' or diag "Dump failed: $@";

is_deeply(
    [ sort @{ DBICTest::Schema::2->loader->generated_classes } ],
    [ sort 'DBICTest::Schema::2', map "DBICTest::Schema::2::Result::$_", qw(Foo Bar) ],
    'all classes regenerated with really_erase_my_files',
);

done_testing();

END { rmtree($dump_path, 1, 1); }