文件时间信息在测试中的应用
1 简介
文件时间信息在测试中也有妙用~
通过记录模块运行前后的文件时间信息来识别运行前后发生变化的文件,从而识别模块运行前后的新增文件、删除的文件和内容发生变化的文件。
利用识别出来的发生变化的文件来减少复杂模块回归测试中采用新旧对比回归测试方法的测试时间,并且能为复杂模块的数据准备工作服务。
如何妙用呢,请看下文~
2 Linux下文件时间简单介绍
在Linux下,一个文件也有三种时间,分别是:访问时间、修改时间、状态改动时间 。
如何查一个文件的三个时间呢?
(1) 先用下面的命令来建立一个文件
$ date ; echo "" >filetime.txt ; ll --full-time filetime.txt
Wed May 5 13:49:57 CST 2010
-rw-rw-r-- 1 work work 1 2010-05-05 13:49:57.000000000 +0800 filetime.txt
(2) 通过stat filetime.txt来查, 如
$ stat filetime.txt
File: `filetime.txt'
Size: 1 Blocks: 8 IO Block: 4096 regular file
Device: 803h/2051d Inode: 147408 Links: 1
Access: (0664/-rw-rw-r--) Uid: ( 500/ work) Gid: ( 502/ work)
Access: 2010-05-05 13:49:57.000000000 +0800
Modify: 2010-05-05 13:49:57.000000000 +0800
Change: 2010-05-05 13:49:57.000000000 +0800
因为这是一个新的文件(filetime.txt),没做过内容、属性的更改,也没读过这个文件,所以三者(访问时间、修改时间、状态改动时间)的时间是一致的。
(1) Access访问时间
读一次这个文件的内容,这个时间就会更新,比如对这个文件运用 more、cat等命令。
(2) Modify修改时间
文件内容最后一次被修改时间,比如:vi后保存文件。ls -l列出的时间就是这个时间。
(3) Change状态改动时间
该文件的i节点最后一次被修改的时间,通过chmod、chown命令修改一次文件属性,这个时间就会更新。
3 常用操作对文件时间的影响
在这里大家要注意的mv操作,mv操作不修改文件的读写时间,一般大家认为一个文件如果读写没有发生变化则该文件没有被操作过,但是该文件很可能被mv处理过,导致时间发生了非预期的改变。
比如存在一个文件a和b,具有相同的文件时间信息,执行mv a b,发现b的读写时间都没有变化就认为b的内容肯定没有改变这个结论是错误的,其实b的内容已经变成a的内容了。
这个结论非常重要,涉及到下面文件时间利用时候为啥需要以?开头的文件出现的必要性。
4 文件时间信息在测试中的应用
4.1 应用原理
通过记录模块运行前后的文件时间信息来识别运行前后发生变化的文件,从而识别模块运行前后的新增文件、删除的文件和内容发生变化的文件。
利用识别出来的发生变化的文件来减少回归测试中采用新旧对比回归测试方法的测试时间,并且能为复杂模块的数据准备工作服务。
具体应用步骤如下面各个小结的描述。
4.2 步骤1:递归获取运行前运行目录下所有文件的时间信息
(1) 代码get_file_timeinfo.sh
function get_file_timeinfo()
{
local target_file=$1
local file=""
if [ -f "$target_file" ]
then
echo -n -e "${target_file}\t" | sed 's/[\/][\/]*/\//g'
stat -c "%X==%Y==%Z" "$target_file" | sed 's/==/\t/g'
return 0
elif [ -d "$target_file" ]
then
for file in `ls -l $target_file | awk 'NF==9{print $9}'`
do
get_file_timeinfo $target_file/$file
done
return 0
else
echo "[error]$target_file is not a file or directory!"
return 1
fi
}
function usage()
{
echo "usage: $0 FileOrDir"
exit 1
}
if [ "$#" -ne 1 -o "$1" == "-h" -o "$1" == "-v" ]
then
usage
fi
get_file_timeinfo $1
(2) 执行程序get_file_timeinfo.sh
./get_file_timeinfo.sh extr-info/ &>before.txt
(3) 查看结果before.txt
文件格式说明:
第1列:文件路径
第2列:访问时间
第3列:修改时间
第4列:状态改动时间
test/AT_InvokeRelation.sh 1273045348 1273045348 1273045348
test/diff-dir.sh 1273045348 1273045348 1273045348
test/diff-file-list.sh 1273045348 1273045348 1273045348
test/diff_file_time.sh 1273045348 1273045348 1273045348
test/get_dir_info.sh 1273045348 1273045348 1273045348
test/get-file-list.sh 1273045348 1273045348 1273045348
test/GetFilesFromDiff.new.sh 1273045348 1273045348 1273045348
test/GetFilesFromDiff.sh 1273045348 1273045348 1273045348
test/get_file_timeinfo.sh 1273045348 1273045348 1273045348
test/GetSysInfo.sh 1273045348 1273045348 1273045348
test/get_var.sh 1273045348 1273045348 1273045348
test/MakeTable.sh 1273045348 1273045348 1273045348
test/MonitorNetwork.sh 1273045348 1273045348 1273045348
test/monrsscpu.sh 1273045415 1273045415 1273045415
test/monrsscpu.sh.1 1273045416 1273045416 1273045416
test/my_many_diff.sh 1273045348 1273045348 1273045348
test/MyProgMonitor.sh 1273045348 1273045348 1273045348
test/process-diff.sh 1273045348 1273045348 1273045348
test/PsMonMemCpu.sh 1273045348 1273045348 1273045348
test/VmstatMonMemCpu.sh 1273045348 1273045348 1273045348
4.3 步骤2:执行程序
此处运行你需要运行的程序
4.4 步骤3:递归获取运行后运行目录下所有文件的时间信息
该部分重复步骤(1)得到运行后的时间信息保存在after.txt中
4.5 步骤4:比较运行前和运行后的时间信息,得到新增的文件、删除的文件、修改的文件
(1) 代码diff_file_time.sh
function usage()
{
echo "usage:$0 before.txt after.txt"
exit 1
}
if [ "$#" -ne 2 -o ! -f "$1" -o ! -f "$2" ]
then
usage
fi
before_file=$1
after_file=$2
awk -F '\t' '
file==1{
index_arr[$1]=1;
access_arr[$1]=$2;
modifty_arr[$1]=$3;
change_arr[$1]=$4;
}
file==2{
if($1 in index_arr)
{
if($3 > modifty_arr[$1] ) ##
{
print "! "$1;
}else if($3 < modifty_arr[$1])
{
print "? "$1;
}else if($2 > access_arr[$1])##
{
print "| "$1;
}else if($2 < access_arr[$1])
{
print "? "$1;
}else if(change_arr[$1] != $4)##
{
print "? "$1;
}
index_arr[$1]=0;
}else
{
index_arr[$1]=2;
}
}
END{
for(file_name in index_arr)
{
if(index_arr[file_name]==1)
{
print "< "file_name;
}else if(index_arr[file_name]==2)
{
print "> "file_name;
}else if(index_arr[file_name]==0)
{
print " "file_name;
}
}
}' file=1 $before_file file=2 $after_file
(2) 执行程序diff_file_time.sh
./diff_file_time.sh before.txt after.txt &>all.filediff
(3) 查看结果all.filediff
文件格式说明:
a) 以| 开头文件:运行前后被读过
b) 以!开头文件:运行前后被修改过
c) 以< 开头文件:运行后被删除了
d) 以> 开头文件:运行后新产生的
e) 以 开头文件:运行前后文件无变化
f) 以? 开头文件:运行前后发生了变化,变化不符合一般文件时间改变逻辑(只改变读写时间并且读写时间都变大了),该处的文件一般为mv操作或者仅仅进行属性修改操作的文件。
| test/GetSysInfo.sh
? test/my_many_diff.sh
! test/process-diff.sh
test/my_many_diff.sh
test/diff-dir.sh
< test/monrsscpu.sh.1
test/MonitorNetwork.sh
test/diff-file-list.sh
test/process-diff.sh
test/diff_file_time.sh
test/PsMonMemCpu.sh
test/GetFilesFromDiff.sh
> test/add
test/MyProgMonitor.sh
< test/get_var.sh
test/GetSysInfo.sh
test/GetFilesFromDiff.new.sh
test/get-file-list.sh
test/get_file_timeinfo.sh
test/MakeTable.sh
< test/VmstatMonMemCpu.sh
test/monrsscpu.sh
test/AT_InvokeRelation.sh
test/get_dir_info.sh
4.6 测试应用场景
(1) 减少回归测试中新旧对比回归测试的时间
若你的回归测试方法是采用跑新旧环境然后对新旧环境的结果进行对比的方式,就意味你需要对环境中所有的文件进行md5比较包括从上游获取的大量只读数据,对于复杂模块而言,对所有的文件进行md5值操作是很费时间的。
由于你利用前面的时间信息已经获得了发生变化的文件(以<>!|?的文件),所以你可以仅仅比较发生了变化的文件,节省了大量的diff时间。
另外一个节省时间的地方,在一个复杂的环境里面,你不用care哪些跟该子模块无关的数据了,即使他们在两个环境里面不一样。过去为了能够让新旧对比的结果准确,我们总是施法将两个环境里面所有的数据实现同步,现在不需要了,同步了该子模块需要的数据已经足够。
(2) 准备数据
现在要开始测试了,需要准备的输入有哪些呢?如果你不清楚,干脆把该子模块跑一下吧,用开始的方法你很容易知道你要准备哪些数据了(以<|?! 开头的文件)。
这个地方有个问题就是哪些需要文件但是不会改变文件时间属性而只是获取某些文件属性的操作需要的文件识别不出来比如-f,不过这种情况在实际程序中出现的非常少( 除了一些标志文件),因为程序获取属性的目的是为了进一步对这个文件进行处理,所以该文件还是会被识别出来(前面说了除了标志文件除外)。
若真遇到标志文件怎么办呢?目前来看俺们这种方法是解决不了了。
4.7 适用范围和应用情况
应用情况:
● 在***进行重构的时候了,为了回归该模块众多的子脚本,我采用了前面的方法来进行子模块回归的数据准备。
***模块情况:
脚本个数:60个左右
线上模块规模:900G左右
运行时间:1天
升级特点:主要为结构调整和小功能升级,每行脚本代码都是diff。
测试特点:主要为回归工作,整体回归和子模块局部回归,众多子模块新旧输入数据同步是难点。
● 在***升级的时候,为了节省新旧diff的时间,我采用了前面的方法来进行新旧回归。
***模块情况:
脚本个数:100个左右
线上模块规模:1T左右
运行时间:2天
升级特点:新策略的添加和旧策略的优化
测试特点:整体回归新旧各跑一次就4天过去了,新旧1T逐个diff不知道要几天!
适用情况:
从现有的试用情况来看,该种方法比较适合复杂模块,因为对于简单或者中等复杂的模块而言,新旧回归对比的时间最多可以在一个晚上空余的时间就可以进行完毕,准备输入数据也不是很难的事情,在这种情况下就没有必要应用这种方法了。
4.8 后序计划
(1) 前面的这两种应用都可以开发配套的自动化结构来支持
(2) 这种方式显然无法适应分布式的情况,因为分布式的数据都不在本地机器,当然若有需求我们也可以开发分布式版本以支持分布式的情况。
(全文完)
转载于:https://blog.51cto.com/baidutech/743555
相关文章:
SpringMVC之请求参数的获取方式
转载出处:https://www.toutiao.com/i6510822190219264516/ SpringMVC之请求参数的获取方式 常见的一个web服务,如何获取请求参数? 一般最常见的请求为GET和POST,get请求的参数在url上可以获取,post请求参数除了url上还…

生成假人脸、假新闻...AI虚拟世界正形成
整理 | 一一出品 | AI科技大本营(ID:rgznai100)AI 正在创造一个独特的虚拟(虚假)信息世界。一个人脸喂养生成网站火了。这个网站可以生成随机人脸图像,这些人脸没有姓名,在现实世界中并不存在,而…

【linux】ARM开发板上设置RTC时间,断电重启后,设置失效的原因分析
问题描述 linux中使用date设置时间后用hwclock -w同步到RTC,断电重启后,有时会失效 原因分析 保存时间戳 1、使用命令关机(halt)会调用rc0.d中的脚本; 2、使用命令重启(reboot)会调用rc6.d中…

【linux】NXP MFGTools工具配置文件详解
mfgtools\cfg.ini [profiles] chip Linux #对应mfgtools\Profiles\Linux\OS Firmware\中“Linux” #MfgTool2.exe中会使用路径:Profiles${chip}\OS Firmware [platform] board MY-IMX6 #没有用,可以忽略 [LIST] name Linux-3.14.52 #对应mfgtools\…

Python打造最强表白程序
作者 | 痴海转载自公众号痴海(ID:ch726612)情人节刚过,朋友圈又是刷屏的节奏。但热闹总是别人的,我们好像只有吃狗粮的份。时间总是飞快流逝,很多事情早已改变,但仿佛只有你的单身状态从未改变。单身久的我…

怎样加强你的意志力
每个人都有惰性,而且每天都在惰性进行斗争,而这个斗争在你死之前,是不会停止的。实际每个人都知道,每天应该坚持学习,早起早睡,可是到时候总是因为各种原因放弃。能坚持下来的人,离目标就更近一…

解除微信回调的Activity必须在包名.wxapi下的限制
很久以前写过一篇文章:Android打包之多版本、多环境、多渠道。里面主要提到了将测试环境和正式环境的包分成不同的包名,同时安装在手机上,以便我们调试。同时,通过manifest的占位符,动态替换icon和label,让…

FreeBSD 6.0架设管理与应用-第三章 UNIX 系统入门
在开始进阶的 FreeBSD 设定之前,我们先来了解一下 UNIX 系统的架构及基本知识。这些知识对于我们之后管理、使用 FreeBSD 十分重要。如果您是 UNIX 新手,请务必详读本章。本章将介绍下列主题:如何登入注销系统。 UNIX 的指令用法。 UNIX 中常…

京东金融App收集用户敏感信息?致歉来了
整理 | 琥珀出品 | AI科技大本营(ID:rgznai100)京东金融 App 收集用户信息大家看到的是安全隐患,而我们看到的是一个大企业的原罪。日前,就京东金融 App 疑似收集信息事件引起了网络上的轩然大波。就该起事件,京东金融…

安装Python的wx库
2019独角兽企业重金招聘Python工程师标准>>> 遇到问题1:pip不是内部或外部命令,也不是可运行的程序 解决办法:修改环境变量:变量值改为:C:\Python27\;C:\Python27\Scripts; 遇到问题2:wxPython.…

【linux驱动】嵌入式 Linux 对内存的直接读写(devmem)
devmem工具源码 #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <string.h> #include <errno.h> #include <signal.h> #include <fcntl.h> #include <ctype.h> #include <termios.h> #include …

【视频】V4L2之ioctl
常见的ioctl命令 VIDIOC_QUERYCAP /* 获取设备支持的操作 */ VIDIOC_G_FMT /* 获取设置支持的视频格式 */ VIDIOC_S_FMT /* 设置捕获视频的格式 */ VIDIOC_REQBUFS /* 向驱动提出申请内存的请求 */ VIDIOC_QUERYBUF /* 向驱动查询申请到的内…

我们期待的TensorFlow 2.0还有哪些变化?
来源 | Google TensorFlow 团队为提高 TensorFlow 的工作效率,TensorFlow 2.0 进行了多项更改,包括删除了多余的 API,使API 更加一致统一,例如统一的 RNNs (循环神经网络),统一的优化器,并且Pyt…

多线程概念与编程
一、多线程的生命周期:新建(New)、就绪(Runnable)、运行(Running)、阻塞(Blocked)和死亡(Dead) 1、新建状态:程序初始化一个Thread时,线程处于新建状态 2、就绪状态:线程Thread调用s…

C技巧:结构体参数转成不定参数
下面这段程序是一个C语言的小技巧,其展示了如何把一个参数为结构体的函数转成一个可变参数的函数,其中用到了宏和内建宏“__VA_ARGS__”,下面这段程序可以在GCC下正常编译通过: #include <stdio.h> #define func(...) myfun…

Arbitrage--POJ 2240
1、题目类型:图论、最短路径、Floyd算法。 2、解题思路:Floyd算法的简单应用;STL中map的简单应用。 3、注意事项:避免map报警告,文件开始调用#pragma warning(disable:4786)。 4、实现方法: #pragmawarning(disable:47…

【视频】V4L2之应用流程
####打开设备文件 int fd = open(Devicename,mode); Devicename:/dev/video0、/dev/video1 …… Mode:O_RDWR [| O_NONBLOCK] 如果使用非阻塞模式调用视频设备,则当没有可用的视频数据时,不会阻塞,而立刻返回。 ####取得设备的capability struct v4l2_capability capabil…

Android NDK开发之旅29 云服务器Ubuntu下搭建NDK环境,并编译FFmpeg
###前言 因为在Linux环境下编译FFmpeg生成库和头文件下比较方便,所以接下来主要操作在Linux环境下进行。但是对于Android NDK 开发新手来说,自己电脑配置Ubuntu Linux环境过程比较繁琐。而采用云服务器极大的方便了此过程,服务器对客户端远程…

一个App卖了4亿美元,这家听声识曲公司为何得到Apple的青睐?
作者 | 琥珀 出品 | AI科技大本营(ID:rgznai100) 是否可以将 Shazam 称为有听歌识曲功能应用的鼻祖? 2018 年 9 月,苹果最终以 4 亿美金完成对 Shazam 公司的收购,让不少人为之振奋,在当时对外公布的一份声…

Product Orders(生产订单)状态相关函数BAPI
[相关表] JEST-对象的系统状态(I****)和用户状态(E****) JSTO-状态对象信息 TJ02T-系统状态文本 -用户状态文本 【锁对象】:生产订单锁对象 ESORDER 函数: ENQUEUE_ESORDER, DEQUEUE_ESORDER [函数1]:检…

5行代码就能入门爬虫?
作者 | 苏克1900来源 | 第2大脑(ID:Mocun6)责编 | swallow不少读者是刚刚入门Python或者想学习Python的,今天就来谈谈如何用快速入门爬虫。先说结论:入门爬虫很容易,几行代码就可以,可以说是学习…

【云周刊】第146期:史上最大规模人机协同的双11,12位技术大V揭秘背后黑科技...
摘要:史上最大规模人机协同的双11,12位技术大V揭秘背后黑科技,INTERSPEECH 2017系列 | 语音识别之语言模型技术,机器学习初学者必须知道的十大算法,云数据库SQL Server 2016和新技术应用...更多精彩内容,尽…

【驱动】GNSS驱动基础
GNSS:Global Navigation Satellite System(全球卫星导航系统) GPS:Global Positioning System(全球定位系统) GPS是美国的卫星导航系统。 还有,俄罗斯的GLONASS;欧盟的Galileo;中国的北斗。 这几大导航系统统称为GNSS GLONASS、Galileo、…

ibaits插入即获取主键(mssql,mysql,oracle)
oracle主键需预先生成,通过sequence;mysql和mssql是插入后生成。 mysql: <insert id"insertStu_mysql" parameterClass"stu"> insert into stu(name) values (#name#) <selectKey resultClass"int" keyProper…

【驱动】GNSS驱动:gpsOneXTRA 援助技术
什么是 “gpsOneXTRA 援助技术”? 高通 gpsOneXTRA 的援助技术在公司的改进中扩展了 gps 芯片组, 允许通过互联网连接下载辅助 gps。芯片组为更精确的位置发现提供了更高的灵敏度, 尤其是在通常难以找到 GPS 信号的位置。 gpsOneXTRA:帮助提高了独立的性能&#x…

2017年书单整理
android书籍: Android进阶之光 刘望舒 点评一下,这本书呢,涉猎很广,涉及的技术,开源库挺多的,适合广度面上的知识增长,对于深度上的提高价值不大,我觉得对我没啥太大价值额 Android安全技术揭秘…

华南理工大学院长涉嫌篡改8名研究生成绩,4人已停职
整理 | 一一出品 | AI科技大本营(ID:rgznai100)2 月 11 日,网友平凡的世界overlooker 在新浪微博上报料,称华南理工大学计算机科学与工程学院的院领导于 2018 年研究生复试结束后,篡改 8 位考生的考试成绩,…

我心中的最佳阵容
世界杯的激情还在心中涤荡,但新赛季的各大联赛却已悄然开打,这里给出我心中的几项最佳,期待他们本赛季的完美表现。 最佳球队:切尔西(上赛季切尔西在安帅执掌球队的首个赛季便夺得英超冠军,欧冠虽惜败于曾经…

如何让AI教机器自己玩俄罗斯方块?
作者 | Ahab转载自公众号Ahab杂货铺(ID:PythonLearningCamp)人工智能大火的今天,如果还是自己玩俄罗斯方块未免显得太 LOW,为什么不对游戏升级,让机器自己去玩俄罗斯方块呢?有了这个想法之后,我…

【驱动】内核打印级别设置
在uboot中设置 setenv loglevel loglevel8 setenv loglevel debug setenv loglevel quiet setenv loglevel setenv mmcargs run set_disp; setenv bootargs console${console},${baudrate} ${loglevel} ${smp} root${mmcroot} ${disp_args}内核对应代码 main.c (init) 467 s…