/
006_single.t
47 lines (41 loc) · 1.04 KB
/
006_single.t
1
2
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
use t::Utils;
use Mock::Basic;
use Test::More;
my $dbh = t::Utils->setup_dbh;
my $db = Mock::Basic->new({dbh => $dbh});
$db->setup_test_db;
$db->insert('mock_basic',{
id => 1,
name => 'perl',
});
subtest 'single' => sub {
my $row = $db->single('mock_basic',{id => 1});
isa_ok $row, 'Teng::Row';
is $row->id, 1;
is $row->name, 'perl';
is_deeply $row->get_columns, +{
id => 1,
name => 'perl',
delete_fg => 0,
};
};
subtest 'single / specific column' => sub {
my $row = $db->single('mock_basic',{id => 1},+{columns => [qw/id/]});
isa_ok $row, 'Teng::Row';
is $row->id, 1;
is_deeply $row->get_columns, +{
id => 1,
};
};
subtest 'single / specific +column' => sub {
my $row = $db->single('mock_basic',{id => 1},+{'+columns' => [\'id+20 as calc']});
isa_ok $row, 'Teng::Row';
is $row->id, 1;
is_deeply $row->get_columns, +{
id => 1,
name => 'perl',
delete_fg => 0,
calc => 21,
};
};
done_testing;