Added a condition to the atime test (#1477)

This commit is contained in:
Takeshi Nakatani 2020-12-02 23:21:25 +09:00 committed by GitHub
parent d0363b118e
commit c589886ba5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -583,6 +583,22 @@ function test_mtime_file {
rm_test_file $ALT_TEST_TEXT_FILE rm_test_file $ALT_TEST_TEXT_FILE
} }
# [NOTE]
# If it mounted with relatime or noatime options , the "touch -a"
# command may not update the atime.
# In ubuntu:xenial, atime was updated even if relatime was granted.
# However, it was not updated in bionic/focal.
# We can probably update atime by explicitly specifying the strictatime
# option and running the "touch -a" command. However, the strictatime
# option cannot be set.
# Therefore, if the relatime option is set, the test with the "touch -a"
# command is bypassed.
# We do not know why atime is not updated may or not be affected by
# these options.(can't say for sure)
# However, if atime has not been updated, the s3fs_utimens entry point
# will not be called from FUSE library. We added this bypass because
# the test became unstable.
#
function test_update_time() { function test_update_time() {
describe "Testing update time function ..." describe "Testing update time function ..."
@ -656,17 +672,19 @@ function test_update_time() {
# #
# "touch -a" -> update ctime/atime, not update mtime # "touch -a" -> update ctime/atime, not update mtime
# #
touch -a $TEST_TEXT_FILE if ! cat /proc/mounts | grep "^s3fs $TEST_BUCKET_MOUNT_POINT_1 " | grep -e noatime -e relatime >/dev/null; then
atime=`get_atime $TEST_TEXT_FILE` touch -a $TEST_TEXT_FILE
ctime=`get_ctime $TEST_TEXT_FILE` atime=`get_atime $TEST_TEXT_FILE`
mtime=`get_mtime $TEST_TEXT_FILE` ctime=`get_ctime $TEST_TEXT_FILE`
if [ $base_atime -eq $atime -o $base_ctime -eq $ctime -o $base_mtime -ne $mtime ]; then mtime=`get_mtime $TEST_TEXT_FILE`
echo "touch with -a option expected updated ctime: $base_ctime != $ctime, atime: $base_atime != $atime and same mtime: $base_mtime == $mtime" if [ $base_atime -eq $atime -o $base_ctime -eq $ctime -o $base_mtime -ne $mtime ]; then
return 1 echo "touch with -a option expected updated ctime: $base_ctime != $ctime, atime: $base_atime != $atime and same mtime: $base_mtime == $mtime"
return 1
fi
base_atime=$atime
base_ctime=$ctime
sleep 2
fi fi
base_atime=$atime
base_ctime=$ctime
sleep 2
# #
# append -> update ctime/mtime, not update atime # append -> update ctime/mtime, not update atime
@ -714,6 +732,10 @@ function test_update_time() {
rm_test_file $TIME2_TEST_TEXT_FILE rm_test_file $TIME2_TEST_TEXT_FILE
} }
# [NOTE]
# See the description of test_update_time () for notes about the
# "touch -a" command and atime.
#
function test_update_directory_time() { function test_update_directory_time() {
describe "Testing update time for directory function ..." describe "Testing update time for directory function ..."
@ -798,17 +820,19 @@ function test_update_directory_time() {
# #
# "touch -a" -> update ctime/atime, not update mtime # "touch -a" -> update ctime/atime, not update mtime
# #
touch -a $TEST_DIR if ! cat /proc/mounts | grep "^s3fs $TEST_BUCKET_MOUNT_POINT_1 " | grep -e noatime -e relatime >/dev/null; then
atime=`get_atime $TEST_DIR` touch -a $TEST_DIR
ctime=`get_ctime $TEST_DIR` atime=`get_atime $TEST_DIR`
mtime=`get_mtime $TEST_DIR` ctime=`get_ctime $TEST_DIR`
if [ $base_atime -eq $atime -o $base_ctime -eq $ctime -o $base_mtime -ne $mtime ]; then mtime=`get_mtime $TEST_DIR`
echo "touch with -a option expected updated ctime: $base_ctime != $ctime, atime: $base_atime != $atime and same mtime: $base_mtime == $mtime" if [ $base_atime -eq $atime -o $base_ctime -eq $ctime -o $base_mtime -ne $mtime ]; then
return 1 echo "touch with -a option expected updated ctime: $base_ctime != $ctime, atime: $base_atime != $atime and same mtime: $base_mtime == $mtime"
return 1
fi
base_atime=$atime
base_ctime=$ctime
sleep 2
fi fi
base_atime=$atime
base_ctime=$ctime
sleep 2
# #
# mv -> update ctime, not update atime/mtime for taget directory # mv -> update ctime, not update atime/mtime for taget directory