HardenedBSD/tools/regression/zfs/zpool/replace/mirror.t
Pawel Jakub Dawidek 1ba4a712dd Update ZFS from version 6 to 13 and bring some FreeBSD-specific changes.
This bring huge amount of changes, I'll enumerate only user-visible changes:

- Delegated Administration

	Allows regular users to perform ZFS operations, like file system
	creation, snapshot creation, etc.

- L2ARC

	Level 2 cache for ZFS - allows to use additional disks for cache.
	Huge performance improvements mostly for random read of mostly
	static content.

- slog

	Allow to use additional disks for ZFS Intent Log to speed up
	operations like fsync(2).

- vfs.zfs.super_owner

	Allows regular users to perform privileged operations on files stored
	on ZFS file systems owned by him. Very careful with this one.

- chflags(2)

	Not all the flags are supported. This still needs work.

- ZFSBoot

	Support to boot off of ZFS pool. Not finished, AFAIK.

	Submitted by:	dfr

- Snapshot properties

- New failure modes

	Before if write requested failed, system paniced. Now one
	can select from one of three failure modes:
	- panic - panic on write error
	- wait - wait for disk to reappear
	- continue - serve read requests if possible, block write requests

- Refquota, refreservation properties

	Just quota and reservation properties, but don't count space consumed
	by children file systems, clones and snapshots.

- Sparse volumes

	ZVOLs that don't reserve space in the pool.

- External attributes

	Compatible with extattr(2).

- NFSv4-ACLs

	Not sure about the status, might not be complete yet.

	Submitted by:	trasz

- Creation-time properties

- Regression tests for zpool(8) command.

Obtained from:	OpenSolaris
2008-11-17 20:49:29 +00:00

135 lines
4.7 KiB
Bash

