1#!/usr/bin/env bash
2# group: rw quick
3# Check live snapshot, followed by active commit, and another snapshot.
4#
5# This test is to catch the error case of BZ #1300209:
6# https://bugzilla.redhat.com/show_bug.cgi?id=1300209
7#
8# Copyright (C) 2016 Red Hat, Inc.
9#
10# This program is free software; you can redistribute it and/or modify
11# it under the terms of the GNU General Public License as published by
12# the Free Software Foundation; either version 2 of the License, or
13# (at your option) any later version.
14#
15# This program is distributed in the hope that it will be useful,
16# but WITHOUT ANY WARRANTY; without even the implied warranty of
17# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18# GNU General Public License for more details.
19#
20# You should have received a copy of the GNU General Public License
21# along with this program.  If not, see <http://www.gnu.org/licenses/>.
22#
23
24# creator
25owner=codyprime@gmail.com
26
27seq=`basename $0`
28echo "QA output created by $seq"
29
30status=1	# failure is the default!
31
32TMP_SNAP1=${TEST_DIR}/tmp.qcow2
33TMP_SNAP2=${TEST_DIR}/tmp2.qcow2
34
35_cleanup()
36{
37    _cleanup_qemu
38    for img in "${TEST_IMG}" "${TMP_SNAP1}" "${TMP_SNAP2}"; do
39        _rm_test_img "$img"
40    done
41}
42
43trap "_cleanup; exit \$status" 0 1 2 3 15
44
45# get standard environment, filters and checks
46. ./common.rc
47. ./common.filter
48. ./common.qemu
49
50_supported_fmt qcow2
51_supported_proto file
52
53size=512M
54
55_make_test_img $size
56
57echo
58echo === Launching QEMU ===
59echo
60
61qemu_comm_method="qmp"
62_launch_qemu -drive file="${TEST_IMG}",if=virtio
63h=$QEMU_HANDLE
64
65
66echo
67echo === Performing Live Snapshot 1 ===
68echo
69
70_send_qemu_cmd $h "{ 'execute': 'qmp_capabilities' }" "return"
71
72
73# First live snapshot, new overlay as active layer
74_send_qemu_cmd $h "{ 'execute': 'blockdev-snapshot-sync',
75                                'arguments': {
76                                             'device': 'virtio0',
77                                             'snapshot-file':'${TMP_SNAP1}',
78                                             'format': 'qcow2'
79                                             }
80                    }" "return"
81
82echo
83echo === Performing block-commit on active layer ===
84echo
85
86capture_events="BLOCK_JOB_READY JOB_STATUS_CHANGE"
87
88# Block commit on active layer, push the new overlay into base
89_send_qemu_cmd $h "{ 'execute': 'block-commit',
90                                'arguments': {
91                                                 'device': 'virtio0'
92                                              }
93                    }" "return"
94
95_wait_event $h "JOB_STATUS_CHANGE"
96_wait_event $h "JOB_STATUS_CHANGE"
97_wait_event $h "JOB_STATUS_CHANGE"
98
99_wait_event $h "BLOCK_JOB_READY"
100
101capture_events=
102
103_send_qemu_cmd $h "{ 'execute': 'block-job-complete',
104                                'arguments': {
105                                                'device': 'virtio0'
106                                              }
107                   }" '"status": "null"'
108
109echo
110echo === Performing Live Snapshot 2 ===
111echo
112
113# New live snapshot, new overlays as active layer
114_send_qemu_cmd $h "{ 'execute': 'blockdev-snapshot-sync',
115                                'arguments': {
116                                                'device': 'virtio0',
117                                                'snapshot-file':'${TMP_SNAP2}',
118                                                'format': 'qcow2'
119                                              }
120                   }" "return"
121
122# success, all done
123echo "*** done"
124rm -f $seq.full
125status=0
126