shell语句 $0————脚本启动名(包括路径) $n————第n个参数,n=1,2,…9 $———— 所有参数列表(不包括脚本本身) $@———— 所有参数列表(独立字符串) $#———— 参数个数(不包括脚本本身) $$———— 当前程式的PID $!———— 执行上一个指令的PID $?———— 执行上一个指令的返回值
1
,
1,
1,————获取shell脚本参 例 if [ $2 -a $2 = “test” ]中 -a是什么意思 -a 与 并且 -o 或 ! 非
文件判断: -r file 用户可读为真 -w file 用户可写为真 -x file 用户可执行为真 -f file 文件为正规文件为真 -d file 文件为目录为真 -c file 文件为字符特殊文件为真 -b file 文件为块特殊文件为真 -s file 文件大小非0时为真 -t file 当文件描述符(默认为1)指定的设备为终端时为真
数字的判断: int1 -eq int2 两数相等为真 int1 -ne int2 两数不等为真 int1 -gt int2 int1大于int2为真 int1 -ge int2 int1大于等于int2为真 int1 -lt int2 int1小于int2为真 int1 -le int2 int1小于等于int2为真
字符串判断: str1 = str2 当两个串有相同内容、长度时为真 str1 != str2 当串str1和str2不等时为真 -n str1 当串的长度大于0时为真(串非空) -z str1 当串的长度为0时为真(空串) str1 当串str1为非空时为真 a~z字符的内容: [ -a FILE ] 如果 FILE 存在则为真。 [ -b FILE ] 如果 FILE 存在且是一个块特殊文件则为真。 [ -c FILE ] 如果 FILE 存在且是一个字特殊文件则为真。 [ -d FILE ] 如果 FILE 存在且是一个目录则为真。 [ -e FILE ] 如果 FILE 存在则为真。 [ -f FILE ] 如果 FILE 存在且是一个普通文件则为真。 [ -g FILE ] 如果 FILE 存在且已经设置了SGID则为真。 [ -h FILE ] 如果 FILE 存在且是一个符号连接则为真。 [ -k FILE ] 如果 FILE 存在且已经设置了粘制位则为真。 [ -p FILE ] 如果 FILE 存在且是一个名字管道(F如果O)则为真。 [ -r FILE ] 如果 FILE 存在且是可读的则为真。 [ -s FILE ] 如果 FILE 存在且大小不为0则为真。 [ -t FD ] 如果文件描述符 FD 打开且指向一个终端则为真。 [ -u FILE ] 如果 FILE 存在且设置了SUID (set user ID)则为真。 [ -w FILE ] 如果 FILE 如果 FILE 存在且是可写的则为真。 [ -x FILE ] 如果 FILE 存在且是可执行的则为真。 [ -O FILE ] 如果 FILE 存在且属有效用户ID则为真。 [ -G FILE ] 如果 FILE 存在且属有效用户组则为真。 [ -L FILE ] 如果 FILE 存在且是一个符号连接则为真。 [ -N FILE ] 如果 FILE 存在 and has been mod如果ied since it was last read则为真。 [ -S FILE ] 如果 FILE 存在且是一个套接字则为真。 [ FILE1 -nt FILE2 ] 如果 FILE1 has been changed more recently than FILE2, or 如果 FILE1 exists and FILE2 does not则为真。 [ FILE1 -ot FILE2 ] 如果 FILE1 比 FILE2 要老, 或者 FILE2 存在且 FILE1 不存在则为真。 [ FILE1 -ef FILE2 ] 如果 FILE1 和 FILE2 指向相同的设备和节点号则为真。 [ -o OPTIONNAME ] 如果 shell选项 “OPTIONNAME” 开启则为真。 [ -z STRING ] “STRING” 的长度为零则为真。 [ -n STRING ] or [ STRING ] “STRING” 的长度为非零 non-zero则为真。 [ STRING1 == STRING2 ] 如果2个字符串相同。 “=” may be used instead of “==” for strict POSIX compliance则为真。 [ STRING1 != STRING2 ] 如果字符串不相等则为真。 [ STRING1 < STRING2 ] 如果 “STRING1” sorts before “STRING2” lexicographically in the current locale则为真。 [ STRING1 > STRING2 ] 如果 “STRING1” sorts after “STRING2” lexicographically in the current locale则为真。
linux shell 加密解密方法(shc/gzexe) shc常用命令: -e date (指定过期日期) -m message (指定过期提示的信息 ) -f script_ name (指定要编译的Shel的路径及文件名) -「Relax security. (可以相同操作系统的不同系统中执行) -V Verbose compilation (编译的详细情况) gzexe命令 – 压缩执行文件 gzexe【参数】【文件】 压缩可执行文件 [root@linuxcool ~]# gzexe abc 解压可执行文件: gzexe -d test.sh 桩(stub)函数的描述:在单元测试中被其他模块调用,在自顶向下的集成过程中尤其有效。 在 bash shell 环境下,当一命令正在执行时,按下 control-Z 会:将前台转入后台
软件验收的分类:1.正式验收测试 2.非正式验收测试 (1)alpha测试:不需要用户进行测试(自身测试) (2)beta测试:需要用户测试(内测)
运用软件测试的工具的目的: 帮助测试寻找问题、协助问题的诊断、节省测试时间
测试人员测试过程: 测试人员职责: 1.编写测试计划、规划详细的测试方案编写测试用例。 2.执行测试工作,提交测试报告。包括编写用于测试的自动测试脚本,完整地记录测试结果,编 写完整的测试报告等相关的技术文档; 3.对测试中发现的问题进行详细分析和准确定位,与开发人员讨论缺陷解决方案。 4.提出对产品的进一步改进的建议, 并评估改进方案是否合理;对测试结果进行总结与统计分析, 对测试进行跟踪,并提出反馈意见。 5.为业务部]提供相应技术支持,确保软件质量指标。 6.完成测试项目归纳及总结文档。
测试人员进入测试时间什么时间段好: 在软件开发的过程中,测试人员应当在一个项目开始立项之后就开始介入,最好是在需求评审的时候,因为提早介入,修改缺陷的成本会很低,并且在测试的时候可以避免遗漏测试场景!
软件测试的原则 : 原则一:测试显示软件存在缺陷 原则二:穷尽测试是不可能的 原则三:尽早介入测试 原则四:缺陷具有集群性 原则五:杀虫剂悖论 原则六:测试是上下文相关的 原则七:没有错误就是好”是谬误
软件测试的目的: 软件测试是为了发现错误而执行程序的过程。
测试流程: 严格执行测试计划,排除测试的随意性,以避免发生疏漏或者重复无效的工作 调试:也被称为Debug 为避免软件缺陷造成的高成本支出或损失,软件测试越早介入越可以帮助规避风险。 基本路径法测试需要覆盖几条路径 可以通过计算谓词节点来做,公式为 基本路径=谓词节点+1; 谓词节点是指程序中的条件语句,比如人while,if,等类型的个数。
圈复杂度: 计算公式1:V(G)=e-n+2p。其中,e表示控制流图中边的数量,n表示控制流图中节点的数量,p图的连接组件数目(图的组件数是相连节点的最大集合)。因为控制流图都是连通的,所以p为1
计算公式2:V(G)=区域数=判定节点数+1。其实,圈复杂度的计算还有更直观的方法,因为圈复杂度所反映的是“判定条件”的数量,所以圈复杂度实际上就是等于判定节点的数量再加上1,也即控制流图的区域数。 对于多分支的CASE结构或IF-ELSEIF-ELSE结构,统计判定节点的个数时需要特别注意一点,要求必须统计全部实际的判定节点数,也即每个ELSEIF语句,以及每个CASE语句,都应该算为一个判定节点。
计算公式3:V(G)=R。其中R代表平面被控制流图划分成的区域数。 针对程序的控制流图计算圈复杂度V(G)时,最好还是采用第一个公式,也即V(G)=e-n+2;而针对模块的控制流图时,可以直接统计判定节点数,这样更为简单;针对复杂的控制流图是,使用区域计算公式V(G)=R更为简单。
单元测试的测试用例主要根据()的结果来设计:详细设计
|