11 my $schema = DBICTest->init_schema();
15 my $prod_rs = $schema->resultset ('Producer');
16 my $prod_count = $prod_rs->count;
18 my $cd = $schema->resultset('CD')->first;
19 $cd->add_to_producers ({name => 'new m2m producer'});
21 is ($prod_rs->count, $prod_count + 1, 'New producer created');
22 ok ($cd->producers->find ({name => 'new m2m producer'}), 'Producer created with correct name');
24 my $cd2 = $schema->resultset('CD')->search ( { cdid => { '!=', $cd->cdid } }, {rows => 1} )->single; # retrieve a cd different from the first
25 $cd2->add_to_producers ({name => 'new m2m producer'}); # attach to an existing producer
26 ok ($cd2->producers->find ({name => 'new m2m producer'}), 'Existing producer attached to existing cd');
28 }, 'Test far-end find_or_create over many_to_many');