summaryrefslogtreecommitdiff
path: root/tests/generic/120
blob: 5a67ed0dc5cd907349882a77443dcb2806882d42 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#!/bin/bash
# SPDX-License-Identifier: GPL-2.0
# Copyright (c) 2000-2002 Silicon Graphics, Inc.  All Rights Reserved.
#
# FS QA Test No. 120
#
# Test noatime mount option.
#
. ./common/preamble
_begin_fstest other atime auto quick

# Import common functions.
. ./common/filter

# real QA test starts here
_supported_fs generic

_require_scratch
_require_atime

_scratch_mkfs >/dev/null 2>&1 || _fail "mkfs failed"

_compare_access_times()
{
	original_access_time="`cat $tmp.out | sed -n '5p'|awk '{ print substr($0,0,32)}'`"
	accessed_time="`$here/src/lstat64 $1 | sed -n '5p'| awk '{ print substr($0,0,32)}'`"
	echo "*** compare access times ***"
	if [ "$original_access_time" != "$accessed_time" ]
		then
		echo "*** file access time updated on $2 (unexpected) ***"
		cat $tmp.out
		echo "---------------------------------------------------"
		$here/src/lstat64 $1
		mount | grep $SCRATCH_MNT
	fi

}

if ! _try_scratch_mount "-o noatime" >$tmp.out 2>&1
then
    cat $tmp.out
    echo "!!! mount failed"
    exit
fi

#executable file
echo "*** copying file ***"
cp $here/src/lstat64 $SCRATCH_MNT
$here/src/lstat64 $SCRATCH_MNT/lstat64 >$tmp.out
sleep 5
echo "*** executing file ***"
$SCRATCH_MNT/lstat64 $SCRATCH_MNT/lstat64 >/dev/null
_compare_access_times $SCRATCH_MNT/lstat64 "executing file"

#reading file
echo "*** creating file ***"
touch $SCRATCH_MNT/testfile
$here/src/lstat64 $SCRATCH_MNT/testfile >$tmp.out
sleep 5
echo "*** reading file ***"
cat $SCRATCH_MNT/testfile >/dev/null
_compare_access_times $SCRATCH_MNT/testfile "reading file"

#writing file
echo "*** creating file ***"
touch $SCRATCH_MNT/testfile2
$here/src/lstat64 $SCRATCH_MNT/testfile2 >$tmp.out
sleep 5
echo "*** writing to file ***"
echo "asdf" >> $SCRATCH_MNT/testfile2
_compare_access_times $SCRATCH_MNT/testfile2 "writing file"

_scratch_unmount

# success, all done
status=0
exit