Add empty possible value to Object::Enum values
[dbsrgits/DBIx-Class-InflateColumn-Object-Enum.git] / t / 01-object-enum.t
CommitLineData
b41bacc7 1use Test::More tests => 24;
86d6940e 2
3BEGIN {
4 use lib 't/lib';
5 use_ok( 'DBICx::TestDatabase'); # test 1
6 use_ok( 'TestDB' ); # test 2
7
8}
9
10sub _check_column { # each call to this = 7 tests
11 my $col = shift;
12 my $name = shift;
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));
20}
21
22my $rs;
23my $db = new DBICx::TestDatabase('TestDB');
24
25ok(ref($db) eq 'TestDB','Testing database looks good');
26
27$rs = $db->resultset('VarcharEnumNullable')->create({id=>0});
28ok(defined($rs),'VarcharEnumNullable: create returned as expected'); # test 3
29ok(!defined($rs->enum),'VarcharEnumNullable: enum column is null as expected'); # test 4
30
31$rs->enum(''); # initialize inflated object for nullable
32_check_column($rs->enum,$rs->result_source->source_name); # tests 5 thru 12
33
34undef $rs;
35eval(q/$db->resultset('VarcharEnumNoneNullable')->create({id=>1})/);
36ok(defined($@),'VarcharEnumNoneNullable(null enum): create with null enum failed as expected'); # test 13
37
b41bacc7 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
86d6940e 42
b41bacc7 43#undef $rs;
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
86d6940e 46
47undef $rs;
48$rs = $db->resultset('VarcharEnumNoneNullable')->create({id=>4,enum=>'red'});
49ok($rs->enum->is_red,'VarcharEnumNoneNullable(valid enum) defined correctly'); # test 23
50
51undef $rs;
52$rs = $db->resultset('NativeEnumNullable')->create({id=>5});
53ok(defined($rs),'NativeEnumNullable: create returned as expected'); # test 24
54ok(!defined($rs->enum),'NativeEnumNullable: enum column is null as expected'); # test 25
55
56$rs->enum(''); # initialize inflated object for nullable
57_check_column($rs->enum,$rs->result_source->source_name); # tests 26 thru 32
58
59undef $rs;
60eval(q/$db->resultset('NativeEnumNoneNullable')->create({id=>6})/);
61ok(defined($@),'NativeEnumNoneNullable(null enum): create with null enum failed as expected'); # test 33
62