4 # This file and its contents are supplied under the terms of the
5 # Common Development and Distribution License ("CDDL"), version 1.0.
6 # You may only use this file in accordance with the terms of version
9 # A full copy of the text of the CDDL should have accompanied this
10 # source. A copy of the CDDL is also available via the Internet at
11 # http://www.illumos.org/license/CDDL.
15 # Copyright (c) 2014, 2016 by Delphix. All rights reserved.
18 .
$STF_SUITE/include
/libtest.shlib
19 .
$STF_SUITE/tests
/functional
/rsend
/rsend.kshlib
23 # Verify resumability of a full and incremental ZFS send/receive in the
24 # presence of a corrupted stream.
27 # 1. Start a full ZFS send, redirect output to a file
28 # 2. Mess up the contents of the stream state file on disk
29 # 3. Try ZFS receive, which should fail with a checksum mismatch error
30 # 4. ZFS send to the stream state file again using the receive_resume_token
31 # 5. ZFS receieve and verify the receive completes successfully
32 # 6. Repeat steps on an incremental ZFS send
33 # 7. Repeat the entire procedure for a dataset at the pool root
36 verify_runnable
"both"
38 log_assert
"Verify resumability of a full and incremental ZFS send/receive " \
39 "in the presence of a corrupted stream"
40 log_onexit resume_cleanup
$sendfs $streamfs
44 streamfs
=$POOL2/stream
46 for sendfs
in $POOL2/sendfs
$POOL2; do
47 test_fs_setup
$sendfs $recvfs
48 resume_test
"zfs send -v $sendfs@a" $streamfs $recvfs
49 resume_test
"zfs send -v -i @a $sendfs@b" $streamfs $recvfs
50 file_check
$sendfs $recvfs
53 log_pass
"Verify resumability of a full and incremental ZFS send/receive " \
54 "in the presence of a corrupted stream"