| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 
 | use strict;
use warnings;
use Test::More tests => 5;
use HTML::FormFu;
use lib 't/lib';
use DBICTestLib 'new_schema';
use MySchema;
my $form = HTML::FormFu->new;
$form->load_config_file('t/update/many_to_many_select.yml');
my $schema = new_schema();
my $master = $schema->resultset('Master')-> create({ id => 1 });
my $band1;
# filler rows
{
    # user 1
    my $u1 = $master->create_related( 'user', { name => 'John' } );
    # band 1
    $band1 = $u1->add_to_bands({ band => 'the beatles' });
}
# rows we're going to use
{
    # user 2
    my $u2 = $master->create_related( 'user', { name => 'Paul', } );
    # band 2
    $u2->add_to_bands({ band => 'wings' });
    # band 3 - not used
    $schema->resultset('Band')->create({ band => 'the kinks' });
    # band 1
    $u2->add_to_bands($band1);
}
# currently,
# user [2] => bands [2, 1]
{
    $form->process( {
            id    => 2,
            name  => 'Paul McCartney',
            bands => [ 1, 3 ],
        } );
    ok( $form->submitted_and_valid );
    my $row = $schema->resultset('User')->find(2);
    $form->model->update($row);
}
{
    my $row = $schema->resultset('User')->find(2);
    is( $row->name, 'Paul McCartney' );
    my @bands = $row->bands->all;
    is( scalar @bands, 2 );
    my @id = sort map { $_->id } @bands;
    is( $id[0], 1 );
    is( $id[1], 3 );
}
 |