1 use Test::More tests => 24;
5 use_ok( 'DBICx::TestDatabase'); # test 1
6 use_ok( 'TestDB' ); # test 2
10 sub _check_column { # each call to this = 7 tests
13 ok(ref($col) =~ /^Object::Enum::/,qq($name: refereces Object::Enum));
14 ok($col->can('set_red'),qq($name: has correct set method));
15 ok($col->set_red,qq($name: set method contained a value));
16 ok($col->is_red,qq($name: boolean return true for correct set value));
17 ok($col->value eq 'red',qq($name: value access returned correct string));
18 ok(!$col->unset,qq($name: unset behaved as expected));
19 ok(!defined($col->value),qq($name: unset has modifed value accessor as expected));
23 my $db = new DBICx::TestDatabase('TestDB');
25 ok(ref($db) eq 'TestDB','Testing database looks good');
27 $rs = $db->resultset('VarcharEnumNullable')->create({id=>0});
28 ok(defined($rs),'VarcharEnumNullable: create returned as expected'); # test 3
29 ok(!defined($rs->enum),'VarcharEnumNullable: enum column is null as expected'); # test 4
31 $rs->enum(''); # initialize inflated object for nullable
32 _check_column($rs->enum,$rs->result_source->source_name); # tests 5 thru 12
35 eval(q/$db->resultset('VarcharEnumNoneNullable')->create({id=>1})/);
36 ok(defined($@),'VarcharEnumNoneNullable(null enum): create with null enum failed as expected'); # test 13
38 # commented tests now conflict with expected behavior
39 #$rs = $db->resultset('VarcharEnumNoneNullable')->create({id=>2,enum=>'none'});
40 #ok(defined($rs),'VarcharEnumNoneNullable(invalid enum): create with invalid enum returns row as expected'); # test 14
41 #_check_column($rs->enum,$rs->result_source->source_name.'(invalid enum)'); # tests 15 thru 21
44 #$rs = $db->resultset('VarcharEnumNoneNullable')->create({id=>3,enum=>'none'});
45 #ok($rs->enum->value ne 'none','VarcharEnumNoneNullable(invalid enum) value return undef on valid as expected'); # test 22
48 $rs = $db->resultset('VarcharEnumNoneNullable')->create({id=>4,enum=>'red'});
49 ok($rs->enum->is_red,'VarcharEnumNoneNullable(valid enum) defined correctly'); # test 23
52 $rs = $db->resultset('NativeEnumNullable')->create({id=>5});
53 ok(defined($rs),'NativeEnumNullable: create returned as expected'); # test 24
54 ok(!defined($rs->enum),'NativeEnumNullable: enum column is null as expected'); # test 25
56 $rs->enum(''); # initialize inflated object for nullable
57 _check_column($rs->enum,$rs->result_source->source_name); # tests 26 thru 32
60 eval(q/$db->resultset('NativeEnumNoneNullable')->create({id=>6})/);
61 ok(defined($@),'NativeEnumNoneNullable(null enum): create with null enum failed as expected'); # test 33