#!/bin/sh
# $FreeBSD$
dir=`dirname $0`
. ${dir}/../../misc.sh
echo "1..27"
disks_create 3
names_create 1
expect_ok ${ZPOOL} create ${name0} mirror ${disk0} ${disk1}
expect_ok ${ZPOOL} export ${name0}
dname0=${disk0}
fdname0=${fdisk0}
guid0=`get_guid ${fdisk0}`
disk_destroy 0
disk_create 0 ${dname0}
expect_ok ${ZPOOL} import ${import_flags} ${name0}
exp=`(
echo " pool: ${name0}"
echo " state: DEGRADED"
echo "status: One or more devices could not be used because the label is missing or"
echo " invalid. Sufficient replicas exist for the pool to continue"
echo " functioning in a degraded state."
echo "action: Replace the device using 'zpool replace'."
echo " see: http://www.sun.com/msg/ZFS-8000-4J"
echo " scrub: none requested"
echo "config:"
echo " NAME STATE READ WRITE CKSUM"
echo " ${name0} DEGRADED 0 0 0"
echo " mirror DEGRADED 0 0 0"
echo " ${guid0} UNAVAIL 0 0 0 was ${fdname0}"
echo " ${disk1} ONLINE 0 0 0"
echo "errors: No known data errors"
)`
expect "${exp}" ${ZPOOL} status ${name0}
expect_ok ${ZPOOL} replace ${name0} ${disk0} ${disk2}
wait_for_resilver ${name0}
exp=`(
echo " pool: ${name0}"
echo " state: ONLINE"
echo " scrub: (scrub|resilver) completed after [0-9]+h[0-9]+m with 0 errors on .*"
echo "config:"
echo " NAME STATE READ WRITE CKSUM"
echo " ${name0} ONLINE 0 0 0"
echo " mirror ONLINE 0 0 0"
echo " ${disk2} ONLINE 0 0 0( [0-9.]+[A-Z] resilvered)?"
echo " ${disk1} ONLINE 0 0 0( [0-9.]+[A-Z] resilvered)?"
echo "errors: No known data errors"
)`
expect "${exp}" ${ZPOOL} status ${name0}
expect_ok ${ZPOOL} destroy ${name0}
expect_fl ${ZPOOL} status -x ${name0}
expect_ok ${ZPOOL} create ${name0} mirror ${disk0} ${disk1}
expect_ok ${ZPOOL} replace ${name0} ${disk1} ${disk2}
wait_for_resilver ${name0}
exp=`(
echo " pool: ${name0}"
echo " state: ONLINE"
echo " scrub: (scrub|resilver) completed after [0-9]+h[0-9]+m with 0 errors on .*"
echo "config:"
echo " NAME STATE READ WRITE CKSUM"
echo " ${name0} ONLINE 0 0 0"
echo " mirror ONLINE 0 0 0"
echo " ${disk0} ONLINE 0 0 0( [0-9.]+[A-Z] resilvered)?"
echo " ${disk2} ONLINE 0 0 0( [0-9.]+[A-Z] resilvered)?"
echo "errors: No known data errors"
)`
expect "${exp}" ${ZPOOL} status ${name0}
expect_ok ${ZPOOL} destroy ${name0}
expect_fl ${ZPOOL} status -x ${name0}
expect_ok ${ZPOOL} create ${name0} mirror ${disk0} ${disk1}
expect_ok ${ZPOOL} export ${name0}
dname0=${disk0}
fdname0=${fdisk0}
guid0=`get_guid ${fdisk0}`
disk_destroy 0
expect_ok ${ZPOOL} import ${import_flags} ${name0}
exp=`(
echo " pool: ${name0}"
echo " state: DEGRADED"
echo " scrub: none requested"
echo "config:"
echo " NAME STATE READ WRITE CKSUM"
echo " ${name0} DEGRADED 0 0 0"
echo " mirror DEGRADED 0 0 0"
echo " ${guid0} REMOVED 0 0 0 was ${fdname0}"
echo " ${disk1} ONLINE 0 0 0"
echo "errors: No known data errors"
)`
expect "${exp}" ${ZPOOL} status ${name0}
expect_ok ${ZPOOL} replace ${name0} ${dname0} ${disk2}
wait_for_resilver ${name0}
exp=`(
echo " pool: ${name0}"
echo " state: ONLINE"
echo " scrub: (scrub|resilver) completed after [0-9]+h[0-9]+m with 0 errors on .*"
echo "config:"
echo " NAME STATE READ WRITE CKSUM"
echo " ${name0} ONLINE 0 0 0"
echo " mirror ONLINE 0 0 0"
echo " ${disk2} ONLINE 0 0 0( [0-9.]+[A-Z] resilvered)?"
echo " ${disk1} ONLINE 0 0 0( [0-9.]+[A-Z] resilvered)?"
echo "errors: No known data errors"
)`
expect "${exp}" ${ZPOOL} status ${name0}
expect_ok ${ZPOOL} destroy ${name0}
expect_fl ${ZPOOL} status -x ${name0}
disk_create 0 ${dname0}
expect_ok ${ZPOOL} create ${name0} mirror ${disk0} ${disk1}
expect_ok ${ZPOOL} offline ${name0} ${disk1}
expect_ok ${ZPOOL} replace ${name0} ${disk1} ${disk2}
wait_for_resilver ${name0}
exp=`(
echo " pool: ${name0}"
echo " state: ONLINE"
echo " scrub: (scrub|resilver) completed after [0-9]+h[0-9]+m with 0 errors on .*"
echo "config:"
echo " NAME STATE READ WRITE CKSUM"
echo " ${name0} ONLINE 0 0 0"
echo " mirror ONLINE 0 0 0"
echo " ${disk0} ONLINE 0 0 0( [0-9.]+[A-Z] resilvered)?"
echo " ${disk2} ONLINE 0 0 0( [0-9.]+[A-Z] resilvered)?"
echo "errors: No known data errors"
)`
expect "${exp}" ${ZPOOL} status ${name0}
expect_ok ${ZPOOL} destroy ${name0}
expect_fl ${ZPOOL} status -x ${name0}
disks_destroy