q{
CREATE TABLE "extra_loader_test1" (
"id" NOT NULL PRIMARY KEY,
- "value" VARCHAR(100)
+ "value" TEXT UNIQUE NOT NULL
)
+ },
+ q{
+ CREATE TABLE extra_loader_test2 (
+ event_id INTEGER PRIMARY KEY
+ )
+ },
+ q{
+ CREATE TABLE extra_loader_test3 (
+ person_id INTEGER PRIMARY KEY
+ )
+ },
+ # Wordy, newline-heavy SQL
+ q{
+ CREATE TABLE extra_loader_test4 (
+ event_id INTEGER NOT NULL
+ CONSTRAINT fk_event_id
+ REFERENCES extra_loader_test2(event_id),
+ person_id INTEGER NOT NULL
+ CONSTRAINT fk_person_id
+ REFERENCES extra_loader_test3 (person_id),
+ PRIMARY KEY (event_id, person_id)
+ )
+ },
+ # make sure views are picked up
+ q{
+ CREATE VIEW extra_loader_test5 AS SELECT * FROM extra_loader_test4
}
],
- drop => [ 'extra_loader_test1' ],
- count => 2,
+ pre_drop_ddl => [ 'DROP VIEW extra_loader_test5' ],
+ drop => [ qw/extra_loader_test1 extra_loader_test2 extra_loader_test3 extra_loader_test4 / ],
+ count => 9,
run => sub {
my ($schema, $monikers, $classes) = @_;
ok ((my $rs = $schema->resultset($monikers->{extra_loader_test1})),
'resultset for quoted table');
- is_deeply [ $rs->result_source->columns ], [ qw/id value/ ],
+ ok ((my $source = $rs->result_source), 'source');
+
+ is_deeply [ $source->columns ], [ qw/id value/ ],
'retrieved quoted column names from quoted table';
+
+ ok ((exists $source->column_info('value')->{is_nullable}),
+ 'is_nullable exists');
+
+ is $source->column_info('value')->{is_nullable}, 0,
+ 'is_nullable is set correctly';
+
+ ok (($source = $schema->source($monikers->{extra_loader_test4})),
+ 'verbose table');
+
+ is_deeply [ $source->primary_columns ], [ qw/event_id person_id/ ],
+ 'composite primary key';
+
+ is ($source->relationships, 2,
+ '2 foreign key constraints found');
+
+ # test that columns for views are picked up
+ is $schema->resultset($monikers->{extra_loader_test5})->result_source->column_info('person_id')->{data_type}, 'INTEGER',
+ 'columns for views are introspected';
},
},
);