t_shrink.sh revision 1.8 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