PageRenderTime 29ms CodeModel.GetById 29ms RepoModel.GetById 0ms app.codeStats 0ms

/tests/sys/cddl/zfs/tests/cli_root/zfs_receive/zfs_receive_003_pos.ksh

https://bitbucket.org/freebsd/freebsd-base
Korn Shell | 107 lines | 38 code | 14 blank | 55 comment | 11 complexity | 9b391edaeb5a407fdcd055d6016c7698 MD5 | raw file
  1. #!/usr/local/bin/ksh93 -p
  2. #
  3. # CDDL HEADER START
  4. #
  5. # The contents of this file are subject to the terms of the
  6. # Common Development and Distribution License (the "License").
  7. # You may not use this file except in compliance with the License.
  8. #
  9. # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
  10. # or http://www.opensolaris.org/os/licensing.
  11. # See the License for the specific language governing permissions
  12. # and limitations under the License.
  13. #
  14. # When distributing Covered Code, include this CDDL HEADER in each
  15. # file and include the License file at usr/src/OPENSOLARIS.LICENSE.
  16. # If applicable, add the following below this CDDL HEADER, with the
  17. # fields enclosed by brackets "[]" replaced with your own identifying
  18. # information: Portions Copyright [yyyy] [name of copyright owner]
  19. #
  20. # CDDL HEADER END
  21. #
  22. # $FreeBSD$
  23. #
  24. # Copyright 2007 Sun Microsystems, Inc. All rights reserved.
  25. # Use is subject to license terms.
  26. #
  27. # ident "@(#)zfs_receive_003_pos.ksh 1.2 07/01/09 SMI"
  28. #
  29. . $STF_SUITE/include/libtest.kshlib
  30. #################################################################################
  31. #
  32. # __stc_assertion_start
  33. #
  34. # ID: zfs_receive_003_pos
  35. #
  36. # DESCRIPTION:
  37. # 'zfs recv -F' to force rollback.
  38. #
  39. # STRATEGY:
  40. # 1. Create pool and fs.
  41. # 2. Create some files in fs and take a snapshot1.
  42. # 3. Create another files in fs and take snapshot2.
  43. # 4. Create incremental stream from snapshot1 to snapshot2.
  44. # 5. fs rollback to snapshot1 and modify fs.
  45. # 6. Verify 'zfs recv -F' can force rollback.
  46. #
  47. # TESTABILITY: explicit
  48. #
  49. # TEST_AUTOMATION_LEVEL: automated
  50. #
  51. # CODING_STATUS: COMPLETED (2006-07-18)
  52. #
  53. # __stc_assertion_end
  54. #
  55. ################################################################################
  56. verify_runnable "both"
  57. function cleanup
  58. {
  59. for snap in $snap2 $snap1; do
  60. datasetexists $snap && log_must $ZFS destroy -rf $snap
  61. done
  62. for file in $ibackup $mntpnt/file1 $mntpnt/file2; do
  63. [[ -f $file ]] && log_must $RM -f $file
  64. done
  65. }
  66. log_assert "'zfs recv -F' to force rollback."
  67. log_onexit cleanup
  68. ibackup=$TMPDIR/ibackup.${TESTCASE_ID}
  69. fs=$TESTPOOL/$TESTFS; snap1=$fs@snap1; snap2=$fs@snap2
  70. mntpnt=$(get_prop mountpoint $fs) || log_fail "get_prop mountpoint $fs"
  71. log_must $MKFILE 10m $mntpnt/file1
  72. log_must $ZFS snapshot $snap1
  73. log_must $MKFILE 10m $mntpnt/file2
  74. log_must $ZFS snapshot $snap2
  75. log_must eval "$ZFS send -i $snap1 $snap2 > $ibackup"
  76. log_note "Verify 'zfs receive' succeed, if filesystem was not modified."
  77. log_must $ZFS rollback -r $snap1
  78. log_must eval "$ZFS receive $fs < $ibackup"
  79. if [[ ! -f $mntpnt/file1 || ! -f $mntpnt/file2 ]]; then
  80. log_fail "'$ZFS receive' failed."
  81. fi
  82. log_note "Verify 'zfs receive' failed if filesystem was modified."
  83. log_must $ZFS rollback -r $snap1
  84. log_must $RM -rf $mntpnt/file1
  85. log_mustnot eval "$ZFS receive $fs < $ibackup"
  86. # Verify 'zfs receive -F' to force rollback whatever filesystem was modified.
  87. log_must $ZFS rollback -r $snap1
  88. log_must $RM -rf $mntpnt/file1
  89. log_must eval "$ZFS receive -F $fs < $ibackup"
  90. if [[ ! -f $mntpnt/file1 || ! -f $mntpnt/file2 ]]; then
  91. log_fail "'$ZFS receive -F' failed."
  92. fi
  93. log_pass "'zfs recv -F' to force rollback passed."