--- trunk/t/1_nos.t 2005/05/16 22:04:40 31 +++ trunk/t/1_nos.t 2005/06/22 16:42:06 63 @@ -3,14 +3,94 @@ use strict; use blib; -use Test::More tests => 5; +use Test::More tests => 76; BEGIN { use_ok('Nos') }; ok(my $nos = new Nos('dsn' => 'dbi:Pg:dbname=notices'), "new"); -ok($nos->_add_list( list => 'My list', email => 'my-list@example.com'), "_add_list"); +ok($nos->new_list( list => 'My list', email => 'my-list@example.com'), "new_list my-list"); +ok($nos->new_list( list => 'another', email => 'another@example.com'), "new_list another"); +ok($nos->new_list( list => 'test', email => 'test@example.com'), "new_list test"); -ok($nos->add_member_to_list( list => 'My list', email => 'foo@example.com' ), "add_member_to_list"); +ok($nos->_get_list('My list'), "_get_list"); +ok($nos->_get_list('another'), "_get_list"); +ok($nos->_get_list('test'), "_get_list"); + +my %ext_id; + +my $i = 0; +foreach my $email (qw(foo@example.com bar@example.com baz@example.com)) { + my $full_name = uc($1)." Doe" if ($email =~ m/^([^@]+)@/); + ok($nos->add_member_to_list( list => 'My list', email => $email, name => $full_name, ext_id => $i ), "add_member_to_list $email, ext_id = $i"); + ok($nos->add_member_to_list( list => 'another', email => $email ), "add_member_to_list $email") if ($i % 2 == 0); + ok($nos->add_member_to_list( list => 'test', email => $email, ext_id => $i ), "add_member_to_list $email, ext_id = $i") if ($i % 3 == 0); + $ext_id{$email} = $i; + $i++; +} + +ok($nos->add_message_to_list( list => 'My list', message => "Subject: test\n\nJust a test\n\n" ), "add_message_to_list"); + +foreach my $i ( 1 .. 10 ) { + ok($nos->add_message_to_list( list => 'another', message => "Subject: test $i" ), "add_message_to_list another $i"); + ok($nos->add_message_to_list( list => 'test', message => "Subject: test e-mail $i\n\nIsn't life great?\n" ), "add_message_to_list test $i") if ($i % 3 == 0); +} + +cmp_ok(scalar $nos->list_members( list => 'My list' ), '==', 3, 'members of My list'); +cmp_ok(scalar $nos->list_members( list => 'another' ), '==', 2, 'members of another'); +cmp_ok(scalar $nos->list_members( list => 'test' ), '==', 1, 'members of test'); + +foreach my $list (('My list', 'another', 'test')) { + diag "checking list $list"; + foreach my $m ( $nos->list_members( list => $list ) ) { + ok(my $email = $m->{'email'}, "have email"); + cmp_ok($m->{'ext_id'}, 'eq', $ext_id{$email}, "ext_id($email)=$ext_id{$email}"); + } +} + + +ok($nos->delete_member( email => 'foo@example.com' ), "delete"); + +cmp_ok(scalar $nos->list_members( list => 'My list' ), '==', 2, 'members of My list'); +cmp_ok(scalar $nos->list_members( list => 'another' ), '==', 1, 'members of another'); +cmp_ok(scalar $nos->list_members( list => 'test' ), '==', 0, 'members of test'); + +ok($nos->delete_member( name => 'BAZ Doe' ), "delete"); + +cmp_ok(scalar $nos->list_members( list => 'My list' ), '==', 1, 'members of My list'); +cmp_ok(scalar $nos->list_members( list => 'another' ), '==', 0, 'members of another'); + +# now test delete + +ok($nos->new_list( list => 'delete', email => 'delete@example.com'), "new_list error"); + +ok($nos->add_member_to_list( list => 'delete', email => 'delete_me@example.com' ), "add test member"); + +my $nr; +ok($nr = scalar $nos->list_members( list => 'delete' ), "get delete list members"); + +foreach my $i (1 .. 5) { + ok($nos->add_member_to_list( list => 'delete', 'email' => 'delete_'.$i.'@example.com'), "add bogus member $i"); +} + +cmp_ok(scalar $nos->list_members( list => 'delete' ), '==', $nr + 5, "new member"); + +ok($nos->delete_member_from_list( list => 'delete', email => 'delete_me@example.com'), "delete_memeber_from_list"); + +cmp_ok(scalar $nos->list_members( list => 'delete' ), '==', $nr + 4, 'member deleted'); + +ok(! $nos->delete_member_from_list( list => 'delete', email => 'delete_me@example.com'), "delete non-existant member"); + +foreach my $i (1 .. 5) { + ok($nos->delete_member( email => 'delete_'.$i.'@example.com'), "delete_member $i"); +} + +cmp_ok(scalar $nos->list_members( list => 'delete' ), '==', 0, "list empty"); + +# test delete lists + +foreach my $list (( 'My list', 'test', 'another', 'delete' )) { + ok($nos->delete_list( list => $list ), "delete $list"); + ok(! $nos->_get_list($list), "$list doesn't exist"); +} -ok($nos->add_message_to_list( list => 'My list', message => 'Subject: test\nJust a test' ), "add_message_to_list");