xref: /netbsd-src/external/bsd/kyua-cli/dist/integration/cmd_db_migrate_test.sh (revision 6b3a42af15b5e090c339512c790dd68f3d11a9d8)
1*6b3a42afSjmmv# Copyright 2013 Google Inc.
2*6b3a42afSjmmv# All rights reserved.
3*6b3a42afSjmmv#
4*6b3a42afSjmmv# Redistribution and use in source and binary forms, with or without
5*6b3a42afSjmmv# modification, are permitted provided that the following conditions are
6*6b3a42afSjmmv# met:
7*6b3a42afSjmmv#
8*6b3a42afSjmmv# * Redistributions of source code must retain the above copyright
9*6b3a42afSjmmv#   notice, this list of conditions and the following disclaimer.
10*6b3a42afSjmmv# * Redistributions in binary form must reproduce the above copyright
11*6b3a42afSjmmv#   notice, this list of conditions and the following disclaimer in the
12*6b3a42afSjmmv#   documentation and/or other materials provided with the distribution.
13*6b3a42afSjmmv# * Neither the name of Google Inc. nor the names of its contributors
14*6b3a42afSjmmv#   may be used to endorse or promote products derived from this software
15*6b3a42afSjmmv#   without specific prior written permission.
16*6b3a42afSjmmv#
17*6b3a42afSjmmv# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18*6b3a42afSjmmv# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19*6b3a42afSjmmv# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20*6b3a42afSjmmv# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21*6b3a42afSjmmv# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22*6b3a42afSjmmv# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23*6b3a42afSjmmv# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24*6b3a42afSjmmv# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25*6b3a42afSjmmv# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26*6b3a42afSjmmv# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27*6b3a42afSjmmv# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28*6b3a42afSjmmv
29*6b3a42afSjmmv
30*6b3a42afSjmmvutils_test_case upgrade
31*6b3a42afSjmmvupgrade_head() {
32*6b3a42afSjmmv    data=$(atf_get_srcdir)/../store
33*6b3a42afSjmmv
34*6b3a42afSjmmv    atf_set require.files "${data}/schema_v1.sql ${data}/testdata_v1.sql"
35*6b3a42afSjmmv    atf_set require.progs "sqlite3"
36*6b3a42afSjmmv}
37*6b3a42afSjmmvupgrade_body() {
38*6b3a42afSjmmv    data=$(atf_get_srcdir)/../store
39*6b3a42afSjmmv
40*6b3a42afSjmmv    mkdir .kyua
41*6b3a42afSjmmv    cat "${data}/schema_v1.sql" "${data}/testdata_v1.sql" \
42*6b3a42afSjmmv        | sqlite3 .kyua/store.db
43*6b3a42afSjmmv    atf_check -s exit:0 -o empty -e empty kyua db-migrate
44*6b3a42afSjmmv}
45*6b3a42afSjmmv
46*6b3a42afSjmmv
47*6b3a42afSjmmvutils_test_case already_up_to_date
48*6b3a42afSjmmvalready_up_to_date_body() {
49*6b3a42afSjmmv    atf_check -s exit:0 -o ignore -e empty \
50*6b3a42afSjmmv        kyua db-exec "SELECT * FROM metadata"  # Create database.
51*6b3a42afSjmmv    atf_check -s exit:1 -o empty -e match:"already at schema version" \
52*6b3a42afSjmmv        kyua db-migrate
53*6b3a42afSjmmv}
54*6b3a42afSjmmv
55*6b3a42afSjmmv
56*6b3a42afSjmmvutils_test_case need_upgrade
57*6b3a42afSjmmvneed_upgrade_head() {
58*6b3a42afSjmmv    data=$(atf_get_srcdir)/../store
59*6b3a42afSjmmv
60*6b3a42afSjmmv    atf_set require.files "${data}/schema_v1.sql"
61*6b3a42afSjmmv    atf_set require.progs "sqlite3"
62*6b3a42afSjmmv}
63*6b3a42afSjmmvneed_upgrade_body() {
64*6b3a42afSjmmv    data=$(atf_get_srcdir)/../store
65*6b3a42afSjmmv
66*6b3a42afSjmmv    mkdir .kyua
67*6b3a42afSjmmv    sqlite3 .kyua/store.db <"${data}/schema_v1.sql"
68*6b3a42afSjmmv    atf_check -s exit:2 -o empty \
69*6b3a42afSjmmv        -e match:"database has schema version 1.*use db-migrate" kyua report
70*6b3a42afSjmmv}
71*6b3a42afSjmmv
72*6b3a42afSjmmv
73*6b3a42afSjmmvutils_test_case store_flag__ok
74*6b3a42afSjmmvstore_flag__ok_body() {
75*6b3a42afSjmmv    echo "This is not a valid database" >test.db
76*6b3a42afSjmmv    atf_check -s exit:1 -o empty -e match:"Migration failed" \
77*6b3a42afSjmmv        kyua db-migrate --store ./test.db
78*6b3a42afSjmmv}
79*6b3a42afSjmmv
80*6b3a42afSjmmv
81*6b3a42afSjmmvutils_test_case store_flag__fail
82*6b3a42afSjmmvstore_flag__fail_body() {
83*6b3a42afSjmmv    atf_check -s exit:1 -o empty -e match:"Cannot open.*test.db" \
84*6b3a42afSjmmv        kyua db-migrate --store ./test.db
85*6b3a42afSjmmv}
86*6b3a42afSjmmv
87*6b3a42afSjmmv
88*6b3a42afSjmmvutils_test_case too_many_arguments
89*6b3a42afSjmmvtoo_many_arguments_body() {
90*6b3a42afSjmmv    cat >stderr <<EOF
91*6b3a42afSjmmvUsage error for command db-migrate: Too many arguments.
92*6b3a42afSjmmvType 'kyua help db-migrate' for usage information.
93*6b3a42afSjmmvEOF
94*6b3a42afSjmmv    atf_check -s exit:3 -o empty -e file:stderr kyua db-migrate abc def
95*6b3a42afSjmmv}
96*6b3a42afSjmmv
97*6b3a42afSjmmv
98*6b3a42afSjmmvatf_init_test_cases() {
99*6b3a42afSjmmv    atf_add_test_case upgrade
100*6b3a42afSjmmv    atf_add_test_case already_up_to_date
101*6b3a42afSjmmv    atf_add_test_case need_upgrade
102*6b3a42afSjmmv
103*6b3a42afSjmmv    atf_add_test_case store_flag__ok
104*6b3a42afSjmmv    atf_add_test_case store_flag__fail
105*6b3a42afSjmmv
106*6b3a42afSjmmv    atf_add_test_case too_many_arguments
107*6b3a42afSjmmv}
108