PageRenderTime 70ms CodeModel.GetById 17ms RepoModel.GetById 1ms app.codeStats 0ms

/tests/sys/cddl/zfs/tests/zvol/zvol_misc/zvol_misc_002_pos.ksh

https://bitbucket.org/freebsd/freebsd-base
Korn Shell | 89 lines | 23 code | 14 blank | 52 comment | 5 complexity | 580a60689e1738d4941b83691123790e 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 2008 Sun Microsystems, Inc. All rights reserved.
  25. # Use is subject to license terms.
  26. #
  27. # ident "@(#)zvol_misc_002_pos.ksh 1.4 08/02/27 SMI"
  28. #
  29. . $STF_SUITE/include/libtest.kshlib
  30. ###############################################################################
  31. #
  32. # __stc_assertion_start
  33. #
  34. # ID: zvol_misc_002_pos
  35. #
  36. # DESCRIPTION:
  37. # Verify that ZFS volume snapshot could be fscked
  38. #
  39. # STRATEGY:
  40. # 1. Create a ZFS volume
  41. # 2. Copy some files and create snapshot
  42. # 3. Verify fsck on the snapshot is OK
  43. #
  44. # TESTABILITY: explicit
  45. #
  46. # TEST_AUTOMATION_LEVEL: automated
  47. #
  48. # CODING_STATUS: COMPLETED (2006-10-13)
  49. #
  50. # __stc_assertion_end
  51. #
  52. ################################################################################
  53. verify_runnable "global"
  54. function cleanup
  55. {
  56. snapexists $TESTPOOL/$TESTVOL@snap && \
  57. $ZFS destroy $TESTPOOL/$TESTVOL@snap
  58. ismounted $TESTDIR ufs && log_must $UMOUNT $TESTDIR
  59. [[ -e $TESTDIR ]] && $RM -rf $TESTDIR
  60. }
  61. log_assert "Verify that ZFS volume snapshot could be fscked"
  62. log_onexit cleanup
  63. $NEWFS /dev/zvol/$TESTPOOL/$TESTVOL >/dev/null 2>&1
  64. (( $? != 0 )) && log_fail "Unable to newfs(1M) $TESTPOOL/$TESTVOL"
  65. log_must $MKDIR $TESTDIR
  66. log_must $MOUNT /dev/zvol/$TESTPOOL/$TESTVOL $TESTDIR
  67. typeset -i fn=0
  68. typeset -i retval=0
  69. # Write about 200MB of data.
  70. populate_dir $TESTDIR/testfile 5 $NUM_WRITES $BLOCKSZ 0
  71. log_must sync
  72. log_must $MOUNT -o rw -u $TESTDIR
  73. log_must $ZFS snapshot $TESTPOOL/$TESTVOL@snap
  74. log_must $FSCK -t ufs -n /dev/zvol/$TESTPOOL/$TESTVOL@snap >/dev/null 2>&1
  75. log_pass "Verify that ZFS volume snapshot could be fscked"