Stefan Hajnoczi | 908eaf6 | 2010-04-26 11:44:05 +0200 | [diff] [blame] | 1 | #!/bin/bash |
Kevin Wolf | 1670140 | 2009-07-16 19:09:41 +0200 | [diff] [blame] | 2 | # |
| 3 | # Merge backing file into test image when converting the image |
| 4 | # |
| 5 | # Copyright (C) 2009 Red Hat, Inc. |
| 6 | # |
| 7 | # This program is free software; you can redistribute it and/or modify |
| 8 | # it under the terms of the GNU General Public License as published by |
| 9 | # the Free Software Foundation; either version 2 of the License, or |
| 10 | # (at your option) any later version. |
| 11 | # |
| 12 | # This program is distributed in the hope that it will be useful, |
| 13 | # but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 14 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 15 | # GNU General Public License for more details. |
| 16 | # |
| 17 | # You should have received a copy of the GNU General Public License |
Christoph Hellwig | e8c212d | 2009-07-16 19:26:54 +0200 | [diff] [blame] | 18 | # along with this program. If not, see <http://www.gnu.org/licenses/>. |
Kevin Wolf | 1670140 | 2009-07-16 19:09:41 +0200 | [diff] [blame] | 19 | # |
| 20 | |
| 21 | # creator |
| 22 | owner=kwolf@redhat.com |
| 23 | |
| 24 | seq=`basename $0` |
| 25 | echo "QA output created by $seq" |
| 26 | |
| 27 | here=`pwd` |
Kevin Wolf | 1670140 | 2009-07-16 19:09:41 +0200 | [diff] [blame] | 28 | status=1 # failure is the default! |
| 29 | |
| 30 | _cleanup() |
| 31 | { |
| 32 | _cleanup_test_img |
| 33 | } |
| 34 | trap "_cleanup; exit \$status" 0 1 2 3 15 |
| 35 | |
| 36 | # get standard environment, filters and checks |
| 37 | . ./common.rc |
| 38 | . ./common.filter |
| 39 | . ./common.pattern |
| 40 | |
| 41 | # Any format supporting backing files |
Stefan Hajnoczi | f5a4bbd | 2010-10-31 16:10:20 -0400 | [diff] [blame] | 42 | _supported_fmt qcow qcow2 vmdk qed |
Peter Lieven | 1f7bf7d | 2014-02-03 10:26:14 +0100 | [diff] [blame] | 43 | _supported_proto file |
Kevin Wolf | 1670140 | 2009-07-16 19:09:41 +0200 | [diff] [blame] | 44 | _supported_os Linux |
Fam Zheng | d2329f2 | 2013-11-26 14:40:33 +0800 | [diff] [blame] | 45 | _unsupported_imgopts "subformat=monolithicFlat" "subformat=twoGbMaxExtentFlat" |
Kevin Wolf | 1670140 | 2009-07-16 19:09:41 +0200 | [diff] [blame] | 46 | |
| 47 | TEST_OFFSETS="0 4294967296" |
| 48 | |
Fam Zheng | 794d00f | 2013-05-07 19:13:05 +0800 | [diff] [blame] | 49 | TEST_IMG_SAVE=$TEST_IMG |
| 50 | TEST_IMG=$TEST_IMG.base |
Kevin Wolf | 1670140 | 2009-07-16 19:09:41 +0200 | [diff] [blame] | 51 | _make_test_img 6G |
| 52 | |
| 53 | echo "Filling base image" |
| 54 | echo |
| 55 | |
| 56 | for offset in $TEST_OFFSETS; do |
| 57 | # Some clusters with alternating backing file/image file reads |
| 58 | io writev $(( offset )) 512 1024 64 |
| 59 | |
| 60 | # Complete backing clusters |
| 61 | io writev $(( offset + 64 * 1024)) 65536 65536 1 |
| 62 | done |
| 63 | _check_test_img |
| 64 | |
| 65 | echo "Creating test image with backing file" |
| 66 | echo |
| 67 | |
Fam Zheng | 9b337ae | 2015-12-22 10:49:11 +0800 | [diff] [blame] | 68 | TEST_IMG="$TEST_IMG_SAVE.orig" |
| 69 | _make_test_img -b "$TEST_IMG_SAVE.base" 6G |
Kevin Wolf | 1670140 | 2009-07-16 19:09:41 +0200 | [diff] [blame] | 70 | |
| 71 | echo "Filling test image" |
| 72 | echo |
| 73 | |
| 74 | for offset in $TEST_OFFSETS; do |
| 75 | # Some clusters with alternating backing file/image file reads |
| 76 | io writev $(( offset + 512 )) 512 1024 64 |
| 77 | |
| 78 | # Complete test image clusters |
| 79 | io writev $(( offset + 64 * 1024 + 65536)) 65536 65536 1 |
| 80 | done |
| 81 | _check_test_img |
| 82 | |
Fam Zheng | 9b337ae | 2015-12-22 10:49:11 +0800 | [diff] [blame] | 83 | TEST_IMG="$TEST_IMG_SAVE" |
| 84 | $QEMU_IMG convert -f $IMGFMT -O $IMGFMT "$TEST_IMG.orig" "$TEST_IMG" |
Kevin Wolf | 1670140 | 2009-07-16 19:09:41 +0200 | [diff] [blame] | 85 | |
| 86 | echo "Reading" |
| 87 | echo |
| 88 | |
| 89 | for offset in $TEST_OFFSETS; do |
| 90 | # Some clusters with alternating backing file/image file reads |
| 91 | io readv $(( offset )) 512 1024 64 |
| 92 | io readv $(( offset + 512 )) 512 1024 64 |
| 93 | |
| 94 | # Complete test image clusters |
| 95 | io readv $(( offset + 64 * 1024)) 65536 65536 1 |
| 96 | io readv $(( offset + 64 * 1024 + 65536)) 65536 65536 1 |
| 97 | |
| 98 | # Empty sectors |
| 99 | io_zero readv $(( offset + 64 * 1024 + 65536 * 4 )) 65536 65536 1 |
| 100 | done |
| 101 | _check_test_img |
| 102 | |
| 103 | # success, all done |
| 104 | echo "*** done" |
| 105 | rm -f $seq.full |
| 106 | status=0 |