003 File Manager
Current Path:
/usr/src/tests/sys/cddl/zfs/tests/cli_root/zfs_receive
usr
/
src
/
tests
/
sys
/
cddl
/
zfs
/
tests
/
cli_root
/
zfs_receive
/
📁
..
📄
Makefile
(738 B)
📄
cleanup.ksh
(1.07 KB)
📄
setup.ksh
(1.09 KB)
📄
zfs_receive.cfg
(1.06 KB)
📄
zfs_receive_001_pos.ksh
(4.9 KB)
📄
zfs_receive_002_pos.ksh
(3.05 KB)
📄
zfs_receive_003_pos.ksh
(3.08 KB)
📄
zfs_receive_004_neg.ksh
(3.26 KB)
📄
zfs_receive_005_neg.ksh
(3.14 KB)
📄
zfs_receive_006_pos.ksh
(3.57 KB)
📄
zfs_receive_007_neg.ksh
(2.68 KB)
📄
zfs_receive_008_pos.ksh
(4.47 KB)
📄
zfs_receive_009_neg.ksh
(3.39 KB)
📄
zfs_receive_test.sh
(7.09 KB)
Editing: zfs_receive_001_pos.ksh
#!/usr/local/bin/ksh93 -p # # CDDL HEADER START # # The contents of this file are subject to the terms of the # Common Development and Distribution License (the "License"). # You may not use this file except in compliance with the License. # # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE # or http://www.opensolaris.org/os/licensing. # See the License for the specific language governing permissions # and limitations under the License. # # When distributing Covered Code, include this CDDL HEADER in each # file and include the License file at usr/src/OPENSOLARIS.LICENSE. # If applicable, add the following below this CDDL HEADER, with the # fields enclosed by brackets "[]" replaced with your own identifying # information: Portions Copyright [yyyy] [name of copyright owner] # # CDDL HEADER END # # $FreeBSD$ # # Copyright 2008 Sun Microsystems, Inc. All rights reserved. # Use is subject to license terms. # # ident "@(#)zfs_receive_001_pos.ksh 1.4 08/02/27 SMI" # . $STF_SUITE/tests/cli_root/cli_common.kshlib ################################################################################# # # __stc_assertion_start # # ID: zfs_receive_001_pos # # DESCRIPTION: # Verifying 'zfs receive [<filesystem|snapshot>] -d <filesystem>' works. # # STRATEGY: # 1. Fill in fs with some data # 2. Create full and incremental send stream # 3. Receive the send stream # 4. Verify the restoring results. # # TESTABILITY: explicit # # TEST_AUTOMATION_LEVEL: automated # # CODING_STATUS: COMPLETED (2005-09-06) # # __stc_assertion_end # ################################################################################ verify_runnable "both" function cleanup { typeset -i i=0 datasetexists $rst_root && \ log_must $ZFS destroy -Rf $rst_root while (( i < 2 )); do snapexists ${orig_snap[$i]} && \ log_must $ZFS destroy -f ${orig_snap[$i]} log_must $RM -f ${bkup[$i]} (( i = i + 1 )) done log_must $RM -rf $TESTDIR1 } function recreate_root { datasetexists $rst_root && \ log_must $ZFS destroy -Rf $rst_root if [[ -d $TESTDIR1 ]] ; then log_must $RM -rf $TESTDIR1 fi log_must $ZFS create $rst_root log_must $ZFS set mountpoint=$TESTDIR1 $rst_root } log_assert "Verifying 'zfs receive [<filesystem|snapshot>] -d <filesystem>' works." log_onexit cleanup typeset datasets="$TESTPOOL/$TESTFS $TESTPOOL" set -A bkup "$TMPDIR/fullbkup" "$TMPDIR/incbkup" orig_sum="" rst_sum="" rst_root=$TESTPOOL/rst_ctr rst_fs=${rst_root}/$TESTFS for orig_fs in $datasets ; do # # Preparations for testing # recreate_root set -A orig_snap "${orig_fs}@init_snap" "${orig_fs}@inc_snap" typeset mntpnt=$(get_prop mountpoint ${orig_fs}) set -A orig_data "${mntpnt}/$TESTFILE1" "${mntpnt}/$TESTFILE2" typeset relative_path="" if [[ ${orig_fs} == *"/"* ]]; then relative_path=${orig_fs#*/} fi typeset leaf_fs=${rst_root}/${relative_path} leaf_fs=${leaf_fs%/} rst_snap=${leaf_fs}@snap set -A rst_snap "$rst_root/$TESTFS@init_snap" "$rst_root/$TESTFS@inc_snap" set -A rst_snap2 "${leaf_fs}@init_snap" "${leaf_fs}@inc_snap" set -A rst_data "$TESTDIR1/$TESTFS/$TESTFILE1" "$TESTDIR1/$TESTFS/$TESTFILE2" set -A rst_data2 "$TESTDIR1/${relative_path}/$TESTFILE1" "$TESTDIR1/${relative_path}/$TESTFILE2" typeset -i i=0 while (( i < ${#orig_snap[*]} )); do log_must $FILE_WRITE -o create -f ${orig_data[$i]} \ -b $BLOCK_SIZE -c $WRITE_COUNT log_must $ZFS snapshot ${orig_snap[$i]} if (( i < 1 )); then log_must eval "$ZFS send ${orig_snap[$i]} > ${bkup[$i]}" else log_must eval "$ZFS send -i ${orig_snap[(( i - 1 ))]} \ ${orig_snap[$i]} > ${bkup[$i]}" fi (( i = i + 1 )) done log_note "Verifying 'zfs receive <filesystem>' works." i=0 while (( i < ${#bkup[*]} )); do if (( i > 0 )); then log_must $ZFS rollback ${rst_snap[0]} fi log_must eval "$ZFS receive $rst_fs < ${bkup[$i]}" snapexists ${rst_snap[$i]} || \ log_fail "Restoring filesystem fails. ${rst_snap[$i]} not exist" compare_cksum ${orig_data[$i]} ${rst_data[$i]} (( i = i + 1 )) done log_must $ZFS destroy -Rf $rst_fs log_note "Verifying 'zfs receive <snapshot>' works." i=0 while (( i < ${#bkup[*]} )); do if (( i > 0 )); then log_must $ZFS rollback ${rst_snap[0]} fi log_must eval "$ZFS receive ${rst_snap[$i]} <${bkup[$i]}" snapexists ${rst_snap[$i]} || \ log_fail "Restoring filesystem fails. ${rst_snap[$i]} not exist" compare_cksum ${orig_data[$i]} ${rst_data[$i]} (( i = i + 1 )) done log_must $ZFS destroy -Rf $rst_fs log_note "Verfiying 'zfs receive -d <filesystem>' works." i=0 while (( i < ${#bkup[*]} )); do if (( i > 0 )); then log_must $ZFS rollback ${rst_snap2[0]} fi log_must eval "$ZFS receive -d -F $rst_root <${bkup[$i]}" snapexists ${rst_snap2[$i]} || \ log_fail "Restoring filesystem fails. ${rst_snap2[$i]} not exist" compare_cksum ${orig_data[$i]} ${rst_data2[$i]} (( i = i + 1 )) done cleanup done log_pass "Verifying 'zfs receive [<filesystem|snapshot>] -d <filesystem>' succeeds."
Upload File
Create Folder