mirror_zfs/tests/zfs-tests/tests/functional/migration/migration.kshlib
наб 23914a3b91 tests: review every instance of $?
Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Reviewed-by: John Kennedy <john.kennedy@delphix.com>
Reviewed-by: Ryan Moeller <ryan@iXsystems.com>
Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz>
Closes #13259
2022-04-01 17:59:30 -07:00

126 lines
2.8 KiB
Plaintext

#
# CDDL HEADER START
#
# The contents of this file are subject to the terms of the
# Common Development and Distribution License (the "License").
# You may not use this file except in compliance with the License.
#
# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
# or http://www.opensolaris.org/os/licensing.
# See the License for the specific language governing permissions
# and limitations under the License.
#
# When distributing Covered Code, include this CDDL HEADER in each
# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
# If applicable, add the following below this CDDL HEADER, with the
# fields enclosed by brackets "[]" replaced with your own identifying
# information: Portions Copyright [yyyy] [name of copyright owner]
#
# CDDL HEADER END
#
#
# Copyright 2007 Sun Microsystems, Inc. All rights reserved.
# Use is subject to license terms.
#
#
# Copyright (c) 2013, 2016 by Delphix. All rights reserved.
#
. $STF_SUITE/tests/functional/migration/migration.cfg
#
# This function creates the test archive for migration.
#
# Usage:
# prepare srcdir cmd
#
# Return value: 0 on success
# 1 on failure
#
# Where:
# srcdir: is the directory where the testfile is
# cmd: is the command to be executed.
# E.g.
# tar cf $TESTDIR/tar$$.tar
#
function prepare #srcdir cmd
{
typeset srcdir=$1
typeset cmd=$2
cwd=$PWD
cd $srcdir || return 1
$cmd || return 1
cd $cwd || return 1
}
#
# This function executes a passed in command and then determines the chksum
# of the resulting file. The chksum components are checked against the ones
# passed in to determine if they are equal. If they are equal, 0 is returned
# otherwise 1 is returned.
#
# Usage:
# migrate destdir oldsuma oldsumb command_to_execute
#
# Return value: 0 on success
# 1 on failure
#
# Where:
# destdir: is the directory where the command is to be executed on
# oldsuma: is the first part of the values returned by sum
# oldsumb: is the second part of the values returned by sum
# cmd: is the command to be executed;
# E.g.
# "tar xf $TESTDIR/tar$$.tar"
#
function migrate #destdir oldsuma oldsumb cmd
{
typeset destdir=$1
typeset oldsuma=$2
typeset oldsumb=$3
typeset cmd=$4
cwd=$PWD
cd $destdir || return 1
$cmd || return 1
read -r suma sumb _ < <(cksum ./$BNAME)
cd $cwd || return 1
if (( $oldsuma != $suma )); then
log_note "sum values are not the same"
return 1
fi
if (( $oldsumb != $sumb )); then
log_note "sum values are not the same"
return 1
fi
}
function migrate_cpio
{
typeset destdir=$1
typeset archive=$2
typeset oldsuma=$3
typeset oldsumb=$4
cwd=$PWD
cd $destdir || return 1
cpio -iv < $archive || return 1
read -r suma sumb _ < <(cksum ./$BNAME)
cd $cwd
if (( $oldsuma != $suma )); then
log_note "sum values are not the same"
return 1
fi
if (( $oldsumb != $sumb )); then
log_note "sum values are not the same"
return 1
fi
}