1 1.8 chopps # $NetBSD: t_shrink.sh,v 1.8 2015/03/29 19:37:02 chopps Exp $ 2 1.1 riz # 3 1.1 riz # Copyright (c) 2010 The NetBSD Foundation, Inc. 4 1.1 riz # All rights reserved. 5 1.1 riz # 6 1.1 riz # This code is derived from software contributed to The NetBSD Foundation 7 1.1 riz # by Jeffrey C. Rizzo. 8 1.1 riz # 9 1.1 riz # Redistribution and use in source and binary forms, with or without 10 1.1 riz # modification, are permitted provided that the following conditions 11 1.1 riz # are met: 12 1.1 riz # 1. Redistributions of source code must retain the above copyright 13 1.1 riz # notice, this list of conditions and the following disclaimer. 14 1.1 riz # 2. Redistributions in binary form must reproduce the above copyright 15 1.1 riz # notice, this list of conditions and the following disclaimer in the 16 1.1 riz # documentation and/or other materials provided with the distribution. 17 1.1 riz # 18 1.1 riz # THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 19 1.1 riz # ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 20 1.1 riz # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 21 1.1 riz # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 22 1.1 riz # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 23 1.1 riz # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 24 1.1 riz # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 25 1.1 riz # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 26 1.1 riz # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 27 1.1 riz # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 28 1.1 riz # POSSIBILITY OF SUCH DAMAGE. 29 1.1 riz # 30 1.1 riz 31 1.1 riz 32 1.5 riz # resize_ffs params as follows: 33 1.5 riz # resize_ffs blocksize fragsize fssize newfssize level numdata swap 34 1.1 riz # where 'numdata' is the number of data directories to copy - this is 35 1.1 riz # determined manually based on the maximum number that will fit in the 36 1.1 riz # created fs. 'level' is the fs-level (-O 0,1,2) passed to newfs. 37 1.1 riz # If 'swap' is included, byteswap the fs 38 1.7 riz test_case shrink_24M_16M_v0_4096 resize_ffs 4096 512 49152 32768 0 41 39 1.7 riz test_case shrink_24M_16M_v0_8192 resize_ffs 8192 1024 49152 32768 0 42 40 1.7 riz test_case shrink_24M_16M_v0_16384 resize_ffs 16384 2048 49152 32768 0 43 41 1.7 riz test_case shrink_24M_16M_v0_32768 resize_ffs 32768 4096 49152 32768 0 42 42 1.7 riz test_case shrink_24M_16M_v0_65536 resize_ffs 65536 8192 49152 32768 0 38 43 1.7 riz test_case shrink_32M_24M_v0_4096 resize_ffs 4096 512 65536 49152 0 55 44 1.7 riz test_case shrink_32M_24M_v0_8192 resize_ffs 8192 1024 65536 49152 0 56 45 1.7 riz test_case shrink_32M_24M_v0_16384 resize_ffs 16384 2048 65536 49152 0 58 46 1.7 riz test_case shrink_32M_24M_v0_32768 resize_ffs 32768 4096 65536 49152 0 56 47 1.7 riz test_case_xfail shrink_32M_24M_v0_65536 "PR bin/44204" resize_ffs 65536 8192 65536 49152 0 51 48 1.7 riz test_case shrink_48M_16M_v0_4096 resize_ffs 4096 512 98304 32768 0 82 49 1.7 riz test_case shrink_48M_16M_v0_8192 resize_ffs 8192 1024 98304 32768 0 84 50 1.7 riz test_case shrink_48M_16M_v0_16384 resize_ffs 16384 2048 98304 32768 0 87 51 1.7 riz test_case shrink_48M_16M_v0_32768 resize_ffs 32768 4096 98304 32768 0 83 52 1.7 riz test_case shrink_48M_16M_v0_65536 resize_ffs 65536 8192 98304 32768 0 76 53 1.7 riz test_case shrink_64M_48M_v0_4096 resize_ffs 4096 512 131072 98304 0 109 54 1.7 riz test_case shrink_64M_48M_v0_8192 resize_ffs 8192 1024 131072 98304 0 111 55 1.7 riz test_case shrink_64M_48M_v0_16384 resize_ffs 16384 2048 131072 98304 0 115 56 1.7 riz test_case shrink_64M_48M_v0_32768 resize_ffs 32768 4096 131072 98304 0 111 57 1.7 riz test_case shrink_64M_48M_v0_65536 resize_ffs 65536 8192 131072 98304 0 101 58 1.7 riz 59 1.5 riz test_case shrink_24M_16M_v1_4096 resize_ffs 4096 512 49152 32768 1 41 60 1.5 riz test_case shrink_24M_16M_v1_8192 resize_ffs 8192 1024 49152 32768 1 42 61 1.5 riz test_case shrink_24M_16M_v1_16384 resize_ffs 16384 2048 49152 32768 1 43 62 1.5 riz test_case shrink_24M_16M_v1_32768 resize_ffs 32768 4096 49152 32768 1 42 63 1.5 riz test_case shrink_24M_16M_v1_65536 resize_ffs 65536 8192 49152 32768 1 38 64 1.5 riz test_case shrink_32M_24M_v1_4096 resize_ffs 4096 512 65536 49152 1 55 65 1.5 riz test_case shrink_32M_24M_v1_8192 resize_ffs 8192 1024 65536 49152 1 56 66 1.5 riz test_case shrink_32M_24M_v1_16384 resize_ffs 16384 2048 65536 49152 1 58 67 1.5 riz test_case shrink_32M_24M_v1_32768 resize_ffs 32768 4096 65536 49152 1 56 68 1.5 riz test_case_xfail shrink_32M_24M_v1_65536 "PR bin/44204" resize_ffs 65536 8192 65536 49152 1 51 69 1.5 riz test_case shrink_48M_16M_v1_4096 resize_ffs 4096 512 98304 32768 1 82 70 1.5 riz test_case shrink_48M_16M_v1_8192 resize_ffs 8192 1024 98304 32768 1 84 71 1.5 riz test_case shrink_48M_16M_v1_16384 resize_ffs 16384 2048 98304 32768 1 87 72 1.5 riz test_case shrink_48M_16M_v1_32768 resize_ffs 32768 4096 98304 32768 1 83 73 1.5 riz test_case shrink_48M_16M_v1_65536 resize_ffs 65536 8192 98304 32768 1 76 74 1.5 riz test_case shrink_64M_48M_v1_4096 resize_ffs 4096 512 131072 98304 1 109 75 1.5 riz test_case shrink_64M_48M_v1_8192 resize_ffs 8192 1024 131072 98304 1 111 76 1.5 riz test_case shrink_64M_48M_v1_16384 resize_ffs 16384 2048 131072 98304 1 115 77 1.5 riz test_case shrink_64M_48M_v1_32768 resize_ffs 32768 4096 131072 98304 1 111 78 1.5 riz test_case shrink_64M_48M_v1_65536 resize_ffs 65536 8192 131072 98304 1 101 79 1.7 riz 80 1.7 riz test_case_xfail shrink_24M_16M_v2_4096 "PR bin/44205" resize_ffs 4096 512 49152 32768 2 41 81 1.7 riz test_case_xfail shrink_24M_16M_v2_8192 "PR bin/44205" resize_ffs 8192 1024 49152 32768 2 42 82 1.7 riz test_case_xfail shrink_24M_16M_v2_16384 "PR bin/44205" resize_ffs 16384 2048 49152 32768 2 43 83 1.7 riz test_case_xfail shrink_24M_16M_v2_32768 "PR bin/44205" resize_ffs 32768 4096 49152 32768 2 42 84 1.7 riz test_case_xfail shrink_24M_16M_v2_65536 "PR bin/44205" resize_ffs 65536 8192 49152 32768 2 38 85 1.7 riz test_case_xfail shrink_32M_24M_v2_4096 "PR bin/44205" resize_ffs 4096 512 65536 49152 2 55 86 1.7 riz test_case_xfail shrink_32M_24M_v2_8192 "PR bin/44205" resize_ffs 8192 1024 65536 49152 2 56 87 1.7 riz test_case_xfail shrink_32M_24M_v2_16384 "PR bin/44205" resize_ffs 16384 2048 65536 49152 2 58 88 1.7 riz test_case_xfail shrink_32M_24M_v2_32768 "PR bin/44205" resize_ffs 32768 4096 65536 49152 2 56 89 1.7 riz test_case_xfail shrink_32M_24M_v2_65536 "PR bin/44204" resize_ffs 65536 8192 65536 49152 2 51 90 1.7 riz test_case_xfail shrink_48M_16M_v2_4096 "PR bin/44205" resize_ffs 4096 512 98304 32768 2 82 91 1.7 riz test_case_xfail shrink_48M_16M_v2_8192 "PR bin/44205" resize_ffs 8192 1024 98304 32768 2 84 92 1.7 riz test_case_xfail shrink_48M_16M_v2_16384 "PR bin/44205" resize_ffs 16384 2048 98304 32768 2 87 93 1.7 riz test_case_xfail shrink_48M_16M_v2_32768 "PR bin/44205" resize_ffs 32768 4096 98304 32768 2 83 94 1.7 riz test_case_xfail shrink_48M_16M_v2_65536 "PR bin/44205" resize_ffs 65536 8192 98304 32768 2 76 95 1.7 riz test_case_xfail shrink_64M_48M_v2_4096 "PR bin/44205" resize_ffs 4096 512 131072 98304 2 109 96 1.7 riz test_case_xfail shrink_64M_48M_v2_8192 "PR bin/44205" resize_ffs 8192 1024 131072 98304 2 111 97 1.7 riz test_case_xfail shrink_64M_48M_v2_16384 "PR bin/44205" resize_ffs 16384 2048 131072 98304 2 115 98 1.7 riz test_case_xfail shrink_64M_48M_v2_32768 "PR bin/44205" resize_ffs 32768 4096 131072 98304 2 111 99 1.5 riz test_case_xfail shrink_64M_48M_v2_65536 "PR bin/44205" resize_ffs 65536 8192 131072 98304 2 101 100 1.7 riz 101 1.1 riz 102 1.1 riz atf_test_case shrink_ffsv1_partial_cg 103 1.1 riz shrink_ffsv1_partial_cg_head() 104 1.1 riz { 105 1.1 riz atf_set "descr" "Checks successful shrinkage of ffsv1 by" \ 106 1.1 riz "less than a cylinder group" 107 1.1 riz } 108 1.1 riz shrink_ffsv1_partial_cg_body() 109 1.1 riz { 110 1.1 riz echo "*** resize_ffs shrinkage partial cg test" 111 1.1 riz 112 1.1 riz atf_check -o ignore -e ignore newfs -V1 -F -s 5760 ${IMG} 113 1.1 riz 114 1.1 riz # shrink so there's a partial cg at the end 115 1.8 chopps atf_check -s exit:0 resize_ffs -c -s 4000 -y ${IMG} 116 1.1 riz atf_check -s exit:0 resize_ffs -s 4000 -y ${IMG} 117 1.1 riz atf_check -s exit:0 -o ignore fsck_ffs -f -n -F ${IMG} 118 1.8 chopps atf_check -s exit:1 resize_ffs -c -s 4000 -y ${IMG} 119 1.1 riz } 120 1.1 riz 121 1.1 riz atf_init_test_cases() 122 1.1 riz { 123 1.1 riz setupvars 124 1.7 riz atf_add_test_case shrink_24M_16M_v0_32768 125 1.7 riz atf_add_test_case shrink_24M_16M_v1_65536 126 1.7 riz atf_add_test_case shrink_24M_16M_v2_4096 127 1.7 riz if [ "${RESIZE_FFS_ALL_TESTS-X}" != "X" ]; then 128 1.7 riz atf_add_test_case shrink_24M_16M_v0_4096 129 1.7 riz atf_add_test_case shrink_24M_16M_v0_8192 130 1.7 riz atf_add_test_case shrink_24M_16M_v0_16384 131 1.7 riz atf_add_test_case shrink_24M_16M_v0_65536 132 1.1 riz atf_add_test_case shrink_24M_16M_v1_4096 133 1.1 riz atf_add_test_case shrink_24M_16M_v1_8192 134 1.1 riz atf_add_test_case shrink_24M_16M_v1_16384 135 1.1 riz atf_add_test_case shrink_24M_16M_v1_32768 136 1.7 riz atf_add_test_case shrink_24M_16M_v2_8192 137 1.7 riz atf_add_test_case shrink_24M_16M_v2_16384 138 1.7 riz atf_add_test_case shrink_24M_16M_v2_32768 139 1.7 riz atf_add_test_case shrink_24M_16M_v2_65536 140 1.7 riz atf_add_test_case shrink_32M_24M_v0_4096 141 1.7 riz atf_add_test_case shrink_32M_24M_v0_8192 142 1.7 riz atf_add_test_case shrink_32M_24M_v0_16384 143 1.7 riz atf_add_test_case shrink_32M_24M_v0_32768 144 1.7 riz atf_add_test_case shrink_32M_24M_v0_65536 145 1.7 riz atf_add_test_case shrink_48M_16M_v0_4096 146 1.7 riz atf_add_test_case shrink_48M_16M_v0_8192 147 1.7 riz atf_add_test_case shrink_48M_16M_v0_16384 148 1.7 riz atf_add_test_case shrink_48M_16M_v0_32768 149 1.7 riz atf_add_test_case shrink_48M_16M_v0_65536 150 1.7 riz atf_add_test_case shrink_64M_48M_v0_4096 151 1.7 riz atf_add_test_case shrink_64M_48M_v0_8192 152 1.7 riz atf_add_test_case shrink_64M_48M_v0_16384 153 1.7 riz atf_add_test_case shrink_64M_48M_v0_32768 154 1.7 riz atf_add_test_case shrink_64M_48M_v0_65536 155 1.1 riz atf_add_test_case shrink_32M_24M_v1_4096 156 1.1 riz atf_add_test_case shrink_32M_24M_v1_8192 157 1.1 riz atf_add_test_case shrink_32M_24M_v1_16384 158 1.1 riz atf_add_test_case shrink_32M_24M_v1_32768 159 1.1 riz atf_add_test_case shrink_32M_24M_v1_65536 160 1.1 riz atf_add_test_case shrink_48M_16M_v1_4096 161 1.1 riz atf_add_test_case shrink_48M_16M_v1_8192 162 1.1 riz atf_add_test_case shrink_48M_16M_v1_16384 163 1.1 riz atf_add_test_case shrink_48M_16M_v1_32768 164 1.1 riz atf_add_test_case shrink_48M_16M_v1_65536 165 1.1 riz atf_add_test_case shrink_64M_48M_v1_4096 166 1.1 riz atf_add_test_case shrink_64M_48M_v1_8192 167 1.1 riz atf_add_test_case shrink_64M_48M_v1_16384 168 1.1 riz atf_add_test_case shrink_64M_48M_v1_32768 169 1.1 riz atf_add_test_case shrink_64M_48M_v1_65536 170 1.7 riz atf_add_test_case shrink_32M_24M_v2_4096 171 1.7 riz atf_add_test_case shrink_32M_24M_v2_8192 172 1.7 riz atf_add_test_case shrink_32M_24M_v2_16384 173 1.7 riz atf_add_test_case shrink_32M_24M_v2_32768 174 1.7 riz atf_add_test_case shrink_32M_24M_v2_65536 175 1.7 riz atf_add_test_case shrink_48M_16M_v2_4096 176 1.7 riz atf_add_test_case shrink_48M_16M_v2_8192 177 1.7 riz atf_add_test_case shrink_48M_16M_v2_16384 178 1.7 riz atf_add_test_case shrink_48M_16M_v2_32768 179 1.7 riz atf_add_test_case shrink_48M_16M_v2_65536 180 1.7 riz atf_add_test_case shrink_64M_48M_v2_4096 181 1.7 riz atf_add_test_case shrink_64M_48M_v2_8192 182 1.7 riz atf_add_test_case shrink_64M_48M_v2_16384 183 1.7 riz atf_add_test_case shrink_64M_48M_v2_32768 184 1.1 riz atf_add_test_case shrink_64M_48M_v2_65536 185 1.2 riz fi 186 1.1 riz atf_add_test_case shrink_ffsv1_partial_cg 187 1.1 riz } 188