dmake: do not set MAKEFLAGS=k
[unleashed/tickless.git] / usr / src / test / zfs-tests / tests / functional / rsend / rsend_019_pos.ksh
blob79c9bb6d9b62f0b9be94d1aae198aef2e480b7ed
1 #!/usr/bin/ksh
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
7 # 1.0 of the CDDL.
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
22 # Description:
23 # Verify resumability of a full and incremental ZFS send/receive in the
24 # presence of a corrupted stream.
26 # Strategy:
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
42 sendfs=$POOL/sendfs
43 recvfs=$POOL3/recvfs
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
51 done
53 log_pass "Verify resumability of a full and incremental ZFS send/receive " \
54 "in the presence of a corrupted stream"