Mercurial > illumos > illumos-gate
view usr/src/test/zfs-tests/tests/functional/nopwrite/nopwrite_varying_compression.ksh @ 13899:0bcf78798346
3311 Want a test framework for arbitrary OS unit tests
3312 Add a testrunner package for OS unit tests
3313 Add a testrunner package to convert ZFS tests from STF
Reviewed by: Matt Ahrens <matthew.ahrens@delphix.com>
Reviewed by: Will Guyette <will.guyette@delphix.com>
Reviewed by: Dan Kimmel <dan.kimmel@delphix.com>
Reviewed by: Adam Leventhal <ahl@delphix.com>
Reviewed by: Henrik Mattson <henrik.mattson@delphix.com>
Reviewed by: Sonu Pillai <sonu.pillai@delphix.com>
Reviewed by: Christopher Siden <chris.siden@delphix.com>
Reviewed by: George Wilson <george.wilson@delphix.com>
Reviewed by: Richard Lowe <richlowe@richlowe.net>
Approved by: Richard Lowe <richlowe@richlowe.net>
author | John Wren Kennedy <john.kennedy@delphix.com> |
---|---|
date | Wed, 05 Dec 2012 22:04:50 -0500 |
parents | |
children |
line wrap: on
line source
#!/usr/bin/ksh # # This file and its contents are supplied under the terms of the # Common Development and Distribution License ("CDDL"), version 1.0. # You may only use this file in accordance with the terms of version # 1.0 of the CDDL. # # A full copy of the text of the CDDL should have accompanied this # source. A copy of the CDDL is also available via the Internet at # http://www.illumos.org/license/CDDL. # # # Copyright (c) 2012 by Delphix. All rights reserved. # . $STF_SUITE/include/libtest.shlib . $STF_SUITE/include/properties.shlib . $STF_SUITE/tests/functional/nopwrite/nopwrite.shlib # # Description: # Verify that if the checksum on the origin and clone is sha256, any compression # algorithm enables nopwrite. # # Strategy: # 1. Create an origin dataset with compression and sha256 checksum. # 2. Write a 64M file into the origin dataset. # 3. For each of 4 randomly chosen compression types: # 3a. Create a snap and clone (inheriting the checksum property) of the origin. # 3b. Apply the compression property to the clone. # 3c. Write the same 64M of data into the file that exists in the clone. # 3d. Verify that no new space was consumed. # verify_runnable "global" origin="$TESTPOOL/$TESTFS" log_onexit cleanup function cleanup { datasetexists $origin && log_must $ZFS destroy -R $origin log_must $ZFS create -o mountpoint=$TESTDIR $origin } log_assert "nopwrite works with sha256 and any compression algorithm" log_must $ZFS set compress=on $origin log_must $ZFS set checksum=sha256 $origin $DD if=/dev/urandom of=$TESTDIR/file bs=1024k count=$MEGS conv=notrunc \ >/dev/null 2>&1 || log_fail "initial dd failed." # Verify nop_write for 4 random compression algorithms for i in $(get_rand_compress 4); do $ZFS snapshot $origin@a || log_fail "zfs snap failed" log_must $ZFS clone -o compress=$i $origin@a $origin/clone $DD if=/$TESTDIR/file of=/$TESTDIR/clone/file bs=1024k count=$MEGS \ conv=notrunc >/dev/null 2>&1 || log_fail "dd failed." log_must verify_nopwrite $origin $origin@a $origin/clone $ZFS destroy -R $origin@a || log_fail "zfs destroy failed" done log_pass "nopwrite works with sha256 and any compression algorithm"