Blame tests/basic/uss.t

Packit b2c0d9
#!/bin/bash
Packit b2c0d9
Packit b2c0d9
. $(dirname $0)/../include.rc
Packit b2c0d9
. $(dirname $0)/../volume.rc
Packit b2c0d9
. $(dirname $0)/../snapshot.rc
Packit b2c0d9
. $(dirname $0)/../fileio.rc
Packit b2c0d9
. $(dirname $0)/../nfs.rc
Packit b2c0d9
Packit b2c0d9
#G_TESTDEF_TEST_STATUS_CENTOS6=NFS_TEST
Packit b2c0d9
Packit b2c0d9
function check_readonly()
Packit b2c0d9
{
Packit b2c0d9
    $@ 2>&1 | grep -q 'Read-only file system'
Packit b2c0d9
    return $?
Packit b2c0d9
}
Packit b2c0d9
Packit b2c0d9
function lookup()
Packit b2c0d9
{
Packit b2c0d9
    ls $1
Packit b2c0d9
    if [ "$?" == "0" ]
Packit b2c0d9
    then
Packit b2c0d9
        echo "Y"
Packit b2c0d9
    else
Packit b2c0d9
        echo "N"
Packit b2c0d9
    fi
Packit b2c0d9
}
Packit b2c0d9
Packit b2c0d9
cleanup;
Packit b2c0d9
TESTS_EXPECTED_IN_LOOP=10
Packit b2c0d9
Packit b2c0d9
TEST init_n_bricks 3;
Packit b2c0d9
TEST setup_lvm 3;
Packit b2c0d9
Packit b2c0d9
TEST glusterd;
Packit b2c0d9
Packit b2c0d9
TEST pidof glusterd;
Packit b2c0d9
Packit b2c0d9
TEST $CLI volume create $V0 $H0:$L1 $H0:$L2 $H0:$L3;
Packit b2c0d9
TEST $CLI volume set $V0 nfs.disable false
Packit b2c0d9
Packit b2c0d9
Packit b2c0d9
TEST $CLI volume start $V0;
Packit b2c0d9
Packit b2c0d9
TEST $GFS --volfile-server=$H0 --volfile-id=$V0 $M0;
Packit b2c0d9
Packit b2c0d9
for i in {1..10} ; do echo "file" > $M0/file$i ; done
Packit b2c0d9
Packit b2c0d9
# Create file and hard-links
Packit b2c0d9
TEST touch $M0/f1
Packit b2c0d9
TEST mkdir $M0/dir
Packit b2c0d9
TEST ln $M0/f1 $M0/f2
Packit b2c0d9
TEST ln $M0/f1 $M0/dir/f3
Packit b2c0d9
Packit b2c0d9
TEST $CLI snapshot config activate-on-create enable
Packit b2c0d9
TEST $CLI volume set $V0 features.uss enable;
Packit b2c0d9
Packit b2c0d9
TEST ! $CLI snapshot create snap1 $V0 no-timestamp description "";
Packit b2c0d9
TEST $CLI snapshot create snap1 $V0 no-timestamp;
Packit b2c0d9
Packit b2c0d9
for i in {11..20} ; do echo "file" > $M0/file$i ; done
Packit b2c0d9
Packit b2c0d9
TEST $CLI snapshot create snap2 $V0 no-timestamp;
Packit b2c0d9
Packit b2c0d9
########### Test inode numbers ###########
Packit b2c0d9
s1_f1_ino=$(STAT_INO $M0/.snaps/snap1/f1)
Packit b2c0d9
TEST [ $s1_f1_ino != 0 ]
Packit b2c0d9
Packit b2c0d9
# Inode number of f1 should be same as f2 f3 within snapshot
Packit b2c0d9
EXPECT $s1_f1_ino STAT_INO $M0/.snaps/snap1/f2
Packit b2c0d9
EXPECT $s1_f1_ino STAT_INO $M0/.snaps/snap1/dir/f3
Packit b2c0d9
EXPECT $s1_f1_ino STAT_INO $M0/dir/.snaps/snap1/f3
Packit b2c0d9
Packit b2c0d9
# Inode number of f1 in snap1 should be different from f1 in snap2
Packit b2c0d9
tmp_ino=$(STAT_INO $M0/.snaps/snap2/f1)
Packit b2c0d9
TEST [ $s1_f1_ino != $tmp_ino ]
Packit b2c0d9
Packit b2c0d9
# Inode number of f1 in snap1 should be different from f1 in regular volume
Packit b2c0d9
tmp_ino=$(STAT_INO $M0/f1)
Packit b2c0d9
TEST [ $s1_f1_ino != $tmp_ino ]
Packit b2c0d9
Packit b2c0d9
# Directory inode of snap1 should be different in each sub-dir
Packit b2c0d9
s1_ino=$(STAT_INO $M0/.snaps/snap1)
Packit b2c0d9
tmp_ino=$(STAT_INO $M0/dir/.snaps/snap1)
Packit b2c0d9
TEST [ $s1_ino != $tmp_ino ]
Packit b2c0d9
##########################################
Packit b2c0d9
Packit b2c0d9
mkdir $M0/dir1;
Packit b2c0d9
mkdir $M0/dir2;
Packit b2c0d9
Packit b2c0d9
for i in {1..10} ; do echo "foo" > $M0/dir1/foo$i ; done
Packit b2c0d9
for i in {1..10} ; do echo "foo" > $M0/dir2/foo$i ; done
Packit b2c0d9
Packit b2c0d9
TEST $CLI snapshot create snap3 $V0 no-timestamp;
Packit b2c0d9
Packit b2c0d9
for i in {11..20} ; do echo "foo" > $M0/dir1/foo$i ; done
Packit b2c0d9
for i in {11..20} ; do echo "foo" > $M0/dir2/foo$i ; done
Packit b2c0d9
Packit b2c0d9
TEST $CLI snapshot create snap4 $V0 no-timestamp;
Packit b2c0d9
## Test that features.uss takes only options enable/disable and throw error for
Packit b2c0d9
## any other argument.
Packit b2c0d9
for i in {1..10}; do
Packit b2c0d9
        RANDOM_STRING=$(uuidgen | tr -dc 'a-zA-Z' | head -c 8)
