Home | History | Annotate | Line # | Download | only in resize_ffs
t_shrink.sh revision 1.7.24.1
      1  1.7.24.1  snj # $NetBSD: t_shrink.sh,v 1.7.24.1 2015/08/06 21:13:44 snj 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.7.24.1  snj 	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.7.24.1  snj 	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