5 eval "use DBIx::Class::CDBICompat;";
8 plan (skip_all => 'Class::Trigger and DBIx::ContextualFetch required');
11 eval "use DBD::SQLite";
12 plan $@ ? (skip_all => 'needs DBD::SQLite for testing') : (tests => 54);
16 #local $SIG{__WARN__} =
17 #sub { like $_[0], qr/clashes with built-in method/, $_[0] };
22 Actor->has_a(film => 'Film');
23 Film->has_a(director => 'Director');
24 sub Class::DBI::sheep { ok 0; }
27 sub Film::mutator_name {
28 my ($class, $col) = @_;
29 return "set_sheep" if lc $col eq "numexplodingsheep";
33 sub Film::accessor_name {
34 my ($class, $col) = @_;
35 return "sheep" if lc $col eq "numexplodingsheep";
39 sub Actor::accessor_name_for {
40 my ($class, $col) = @_;
41 return "movie" if lc $col eq "film";
45 # This is a class with accessor_name_for() but no corresponding mutatori_name_for()
46 sub Director::accessor_name_for {
47 my($class, $col) = @_;
48 return "nutty_as_a_fruitcake" if lc $col eq "isinsane";
54 Director => 'Peter Jackson',
60 $data->{NumExplodingSheep} = 1;
61 ok my $bt = Film->create($data), "Modified accessor - with column name";
64 is $@, '', "No errors";
69 ok my $bt = Film->create($data), "Modified accessor - with accessor";
72 is $@, '', "No errors";
75 my @film = Film->search({ sheep => 1 });
76 is @film, 2, "Can search with modified accessor";
82 local $data->{set_sheep} = 1;
83 ok my $bt = Film->create($data), "Modified mutator - with mutator";
86 is $@, '', "No errors";
89 local $data->{NumExplodingSheep} = 1;
90 ok my $bt = Film->create($data), "Modified mutator - with column name";
93 is $@, '', "No errors";
96 local $data->{sheep} = 1;
97 ok my $bt = Film->create($data), "Modified mutator - with accessor";
100 is $@, '', "No errors";
106 name => 'Peter Jackson',
109 my $bt = Film->create($data);
110 my $ac = Actor->create($p_data);
112 eval { my $f = $ac->film };
113 like $@, qr/film/, "no hasa film";
116 ok my $f = $ac->movie, "hasa movie";
118 is $f->id, $bt->id, " - Bad Taste";
120 is $@, '', "No errors";
123 local $data->{Title} = "Another film";
124 my $film = Film->create($data);
126 eval { $ac->film($film) };
129 eval { $ac->movie($film) };
133 ok $ac->set_film($film), "Set movie through hasa";
135 ok my $f = $ac->movie, "hasa movie";
137 is $f->id, $film->id, " - Another Film";
139 is $@, '', "No problem";
145 # Make sure a class with an accessor_name() method has a similar mutator.
147 my $aki = Director->create({
148 name => "Aki Kaurismaki",
151 $aki->nutty_as_a_fruitcake(1);
152 is $aki->nutty_as_a_fruitcake, 1,
153 "a custom accessor without a custom mutator is setable";
158 Film->columns(TEMP => qw/nonpersistent/);
159 ok(Film->find_column('nonpersistent'), "nonpersistent is a column");
160 ok(!Film->has_real_column('nonpersistent'), " - but it's not real");
163 my $film = Film->create({ Title => "Veronique", nonpersistent => 42 });
164 is $film->title, "Veronique", "Title set OK";
165 is $film->nonpersistent, 42, "As is non persistent value";
166 $film->remove_from_object_index;
167 ok $film = Film->retrieve('Veronique'), "Re-retrieve film";
168 is $film->title, "Veronique", "Title still OK";
169 is $film->nonpersistent, undef, "Non persistent value gone";
170 ok $film->nonpersistent(40), "Can set it";
171 is $film->nonpersistent, 40, "And it's there again";
172 ok $film->update, "Commit the film";
173 is $film->nonpersistent, 40, "And it's still there";
179 [Actor->columns('Essential')],
180 [Actor->columns('Primary')],
181 "Actor has no specific essential columns"
183 ok(Actor->find_column('nonpersistent'), "nonpersistent is a column");
184 ok(!Actor->has_real_column('nonpersistent'), " - but it's not real");
185 my $pj = eval { Actor->search(name => "Peter Jackson")->first };
186 is $@, '', "no problems retrieving actors";
187 isa_ok $pj => "Actor";
192 my $naked = Film->create({ title => 'Naked' });
193 my $sandl = Film->create({ title => 'Secrets and Lies' });
196 my $update_failure = sub {
198 eval { $obj->rating($rating++) };
199 return $@ =~ /read only/;
202 ok !$update_failure->($naked), "Can update Naked";
203 ok $naked->make_read_only, "Make Naked read only";
204 ok $update_failure->($naked), "Can't update Naked any more";
205 ok !$update_failure->($sandl), "But can still update Secrets and Lies";
206 my $july4 = eval { Film->create({ title => "4 Days in July" }) };
207 isa_ok $july4 => "Film", "And can still create new films";
209 ok(Film->make_read_only, "Make all Films read only");
210 ok $update_failure->($naked), "Still can't update Naked";
211 ok $update_failure->($sandl), "And can't update S&L any more";
212 eval { $july4->delete };
213 like $@, qr/read only/, "And can't delete 4 Days in July";
214 my $abigail = eval { Film->create({ title => "Abigail's Party" }) };
215 like $@, qr/read only/, "Or create new films";
216 $SIG{__WARN__} = sub { };