aboutsummaryrefslogtreecommitdiffstats
path: root/meta-perl/recipes-perl/libdb/libdbd-sqlite-perl/sqlite-perl-test.pl
blob: 40f5916f58ebd3be067a3e283f2873769131fbcb (plain)
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#! /usr/bin/env perl
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software Foundation.
#
# Copyright (C) 2013 Wind River Systems, Inc.
#
# - It tests DBI and DBD::SQLite could work correctly which means one could
#   manipulate sqlite database in perl
# - The test includes create/insert/update/delete/select, the five important
#   things one can do with a table
use DBI;

sub execute_sql {
    my $dbh = $_[0];
    my $sql = $_[1];
    my $sth = $dbh->prepare($sql)
        or die "Couldn't prepare statement: " . $dbh->errstr;
    $sth->execute();
    print "$sql\n";
    return $sth;
}

sub select_all {
    my $dbh = $_[0];
    my $table = $_[1];
    my $sth = &execute_sql($dbh, "Select * from $table");

    print "-----------------------------------\n";
    while (@data = $sth->fetchrow_array()) {
        my $name = $data[0];
        my $id = $data[1];
        print "$name: $id\n";
    }
    print "\n";

    $sth->finish;
    return $sth;
}

# A private, temporary in-memory database is created for the connection.
# This in-memory database will vanish when the database connection is
# closed. It is handy for your library tests.
my $dbfile = ":memory:";
my $dbh = DBI->connect("DBI:SQLite:dbname=$dbfile","","")
        or die "Couldn't connect to database: " . DBI->errstr;
print "Connect to SQLite's in-memory database\n";

&execute_sql($dbh, "Create table tbl1(name varchar(10), id smallint)");
&execute_sql($dbh, "Insert into tbl1 values('yocto',10)");
&execute_sql($dbh, "Insert into tbl1 values('windriver', 20)");
&select_all($dbh, "tbl1");

&execute_sql($dbh, "Update tbl1 set name = 'oe-core' where id = 10");
&execute_sql($dbh, "Delete from tbl1 where id = 20");
&select_all($dbh, "tbl1");

$dbh->disconnect;
print "Test Success\n"