PageRenderTime 25ms CodeModel.GetById 16ms RepoModel.GetById 0ms app.codeStats 0ms

/tests/sys/cddl/zfs/tests/hotplug/hotplug_008_pos.ksh

https://bitbucket.org/freebsd/freebsd-base
Korn Shell | 74 lines | 11 code | 9 blank | 54 comment | 1 complexity | 05372e3016df54674ed7c887522e0cfb 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 "@(#)hotplug_008_pos.ksh 1.3 08/02/27 SMI"
  28. #
  29. . $STF_SUITE/tests/hotplug/hotplug.kshlib
  30. #################################################################################
  31. #
  32. # __stc_assertion_start
  33. #
  34. # ID: hotplug_008_pos
  35. #
  36. # DESCRIPTION:
  37. # After hot spare device is revoved, the devices state will be 'REMOVED'.
  38. # No FMA faults was generated.
  39. #
  40. # STRATEGY:
  41. # 1. Create mirror/raidz/raidz2 pool with hot spare device.
  42. # 2. Synchronise with device in the background.
  43. # 3. Remove the hotspare device.
  44. # 4. Verify the device's status is 'REMOVED'.
  45. # 5. Verify no FMA fault was generated.
  46. #
  47. # TESTABILITY: explicit
  48. #
  49. # TEST_AUTOMATION_LEVEL: automated
  50. #
  51. # CODING_STATUS: COMPLETED (2007-06-01)
  52. #
  53. # __stc_assertion_end
  54. #
  55. ################################################################################
  56. log_assert "When removing hotspare device, verify device status is 'REMOVED'."
  57. for type in "mirror" "raidz" "raidz2"; do
  58. log_must $ZPOOL create -f $TESTPOOL $type $DISK0.nop $DISK1.nop $DISK2.nop spare $DISK3.nop
  59. log_must destroy_gnop $DISK3
  60. wait_for 15 1 check_state $TESTPOOL $DISK3.nop 'REMOVED'
  61. log_must check_state $TESTPOOL $DISK3.nop 'REMOVED'
  62. log_must create_gnop $DISK3
  63. cleanup_testenv $TESTPOOL
  64. done
  65. log_pass "When removing hotspare device, verify device status is 'REMOVED'."