1#!/bin/bash 2 3################################################################################ 4## ## 5## Copyright (c) 2009 FUJITSU LIMITED ## 6## ## 7## This program is free software; you can redistribute it and#or modify ## 8## it under the terms of the GNU General Public License as published by ## 9## the Free Software Foundation; either version 2 of the License, or ## 10## (at your option) any later version. ## 11## ## 12## This program is distributed in the hope that it will be useful, but ## 13## WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY ## 14## or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ## 15## for more details. ## 16## ## 17## You should have received a copy of the GNU General Public License ## 18## along with this program; if not, write to the Free Software ## 19## Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA ## 20## ## 21## Author: Li Zefan <lizf@cn.fujitsu.com> ## 22## Miao Xie <miaox@cn.fujitsu.com> ## 23## ## 24################################################################################ 25 26export TCID="ext4-nsec-timestamps" 27export TST_TOTAL=2 28 29. ext4_funcs.sh 30 31# Test that file timestamps is second with 128 inode size 32ext4_test_sec_timestamps() 33{ 34 tst_resm TINFO "Test timestamps with 128 inode size" 35 36 mkfs.ext4 -I 128 $EXT4_DEV &> /dev/null 37 if [ $? -ne 0 ]; then 38 tst_resm TFAIL "failed to create ext4 filesystem" 39 return 40 fi 41 42 tune2fs -O extents $EXT4_DEV &> /dev/null 43 44 mount -t ext4 $EXT4_DEV mnt_point 45 if [ $? -ne 0 ]; then 46 tst_resm TFAIL "failed to mount ext4 filesystem" 47 return 48 fi 49 50 touch mnt_point/tmp_file 51 52 atime=`ext4_file_time mnt_point/tmp_file atime nsec` 53 mtime=`ext4_file_time mnt_point/tmp_file mtime nsec` 54 ctime=`ext4_file_time mnt_point/tmp_file ctime nsec` 55 56 if [ $atime -ne 0 -o $mtime -ne 0 -o $ctime -ne 0 ]; then 57 tst_resm TFAIL "Timestamp is not second(atime: $atime, mtime: \ 58 $mtime, ctime: $ctime)" 59 umount mnt_point 60 return 61 fi 62 63 umount mnt_point 64 if [ $? -ne 0 ]; then 65 tst_resm TFAIL "failed to umount ext4 filesystem" 66 return 67 fi 68 69 tst_resm TPASS "Ext4 nanosecond timestamps test with 128 inode size pass" 70} 71 72# Test file timestamps is nanosecond with 256 inode size 73ext4_test_nsec_timestamps() 74{ 75 tst_resm TINFO "Test timestamps with 256 inode size" 76 77 mkfs.ext3 -I 256 $EXT4_DEV &> /dev/null 78 if [ $? -ne 0 ]; then 79 tst_resm TFAIL "failed to create ext4 filesystem" 80 return 81 fi 82 83 mount -t ext4 $EXT4_DEV mnt_point 84 if [ $? -ne 0 ]; then 85 tst_resm TFAIL "failed to mount ext4 filesystem" 86 return 87 fi 88 89 # Create file 90 touch mnt_point/tmp_file 91 sleep 1 92 93 # Change atime, ctime and mtime of the file 94 touch mnt_point/tmp_file 95 96 cur_time=`date '+%s %N'` 97 sec=`echo $cur_time | awk {'print $1'}` 98 nsec=`echo $cur_time | awk {'print $2'}` 99 100 sec_atime=`ext4_file_time mnt_point/tmp_file atime sec` 101 sec_mtime=`ext4_file_time mnt_point/tmp_file mtime sec` 102 sec_ctime=`ext4_file_time mnt_point/tmp_file ctime sec` 103 nsec_atime=`ext4_file_time mnt_point/tmp_file atime nsec` 104 nsec_mtime=`ext4_file_time mnt_point/tmp_file mtime nsec` 105 nsec_ctime=`ext4_file_time mnt_point/tmp_file ctime nsec` 106 107 # Test nanosecond 108 if [ $nsec_atime -eq 0 -a $nsec_mtime -eq 0 -a $nsec_ctime -eq 0 ] 109 then 110 tst_resm TFAIL "The timestamp is not nanosecond(nsec_atime: $nsec_atime, nsec_mtime: $nsec_mtime, nsec_ctime: $nsec_ctime)" 111 umount mnt_point 112 return 113 fi 114 115 diff1=$(( $sec_atime - $sec )) 116 diff2=$(( $sec_mtime - $sec )) 117 diff3=$(( $sec_ctime - $sec )) 118 119 # Test difference between file time and current time 120 if [ $diff1 -gt 1 -o $diff2 -gt 1 -o $diff2 -gt 1 ]; then 121 tst_resm TFAIL "The timestamp is wrong, it must be earlier \ 122 than the current time we got.(sec_atime: $sec_atime, \ 123 sec_mtime: $sec_mtime, sec_ctime: $sec_ctime, \ 124 cur_time[s]: $sec)" 125 umount mnt_point 126 return 127 fi 128 129 umount mnt_point 130 if [ $? -ne 0 ]; then 131 tst_resm TFAIL "failed to umount ext4 filesystem" 132 return 133 fi 134 135 # Test mount to ext3 and then mount back to ext4 136 mount -t ext3 $EXT4_DEV mnt_point 137 if [ $? -ne 0 ]; then 138 tst_resm TFAIL "failed to mount to ext3" 139 return 140 fi 141 umount mnt_point 142 143 mount -t ext4 $EXT4_DEV mnt_point 144 if [ $? -ne 0 ]; then 145 tst_resm TFAIL "failed to mount back to ext4" 146 return 147 fi 148 149 nsec_atime2=`ext4_file_time mnt_point/tmp_file atime nsec` 150 nsec_mtime2=`ext4_file_time mnt_point/tmp_file mtime nsec` 151 nsec_ctime2=`ext4_file_time mnt_point/tmp_file mtime nsec` 152 153 if [ $nsec_atime -ne $nsec_atime2 -o $nsec_ctime -ne $nsec_ctime2 -o \ 154 $nsec_mtime -ne $nsec_mtime2 ]; then 155 tst_resm TFAIL "File nanosecond timestamp has changed \ 156 unexpected. Before[atime mtime ctime]: $nsec_atime \ 157 $nsec_mtime $nsec_ctime, After[atime mtime ctime]: \ 158 $nsec_atime2 $nsec_mtime2 $nsec_ctime2)" 159 umount mnt_point 160 return 161 fi 162 163 umount mnt_point 164 tst_resm TPASS "Ext4 nanosecond timestamps test with 256 inode size pass" 165} 166 167# main 168ext4_setup 169 170ext4_test_sec_timestamps 171ext4_test_nsec_timestamps 172 173tst_exit 174