Packit b2c0d9
        TEST_IN_LOOP ! $CLI volume set $V0 features.uss $RANDOM_STRING
Packit b2c0d9
done
Packit b2c0d9
Packit b2c0d9
## Test that features.snapshot-directory:
Packit b2c0d9
##   contains only '0-9a-z-_'
Packit b2c0d9
#    starts with dot (.)
Packit b2c0d9
#    value cannot exceed 255 characters
Packit b2c0d9
## and throws error for any other argument.
Packit b2c0d9
TEST ! $CLI volume set $V0 features.snapshot-directory a/b
Packit b2c0d9
TEST ! $CLI volume set $V0 features.snapshot-directory snaps
Packit b2c0d9
TEST ! $CLI volume set $V0 features.snapshot-directory -a
Packit b2c0d9
TEST ! $CLI volume set $V0 features.snapshot-directory .
Packit b2c0d9
TEST ! $CLI volume set $V0 features.snapshot-directory ..
Packit b2c0d9
TEST ! $CLI volume set $V0 features.snapshot-directory .123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345
Packit b2c0d9
Packit b2c0d9
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
Packit b2c0d9
Packit b2c0d9
TEST $GFS --volfile-server=$H0 --volfile-id=$V0 $M0;
Packit b2c0d9
Packit b2c0d9
# test 15
Packit b2c0d9
EXPECT_WITHIN $PROCESS_UP_TIMEOUT "4" count_snaps $M0
Packit b2c0d9
Packit b2c0d9
NUM_SNAPS=$(ls $M0/.snaps | wc -l);
Packit b2c0d9
Packit b2c0d9
TEST [ $NUM_SNAPS == 4 ]
Packit b2c0d9
TEST ls $M0/.snaps/snap1;
Packit b2c0d9
TEST ls $M0/.snaps/snap2;
Packit b2c0d9
TEST ls $M0/.snaps/snap3;
Packit b2c0d9
TEST ls $M0/.snaps/snap4;
Packit b2c0d9
Packit b2c0d9
TEST ls $M0/.snaps/snap3/dir1;
Packit b2c0d9
TEST ls $M0/.snaps/snap3/dir2;
Packit b2c0d9
Packit b2c0d9
TEST ls $M0/.snaps/snap4/dir1;
Packit b2c0d9
TEST ls $M0/.snaps/snap4/dir2;
Packit b2c0d9
Packit b2c0d9
TEST ls $M0/dir1/.snaps/
Packit b2c0d9
TEST ! ls $M0/dir1/.snaps/snap1;
Packit b2c0d9
TEST ! ls $M0/dir2/.snaps/snap2;
Packit b2c0d9
TEST   ls $M0/dir1/.snaps/snap3;
Packit b2c0d9
TEST   ls $M0/dir2/.snaps/snap4;
Packit b2c0d9
Packit b2c0d9
TEST fd1=`fd_available`
Packit b2c0d9
TEST fd_open $fd1 'r' $M0/.snaps/snap1/file1;
Packit b2c0d9
TEST fd_cat $fd1
Packit b2c0d9
Packit b2c0d9
# opening fd with in write mode for snapshot files should fail
Packit b2c0d9
TEST fd2=`fd_available`
Packit b2c0d9
TEST ! fd_open $fd1 'w' $M0/.snaps/snap1/file2;
Packit b2c0d9
Packit b2c0d9
# lookup on .snaps in the snapshot world should fail
Packit b2c0d9
TEST ! stat $M0/.snaps/snap1/.snaps
Packit b2c0d9
Packit b2c0d9
# creating new entries in snapshots should fail
Packit b2c0d9
TEST check_readonly mkdir $M0/.snaps/new
Packit b2c0d9
TEST check_readonly touch $M0/.snaps/snap2/other;
Packit b2c0d9
Packit b2c0d9
TEST fd3=`fd_available`
Packit b2c0d9
TEST fd_open $fd3 'r' $M0/dir1/.snaps/snap3/foo1
Packit b2c0d9
Packit b2c0d9
TEST fd_cat $fd3;
Packit b2c0d9
Packit b2c0d9
TEST fd_close $fd1;
Packit b2c0d9
TEST fd_close $fd2;
Packit b2c0d9
TEST fd_close $fd3
Packit b2c0d9
Packit b2c0d9
Packit b2c0d9
# similar tests on nfs mount
Packit b2c0d9
##Wait for connection establishment between nfs server and brick process
Packit b2c0d9
EXPECT_WITHIN $NFS_EXPORT_TIMEOUT "1" is_nfs_export_available;
Packit b2c0d9
#test 44
Packit b2c0d9
TEST mount_nfs $H0:/$V0 $N0 nolock;
Packit b2c0d9
Packit b2c0d9
NUM_SNAPS=$(ls $N0/.snaps | wc -l);
Packit b2c0d9
Packit b2c0d9
TEST [ $NUM_SNAPS == 4 ];
Packit b2c0d9
Packit b2c0d9
TEST stat $N0/.snaps/snap1;
Packit b2c0d9
TEST stat $N0/.snaps/snap2;
Packit b2c0d9
Packit b2c0d9
TEST ls -l $N0/.snaps;
Packit b2c0d9
Packit b2c0d9
# readdir + lookup on each entry
Packit b2c0d9
TEST ls -l $N0/.snaps/snap1;
Packit b2c0d9
TEST ls -l $N0/.snaps/snap2;
Packit b2c0d9
Packit b2c0d9
# readdir + access each entry by doing stat. If snapview-server has not
Packit b2c0d9
# filled the fs instance and handle in the inode context of the entry as
Packit b2c0d9
# part of readdirp, then when stat comes (i.e fop comes directly without
Packit b2c0d9
# a previous lookup), snapview-server should do a lookup of the entry via
Packit b2c0d9
# gfapi call and fill in the fs instance + handle information in the inode
Packit b2c0d9
# context
Packit b2c0d9
TEST ls $N0/.snaps/snap3/;
Packit b2c0d9
TEST stat $N0/.snaps/snap3/dir1;
Packit b2c0d9
TEST stat $N0/.snaps/snap3/dir2;
Packit b2c0d9
Packit b2c0d9
TEST ls -l $N0/.snaps/snap3/dir1;
Packit b2c0d9
TEST ls -l $N0/.snaps/snap3/dir2;
Packit b2c0d9
TEST ls -l $N0/.snaps/snap4/dir1;
Packit b2c0d9
TEST ls -l $N0/.snaps/snap4/dir2;
Packit b2c0d9
Packit b2c0d9
TEST ! ls -l $N0/dir1/.snaps/snap1;
Packit b2c0d9
TEST ! ls -l $N0/dir2/.snaps/snap2;
Packit b2c0d9
TEST   ls -l $N0/dir1/.snaps/snap3;
Packit b2c0d9
TEST   ls -l $N0/dir2/.snaps/snap4;
Packit b2c0d9
Packit b2c0d9
Packit b2c0d9
TEST fd1=`fd_available`
Packit b2c0d9
TEST fd_open $fd1 'r' $N0/.snaps/snap1/file1;
Packit b2c0d9
TEST fd_cat $fd1
Packit b2c0d9
Packit b2c0d9
TEST fd2=`fd_available`
Packit b2c0d9
TEST ! fd_open $fd1 'w' $N0/.snaps/snap1/file2;
Packit b2c0d9
Packit b2c0d9
TEST ! stat $N0/.snaps/snap1/.stat
Packit b2c0d9
Packit b2c0d9
TEST check_readonly mkdir $N0/.snaps/new
Packit b2c0d9
Packit b2c0d9
TEST check_readonly touch $N0/.snaps/snap2/other;
Packit b2c0d9
Packit b2c0d9
TEST fd3=`fd_available`
Packit b2c0d9
TEST fd_open $fd3 'r' $N0/dir1/.snaps/snap3/foo1
Packit b2c0d9
Packit b2c0d9
TEST fd_cat $fd3;
Packit b2c0d9
Packit b2c0d9
Packit b2c0d9
TEST fd_close $fd1;
Packit b2c0d9
TEST fd_close $fd2;
Packit b2c0d9
TEST fd_close $fd3;
Packit b2c0d9
Packit b2c0d9
# test 73
Packit b2c0d9
TEST $CLI volume set $V0 "features.snapshot-directory" .history
Packit b2c0d9
Packit b2c0d9
#snapd client might take fraction of time to compare the volfile from glusterd
Packit b2c0d9
#hence a EXPECT_WITHIN is a better choice here
Packit b2c0d9
EXPECT_WITHIN 2 "Y" lookup "$M0/.history";
Packit b2c0d9
Packit b2c0d9
NUM_SNAPS=$(ls $M0/.history | wc -l);
Packit b2c0d9
Packit b2c0d9
TEST [ $NUM_SNAPS == 4 ]
Packit b2c0d9
Packit b2c0d9
TEST ls $M0/.history/snap1;
Packit b2c0d9
TEST ls $M0/.history/snap2;
Packit b2c0d9
TEST ls $M0/.history/snap3;
Packit b2c0d9
TEST ls $M0/.history/snap4;
Packit b2c0d9
Packit b2c0d9
TEST ls $M0/.history/snap3/dir1;
Packit b2c0d9
TEST ls $M0/.history/snap3/dir2;
Packit b2c0d9
Packit b2c0d9
TEST ls $M0/.history/snap4/dir1;
Packit b2c0d9
TEST ls $M0/.history/snap4/dir2;
Packit b2c0d9
Packit b2c0d9
TEST ls $M0/dir1/.history/
Packit b2c0d9
TEST ! ls $M0/dir1/.history/snap1;
Packit b2c0d9
TEST ! ls $M0/dir2/.history/snap2;
Packit b2c0d9
TEST   ls $M0/dir1/.history/snap3;
Packit b2c0d9
TEST   ls $M0/dir2/.history/snap4;
Packit b2c0d9
Packit b2c0d9
TEST fd1=`fd_available`
Packit b2c0d9
TEST fd_open $fd1 'r' $M0/.history/snap1/file1;
Packit b2c0d9
TEST fd_cat $fd1
Packit b2c0d9
Packit b2c0d9
# opening fd with in write mode for snapshot files should fail
Packit b2c0d9
TEST fd2=`fd_available`
Packit b2c0d9
TEST ! fd_open $fd1 'w' $M0/.history/snap1/file2;
Packit b2c0d9
Packit b2c0d9
# lookup on .history in the snapshot world should fail
Packit b2c0d9
TEST ! stat $M0/.history/snap1/.history
Packit b2c0d9
Packit b2c0d9
# creating new entries in snapshots should fail
Packit b2c0d9
TEST check_readonly mkdir $M0/.history/new
Packit b2c0d9
TEST check_readonly touch $M0/.history/snap2/other;
Packit b2c0d9
Packit b2c0d9
TEST fd3=`fd_available`
Packit b2c0d9
TEST fd_open $fd3 'r' $M0/dir1/.history/snap3/foo1
Packit b2c0d9
Packit b2c0d9
TEST fd_cat $fd3;
Packit b2c0d9
Packit b2c0d9
TEST fd_close $fd1;
Packit b2c0d9
TEST fd_close $fd2;
Packit b2c0d9
TEST fd_close $fd3
Packit b2c0d9
Packit b2c0d9
Packit b2c0d9
# similar tests on nfs mount
Packit b2c0d9
# test 103
Packit b2c0d9
TEST ls $N0/.history;
Packit b2c0d9
Packit b2c0d9
NUM_SNAPS=$(ls $N0/.history | wc -l);
Packit b2c0d9
Packit b2c0d9
TEST [ $NUM_SNAPS == 4 ];
Packit b2c0d9
Packit b2c0d9
TEST ls -l $N0/.history/snap1;
Packit b2c0d9
TEST ls -l $N0/.history/snap2;
Packit b2c0d9
TEST ls -l $N0/.history/snap3;
Packit b2c0d9
TEST ls -l $N0/.history/snap4;
Packit b2c0d9
Packit b2c0d9
TEST ls -l $N0/.history/snap3/dir1;
Packit b2c0d9
TEST ls -l $N0/.history/snap3/dir2;
Packit b2c0d9
Packit b2c0d9
TEST ls -l $N0/.history/snap4/dir1;
Packit b2c0d9
TEST ls -l $N0/.history/snap4/dir2;
Packit b2c0d9
Packit b2c0d9
TEST ! ls -l $N0/dir1/.history/snap1;
Packit b2c0d9
TEST ! ls -l $N0/dir2/.history/snap2;
Packit b2c0d9
TEST   ls -l $N0/dir1/.history/snap3;
Packit b2c0d9
TEST   ls -l $N0/dir2/.history/snap4;
Packit b2c0d9
Packit b2c0d9
TEST fd1=`fd_available`
Packit b2c0d9
TEST fd_open $fd1 'r' $N0/.history/snap1/file1;
Packit b2c0d9
TEST fd_cat $fd1
Packit b2c0d9
Packit b2c0d9
TEST fd2=`fd_available`
Packit b2c0d9
TEST ! fd_open $fd1 'w' $N0/.history/snap1/file2;
Packit b2c0d9
Packit b2c0d9
TEST ! stat $N0/.history/snap1/.stat
Packit b2c0d9
Packit b2c0d9
TEST check_readonly mkdir $N0/.history/new
Packit b2c0d9
Packit b2c0d9
TEST check_readonly touch $N0/.history/snap2/other;
Packit b2c0d9
Packit b2c0d9
TEST fd3=`fd_available`
Packit b2c0d9
TEST fd_open $fd3 'r' $N0/dir1/.history/snap3/foo1
Packit b2c0d9
Packit b2c0d9
TEST fd_cat $fd3;
Packit b2c0d9
Packit b2c0d9
TEST fd_close $fd1;
Packit b2c0d9
TEST fd_close $fd2;
Packit b2c0d9
TEST fd_close $fd3;
Packit b2c0d9
Packit b2c0d9
## Before killing daemon to avoid deadlocks
Packit b2c0d9
EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" umount_nfs $N0
Packit b2c0d9
Packit b2c0d9
#test 131
Packit b2c0d9
TEST $CLI snapshot create snap5 $V0 no-timestamp
Packit b2c0d9
TEST ls $M0/.history;
Packit b2c0d9
Packit b2c0d9
function count_snaps
Packit b2c0d9
{
Packit b2c0d9
    local mount_point=$1;
Packit b2c0d9
    local num_snaps;
Packit b2c0d9
Packit b2c0d9
    num_snaps=$(ls $mount_point/.history | wc -l);
Packit b2c0d9
Packit b2c0d9
    echo $num_snaps;
Packit b2c0d9
}
Packit b2c0d9
Packit b2c0d9
EXPECT_WITHIN 30 "5" count_snaps $M0;
Packit b2c0d9
Packit b2c0d9
# deletion of a snapshot and creation of a new snapshot with same name
Packit b2c0d9
# should not create problems. The data that was supposed to be present
Packit b2c0d9
# in the deleted snapshot need not be present in the new snapshot just
Packit b2c0d9
# because the name is same. Ex:
Packit b2c0d9
# 1) Create a file "aaa"
Packit b2c0d9
# 2) Create a snapshot snap6
Packit b2c0d9
# 3) stat the file "aaa" in snap6 and it should succeed
Packit b2c0d9
# 4) delete the file "aaa"
Packit b2c0d9
# 5) Delete the snapshot snap6
Packit b2c0d9
# 6) Create a snapshot snap6
Packit b2c0d9
# 7) stat the file "aaa" in snap6 and it should fail now
Packit b2c0d9
Packit b2c0d9
echo "aaa" > $M0/aaa;
Packit b2c0d9
Packit b2c0d9
TEST $CLI snapshot create snap6 $V0 no-timestamp
Packit b2c0d9
Packit b2c0d9
TEST ls $M0/.history;
Packit b2c0d9
Packit b2c0d9
EXPECT_WITHIN 30 "6" count_snaps $M0;
Packit b2c0d9
Packit b2c0d9
EXPECT_WITHIN 10 "Y" lookup $M0/.history/snap6/aaa
Packit b2c0d9
Packit b2c0d9
TEST rm -f $M0/aaa;
Packit b2c0d9
Packit b2c0d9
TEST $CLI snapshot delete snap6;
Packit b2c0d9
Packit b2c0d9
TEST $CLI snapshot create snap6 $V0 no-timestamp
Packit b2c0d9
Packit b2c0d9
TEST ls $M0/.history;
Packit b2c0d9
Packit b2c0d9
EXPECT_WITHIN 30 "6" count_snaps $M0;
Packit b2c0d9
Packit b2c0d9
TEST ls $M0/.history/snap6/;
Packit b2c0d9
Packit b2c0d9
TEST ! stat $M0/.history/snap6/aaa;
Packit b2c0d9
Packit b2c0d9
cleanup;