File: 63_param_values.t

package info (click to toggle)
libdbd-sqlite3-perl 1.76-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 11,004 kB
  • sloc: ansic: 167,715; perl: 1,788; pascal: 277; makefile: 9
file content (30 lines) | stat: -rw-r--r-- 943 bytes parent folder | download | duplicates (3)
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
use strict;
use warnings;
use lib "t/lib";
use SQLiteTest qw/connect_ok/;
use Test::More;
use if -d ".git", "Test::FailWarnings";

my $dbh = connect_ok( RaiseError => 1 );
ok $dbh->do('create table foo (id integer, value integer)');
{
    my $sth = $dbh->prepare('select * from foo where id = ?');
    $sth->execute(100);
    is_deeply $sth->{ParamValues} => {1 => 100}, "ParamValues after execution";
}
{
    my $sth = $dbh->prepare('select * from foo where id = :AAA');
    $sth->execute(100);
    is_deeply $sth->{ParamValues} => {':AAA' => 100}, "ParamValues after execution (named parameter)";
}
{
    my $sth = $dbh->prepare('select * from foo where id = ?');
    $sth->bind_param(1, 100);
    is_deeply $sth->{ParamValues} => {1 => 100}, "ParamValues before execution";
}
{
    my $sth = $dbh->prepare('select * from foo where id = ?');
    is_deeply $sth->{ParamValues} => {1 => undef}, "ParamValues without binding";
}

done_testing;