2013-02-11 20:57:29 +04:00
#!/bin/bash
2018-09-12 15:49:09 +03:00
dhthashdebugxattr="dht.file.hashed-subvol."
2014-08-23 13:14:36 +04:00
2013-02-11 20:57:29 +04:00
function get_layout()
{
2014-08-23 13:14:36 +04:00
getfattr -n trusted.glusterfs.dht -e hex $1 2>&1 | grep dht | cut -d = -f2
2013-02-11 20:57:29 +04:00
}
## populates $BRICK1 and $BRICK2 with hashed/cached subvolume. These will be
## used by get_cached_brick and get_hashed_brick
function file_has_linkfile()
{
k=0
l=0
while [ $k -lt $BRICK_COUNT ]
do
2014-08-23 13:14:36 +04:00
stat=$(stat $B0/${V0}$k/$1 2>/dev/null)
2013-02-11 20:57:29 +04:00
if [ $? -eq 0 ]
then
let l++
let "BRICK${l}=$k"
fi
let k++
done
return $l
}
function get_cached_brick()
{
i=1
brick=$BRICK1
while [ $i -lt 3 ]
do
2014-08-23 13:14:36 +04:00
test=$(getfattr -n trusted.glusterfs.dht.linkto -e text $B0/${V0}$brick/$1 2>&1)
2013-02-11 20:57:29 +04:00
if [ $? -eq 1 ]
then
cached=$brick
i=$(( $i+3 ))
fi
brick=$BRICK1
let i++
done
return $cached
}
function get_hashed_brick()
{
j=1
brick=$BRICK1
while [ $j -lt 3 ]
do
2014-08-23 13:14:36 +04:00
test=$(getfattr -n trusted.glusterfs.dht.linkto -e text $B0/${V0}$brick/$1 2>&1)
2013-02-11 20:57:29 +04:00
if [ $? -eq 0 ]
then
hashed=$brick
j=$(( $j+3 ))
fi
brick=$BRICK2
let j++
done
return $hashed
}
2013-02-25 08:32:15 +04:00
2017-05-10 18:56:28 +03:00
function cluster_rebalance_completed()
{
val=1
# Rebalance status will be either "failed" or "completed"
test=$($CLI_1 volume rebalance $V0 status | grep "in progress" 2>&1)
if [ $? -ne 0 ]
then
val=0
fi
echo $val
# Do not *return* the value here. If it's non-zero, that will cause
# EXPECT_WITHIN (e.g. in bug-884455.t) to return prematurely, leading to
# a spurious test failure. Nothing else checks the return value anyway
# (they all check the output) so there's no need for it to be non-zero
# just because grep didn't find what we want.
}
2013-02-25 08:32:15 +04:00
function rebalance_completed()
{
val=1
2017-05-10 18:56:28 +03:00
test=$($CLI volume rebalance $V0 status | grep localhost | grep "completed" 2>&1)
2013-02-25 08:32:15 +04:00
if [ $? -eq 0 ]
then
2017-05-10 18:56:28 +03:00
val=0
2013-02-25 08:32:15 +04:00
fi
echo $val
2015-03-25 16:21:06 +03:00
# Do not *return* the value here. If it's non-zero, that will cause
# EXPECT_WITHIN (e.g. in bug-884455.t) to return prematurely, leading to
# a spurious test failure. Nothing else checks the return value anyway
# (they all check the output) so there's no need for it to be non-zero
# just because grep didn't find what we want.
2013-02-25 08:32:15 +04:00
}
2014-04-21 17:29:00 +04:00
function remove_brick_completed()
{
val=1
2015-06-03 09:33:05 +03:00
test=$(gluster volume remove-brick $V0 $H0:$B0/${V0}2 status | grep localhost | grep "completed" 2>&1)
2014-04-21 17:29:00 +04:00
if [ $? -eq 0 ]
then
val=0
fi
echo $val
}
2014-05-21 16:17:03 +04:00
function dht_get_linkto_target()
{
local path=$1;
2014-08-23 13:14:36 +04:00
echo $(getfattr -e text --only-values --absolute-names -n trusted.glusterfs.dht.linkto $path)
2014-05-21 16:17:03 +04:00
}
function is_dht_linkfile()
{
local path=$1
retval=0
2014-08-23 13:14:36 +04:00
local output=$(stat -c %a $path)
2014-05-21 16:17:03 +04:00
if [ $output -eq 1000 ]; then
retval=1
fi
echo $retval
return $retval
}
2018-09-12 15:49:09 +03:00
# Given an existing directory on the volume, get the hashed subvol for a file
# in that directory
# Input: filename dirpath_on_mount
function dht_get_hash_subvol()
{
local hashed_subvol
hashed_subvol=$(getfattr --only-values -n "$dhthashdebugxattr$1" $2 2>/dev/null)
echo $hashed_subvol
}
# Find the first filename that hashes to the same subvol
# as $1
# Input: subvol_name dirpath_on_mount file_pattern
function dht_first_filename_with_hashsubvol()
{
local in_subvol=$1
local in_path=$2
local in_hash_subvol
local file_pattern=$3
local filename
for i in {1..50}
do
filename="$file_pattern$i"
in_hash_subvol=$(dht_get_hash_subvol "$filename" "$in_path")
# echo $in_hash_subvol
if [ "$in_subvol" == "$in_hash_subvol" ]; then
fn_return_val=$filename
return 0
fi
done
return 1
}