Linux之Bash基础特性条件测试&&自定义退出状态码(6)

简介:

条件测试

    判断某需求是否满足,需要由测试机制来实现。

    根据命令的执行状态结果,表达不同的测试条件


1、根据id命令的执行状态结果,判断用户是否存在

1
2
3
4
5
6
7
8
9
[root@izpo45bh60h6bsz ~] # id root
uid=0(root) gid=0(root)  groups =0(root)
[root@izpo45bh60h6bsz ~] # echo $?
0
 
[root@izpo45bh60h6bsz ~] # id help
id : help: no such user
[root@izpo45bh60h6bsz ~] # echo $?
1


2、根据在/etc/passwd文件中找到root开头的词的执行状态结果,判断用户是否存在

1
2
3
4
5
6
[root@izpo45bh60h6bsz ~] # grep -q '^root\b' /etc/passwd
[root@izpo45bh60h6bsz ~] # echo $?
0
[root@izpo45bh60h6bsz ~] # grep -q '^help\b' /etc/passwd
[root@izpo45bh60h6bsz ~] # echo $?
1


使用测试,在测试时,要使用特殊的测试符

    1)test 测试表达式

1
2
3
4
5
6
[root@izpo45bh60h6bsz ~] # test 1 > 3
[root@izpo45bh60h6bsz ~] # echo $?
0
[root@izpo45bh60h6bsz ~] # test 1 -gt 3 # 在数值测试时,用-gt表示 > 符号
[root@izpo45bh60h6bsz ~] # echo $?
1

    2)[ 测试表达式 ]

1
2
3
4
5
6
[root@izpo45bh60h6bsz ~] # [1 -lt 3]   # 测试表达示与中括号必须存在空格,否则就会报错。
- bash : [1:  command  not found
 
[root@izpo45bh60h6bsz ~] # [ 1 -lt 3 ]  # 在数值测试时,用-lt表示 < 符号
[root@izpo45bh60h6bsz ~] # echo $?
0

  3) [[  测试表达式 ]]

1
2
3
4
5
6
[root@izpo45bh60h6bsz ~] # [[1 -lt 3]]
- bash : [[1:  command  not found
 
[root@izpo45bh60h6bsz ~] # [[ 1 -eq 3 ]]  # 在数值测试时,用-eq 表示 = 符号
[root@izpo45bh60h6bsz ~] # echo $?
1


测试符分类

    数值测试

        -eq 左侧是否等于右侧

        -ne 是不等于

        -gt 是否大于

        -ge 是否大于等于

        -lt 是否小于

        -le 是否小于等于

    

1)A  -eq  B,  测试A所表示的数值是否等于B所表示的数值。等于为真

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
##测试方法一
# A=1
# B=10
# test $B -eq $A  # 测试变量B内存空间中存储的数据和变量A内存空间中存储的数据是否相等
# echo $?
1
 
##测试方法二
# [ $B -eq $A ]
# echo $?
1
 
##测试方法三
# [[ $B -eq $A ]]
# echo $?
1

2)A  -ne  B,  测试A所表示的数值是否不等于B所表示的数值。不等于为真

1
2
3
4
5
6
7
8
9
10
11
12
13
14
##测试方法一
# test $B -ne $A  # 测试变量B内存空间中存储的数据和变量A内存空间中存储的数据是否不相等
# echo $?
0
 
##测试方法二
# [ $B -ne $A ]
# echo $?
0
 
##测试方法三
# [[ $B -ne $A ]]
# echo $?
0

3) A  -gt  B , 测试A所表示的数值是否大于B所表示的数值。大于为真

1
2
3
4
5
6
7
8
9
10
11
12
13
14
##测试方法一
# test 10 -gt 3 # 测试10是否大于3
# echo $?
0
 
##测试方法二
# [ 10 -gt 3 ]
# echo $?
0
 
##测试方法三
# [[ 10 -gt 3 ]]
# echo $?
0

3) A  -ge  B , 测试A所表示的数值是否大于等于B所表示的数值。大于等于为真

1
2
3
4
5
6
7
8
9
10
11
12
13
14
##测试方法一
# test 10 -ge 3 # 测试10是否大于等于3
# echo $?
0
 
##测试方法二
# [ 10 -ge 3 ]
# echo $?
0
 
##测试方法三
# [[ 10 -ge 3 ]]
# echo $?
0

4)A -lt B , 测试A所表示的数值是否小于B所表示的数值。小于为真

1
2
3
4
5
6
7
8
9
10
11
12
13
14
##测试方法一
# let 1 -lt 3    # 测试 1 是否小于 3
# echo $?
0
 
##测试方法二
# [ 1 -lt 3 ]
# echo $?
0
 
##测试方法三
# [[ 1 -lt 3 ]]
# echo $?
0

5)A -le B , 测试A所表示的数值是否小于等于B所表示的数值。小于等于为真

1
2
3
4
5
6
7
8
9
10
11
12
13
14
##测试方法一
# let 1 -le 3    # 测试 1 是否小于 3
# echo $?
0
 
##测试方法二
# [ 1 -le 3 ]
# echo $?
0
 
##测试方法三
# [[ 1 -le 3 ]]
# echo $?
0

    

    字符测试 (所有的操作数,都应该使用引用)

== 等值测试

>  是否大于, ASCII码的比较

<  是否小于

!= 是否不等于

A =~ PATTERN 左侧字符串是否能够被右侧的(正则表达式)PATTERN所匹配到。一般用于 ` ` 中,PATTERN不能加引号

-z "STRING" 测试字串是否为空,空为真

-n "STRING" 是否不空

1) A == B ,A所表示的字符和B所表示的字符是否相等

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
##测试方法一
# test "obama" == "obama"  # 测试左侧字符串,是否与右侧字符串相等
# echo $?
0
 
# test "obama" == "Obama"   # 可见字符串,必须完成相等
# echo $?
1
 
# A=obama
# B=jerry
# test "$A" == "$B"     # 测试A变量内存空间存储的数据(字符型或数值型)是否与B变量中存储的数据相等
# echo $?
1
 
##测试方法二
# [ "obama" == "obama" ]
# echo $?
0
 
# A=obama
# B=jerry
# [ "$A" == "$B" ]
# echo $?
1
 
##测试方法三
# [[ "obama" == "obama" ]]
# echo $?
0
 
# [[ "$A" == "$B" ]]
# echo $?
1

2) A > B ,A所表示的字符是否大于B所表示的字符

3) A < B ,A所表示的字符是否小于B所表示的字符

4) A != B ,A所表示的字符和B所表示的字符是否不相等

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
##测试方法一
# test  "obama"  !=  "obama"   # 测试左侧字符串,是否与右侧字符串不相等
# echo $?
1
 
# test  "$B"  !=  "$A" 
# echo $?
0
 
##测试方法二
# [  "obama"  !=  "obama" 
# echo $?
1
 
# [  "$B"  !=  "$A" 
# echo $?
0
 
##测试方法三
# [[  "obama"  !=  "obama"  ]]
# echo $?
1
 
# A=obama
# B=jerry
# [[  "$A"  !=  "$B"  ]]
# echo $?
0

5) A =~ B ,A所表示的字符能否被B所表示的(正则表达式)模式所匹配。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# test "obama" =~ "^o.*"
- bash test : =~: binary operator expected
# test "obama" =~ ^o.*
- bash test : =~: binary operator expected
 
# [ "obama" =~ "^o.*" ]
- bash : [: =~: binary operator expected
# [ "obama" =~ ^o.* ]
- bash : [: =~: binary operator expected
 
# [[ "obama" =~ "^o.*" ]]
# echo $?
1
 
# [[ "obama" =~ ^o.* ]] #模式不能加引号
# echo $?
0

6)-z  "B",  测试B所表示的字符串是否为空,空为真

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
##测试方法一
# test -z "obama"
# echo $?
1
 
A=
# test -z "$A"  # A变量为空时,测试其结果
# echo $?
0
 
A=jerry
# test -z "$A"  # A变量不空时,测试其结果
# echo $?
1
 
##测试方法二
# [ -z "how are you?" ]
# echo $?
1
 
A=
# [ -z "$A" ]
# echo $?
0
 
##测试方法三
# [[ -z "how are you?" ]] # 测试字串是否为空
# echo $?
1
 
A=
# [[ -z "$A" ]]  # 测试变量中存储的字串,是否为空
# echo $?
0

7) -n "B",  测试B所表示的字符串是否为不空,不空为真

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
##测试方法一
# test -n "obama"
# echo $?
0
 
A=
# test -n "$A"  # A变量为空时,测试其结果
# echo $?
1
 
A=jerry
# test -n "$A"  # A变量不空时,测试其结果
# echo $?
0
 
##测试方法二
# [ -n "how are you?" ]
# echo $?
0
 
A=
# [ -n "$A" ]
# echo $?
1
 
##测试方法三
# [[ -n "how are you?" ]] # 测试字串是否为空
# echo $?
1
 
A=
# [[ -n "$A" ]]  # 测试变量中存储的字串,是否为空
# echo $?
1

    文件测试

-a 或 -e 测试文件是否存在,存在时状态返回值为0,否则为1-255

1
2
3
4
5
6
7
# [ -a /tmp/file.txt ] # 测试文件是否存在,存在执行状态结果为0,否则为1-255
# echo $?
0
 
# [ -e /tmp/file.txt ] # 测试文件是否存在,存在执行状态结果为0,否则为1-255
# echo $?
0

存在且文件为什么类别 (dbc lsp)

-b 是否存在且为 块设备文件,存在则为真

1
2
3
4
5
6
7
8
9
10
11
# [ -b /dev/sda ]  #不存在或不为块设备,结果为1.-255
# echo $?
1
# [ -b /dev/vda ]  #存在且为块设备,结果为0
# echo $?
0
 
# ls -l /dev/sda   #验证结果,不存在
ls : cannot access  /dev/sda : No such  file  or directory
# ls -l /dev/vda   #验证结果,存在
brw-rw---- 1 root disk 253, 0 Jul 31  2017  /dev/vda    ##由b可知为块设备

-c 是否存在 且为字符设备文件

1
2
3
4
5
6
7
8
9
10
crw-rw-rw- 1 root root      1,   5 Jul 31  2017 zero
crw-rw-rw- 1 root root      1,   3 Jul 31  2017 null
 
# [ -c /dev/null ] #存在且为字符设备
# echo $?
0
 
# [ -c /dev/zero ]
# echo $?
0

-d 是否存在 且为目录 文件

1
2
3
4
5
# ls -ld /etc
drwxr-xr-x. 111 root root 12288 Jun 11 16:38  /etc
# [ -d /etc ]
# echo $?
0

-f 是否存在 且为普通 文件

1
2
3
4
5
# ls -l /var/log/yum.log
-rw------- 1 root root 0 Jun 10 12:26  /var/log/yum .log
# [ -f /var/log/yum.log ]
# echo $?
0

-p 管道

1
2
3
# [ -p /var/log/yum.log ]
# echo $?
1

-h 或 -L 符号链接

1
2
3
4
5
6
7
8
# ls -l /etc/system-release
lrwxrwxrwx 1 root root 14 Jul 31  2017  /etc/system-release  -> centos-release
# [ -h /etc/system-release ]
# echo $?
0
# [ -L /etc/system-release ]
# echo $?
0

-S 套接字

1
2
3
4
5
6
# ls -l /dev/log
srw-rw-rw- 1 root root 0 Jul 31  2017  /dev/log
 
# [ -S /dev/log ]
# echo $?
0

存在且有特殊权限:(文件本身)

-g ,拥有sgid权限 

1
2
3
4
5
# ls -l /etc/passwd
-rw-r--r-- 1 root root 3673 Jun 10 13:22  /etc/passwd
# [ -g /etc/passwd ]
# echo $?
1

-u ,拥有suid权限

1
2
3
# [ -u /etc/passwd ]
# echo $?
1

-k , 拥有sticky权限

1
2
3
4
5
6
# [ -k /tmp ]
 
# echo $?
0
# ls -ld /tmp
drwxrwxrwt. 13 root root 4096 Jun 12 00:11  /tmp

文件权限: (跟用户相关) 

-r 文件存在且可读 cat

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
# ls -l /etc/shadow a.txt
-rw-r--r-- 1 root root  127 Jun 11 19:25 a.txt
---------- 1 root root 2843 Jun 10 13:24  /etc/shadow
 
# [ -r a.txt ]
# echo $?
0
# [ -r /etc/shadow ]  ##root用户能读
# echo $?
0
 
# su - myuser
Last login: Tue Aug  1 18:49:22 CST 2017 on pts /0
$ [ -r  /etc/shadow  ]   ##对于普通用户不能读
echo  $?
1

-w 文件存在且可写 修改

1
2
3
4
5
6
7
8
9
# ls -l /etc/shadow a.txt
-rw-r--r-- 1 root root  127 Jun 11 19:25 a.txt
---------- 1 root root 2843 Jun 10 13:24  /etc/shadow
# [ -w /etc/shadow ]
# echo $?
0
# [ -w a.txt ]
# echo $?
0

-x 文件存在且可执行 对于当前用户

1
2
3
4
5
# ls -l /bin/ls
-rwxr-xr-x 1 root root 117656 Nov  6  2016  /bin/ls
# [ -x /bin/ls ]
# echo $?
0

-s FILE 文件存在且非空

1
2
3
4
5
# touch b.txt 
# cat b.txt 
# [ -s b.txt ]
# echo $?
1

-t fd 文件描述符 fd是否打开,且与某个终端相关

运行命令

1、终端无关: 与随系统启动

2、终端相关: 手动运行,在交互式接口运行的命令。linux任何一个文件被打开都有一个文件描述符追踪文件


-N FILE 文件从上次打开后 是否被修改过? (重定向)

1
2
3
4
5
6
7
8
# [ -N a.txt ]
# echo $?
1
 
# echo "abc" >> a.txt
# [ -N a.txt ]
# echo $?
0

-O FILE 当前有效用户是否为文件的属主

1
2
3
4
5
# ls -l a.txt
-rw-r--r-- 1 root root 131 Jun 12 00:37 a.txt
# [ -O a.txt ]
# echo $?
0

-G FILE 当前有效用户是否为文件的属组

1
2
3
# [ -G a.txt ]
# echo $?
0


FILE1 -ef FILE2  refer to 指向    指向同一个设备上的相同inode

    FILE1和FILE2是否为互为硬链接

1
2
3
4
5
6
7
8
9
10
11
# [ a.txt -ef b.txt ]
# echo $?
1
 
# ln a.txt a.hl   ##创建硬链接
# ls -li a.txt a.hl
1558766 -rw-r--r-- 2 root root 131 Jun 12 00:37 a.hl    #inode 1558766
1558766 -rw-r--r-- 2 root root 131 Jun 12 00:37 a.txt   #inode 1558766
# [ a.txt -ef a.hl ]
# echo $?
0


FILE1 -nt FILE2   new than  最近一次修改的时间戳FILE1较FILE2更靠近现在

1
2
3
4
5
6
# ls -l /tmp/ntp.conf*
-rw-r--r-- 1 root root 2439 Jun 11 20:46  /tmp/ntp .conf
-rw-r--r-- 1 root root 2439 Jun 12 00:47  /tmp/ntp .conf.bak
# [ /tmp/ntp.conf -nt /tmp/ntp.conf.bak ]
# echo $? ###说明/tmp/ntp.conf.bak更新
1

FILE1 -ot FILE2   old than    最近一次修改的时间戳FILE1较FILE2更远离现在

1
2
3
# [ /tmp/ntp.conf -ot /tmp/ntp.conf.bak ]
# echo $?  ###说明/tmp/ntp.conf  更旧
0


组合测试条件

    逻辑运算:

        连接命令

            COMMAND1 && COMMAND2

            COMMAND1 || COMMAND2

            ! COMMAND


        连接条件

            [ EXPRESSION ] && [ EXPRESSION ] 相当于 [ EXPRESSION -a EXPRESSION ]

            [ EXPRESSION ]   ||   [ EXPRESSION ] 相当于 [ EXPRESSION -o EXPRESSION ]

            [ ! EXPRESSION ]

摩根定律

    非(P 且 Q) = (非 P) 或 (非 Q)

    非(P 或 Q) = (非 P) 且 (非 Q)

    

    例如:

    [ ! EXPRESSION ] &&  [ ! EXPRESSION ] 相当于 [   !   \(   EXPRESSION -o EXPRESSION  \)  ]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
install  -m 000  /etc/issue  /tmp
ls  -l  /tmp/issue 
---------- 1 myuser myuser 23 Jun 12 05:32  /tmp/issue
 
$ [ ! -r  /tmp/issue  ] && [ ! -w  /tmp/issue  ]
echo  $?
0
 
$ [ ! \( -r  /tmp/issue  -o -w  /tmp/issue  \) ]
echo  $?
0
 
$ [ ! \(-r  /tmp/issue  -o -w  /tmp/issue \) ]
- bash : [: too many arguments

2、bash中自定义退出状态码

    exit [#]  在bash脚本中,一旦遇到exit命令就会终止脚本,退出状态码为exit后的数值。

1、exit存在时

1
2
3
4
5
6
7
8
9
10
# nano helo.sh
#!/bin/bash
printf  "hello everyone\n" 
exit  1
 
## 判断脚本执行的状态结果
# bash helo.sh 
hello everyone
# echo $?
1

2、exit不存在时

1
2
3
4
5
6
7
8
9
10
11
# nano helo.sh
#!/bin/bash
printf  "hello everyone\n" 
 
## 判断脚本执行的状态结果
# bash helo.sh
#!/bin/bash
ls  /varr
printf  "hello everyone\n" 
# echo $?   ##返回值为最后一个命令的执行状态结果
0










本文转自 lccnx 51CTO博客,原文链接:http://blog.51cto.com/sonlich/1953085,如需转载请自行联系原作者
目录
相关文章
|
5月前
|
测试技术 Android开发 Python
探索软件测试的艺术:从基础到高级安卓应用开发中的自定义视图
【8月更文挑战第29天】在软件开发的世界中,测试是不可或缺的一环。它如同艺术一般,需要精细的技巧和深厚的知识。本文旨在通过浅显易懂的语言,引领读者从软件测试的基础出发,逐步深入到更复杂的测试策略和工具的使用,最终达到能够独立进行高效测试的水平。我们将一起探索如何通过不同的测试方法来确保软件的质量和性能,就像艺术家通过不同的色彩和笔触来完成一幅画作一样。
|
3月前
|
机器学习/深度学习 JSON 算法
实例分割笔记(一): 使用YOLOv5-Seg对图像进行分割检测完整版(从自定义数据集到测试验证的完整流程)
本文详细介绍了使用YOLOv5-Seg模型进行图像分割的完整流程,包括图像分割的基础知识、YOLOv5-Seg模型的特点、环境搭建、数据集准备、模型训练、验证、测试以及评价指标。通过实例代码,指导读者从自定义数据集开始,直至模型的测试验证,适合深度学习领域的研究者和开发者参考。
1021 3
实例分割笔记(一): 使用YOLOv5-Seg对图像进行分割检测完整版(从自定义数据集到测试验证的完整流程)
|
2月前
|
Web App开发 定位技术 iOS开发
Playwright 是一个强大的工具,用于在各种浏览器上测试应用,并模拟真实设备如手机和平板。通过配置 `playwright.devices`,可以轻松模拟不同设备的用户代理、屏幕尺寸、视口等特性。此外,Playwright 还支持模拟地理位置、区域设置、时区、权限(如通知)和配色方案,使测试更加全面和真实。例如,可以在配置文件中设置全局的区域设置和时区,然后在特定测试中进行覆盖。同时,还可以动态更改地理位置和媒体类型,以适应不同的测试需求。
Playwright 是一个强大的工具,用于在各种浏览器上测试应用,并模拟真实设备如手机和平板。通过配置 `playwright.devices`,可以轻松模拟不同设备的用户代理、屏幕尺寸、视口等特性。此外,Playwright 还支持模拟地理位置、区域设置、时区、权限(如通知)和配色方案,使测试更加全面和真实。例如,可以在配置文件中设置全局的区域设置和时区,然后在特定测试中进行覆盖。同时,还可以动态更改地理位置和媒体类型,以适应不同的测试需求。
102 1
|
3月前
|
机器学习/深度学习 JSON 算法
语义分割笔记(二):DeepLab V3对图像进行分割(自定义数据集从零到一进行训练、验证和测试)
本文介绍了DeepLab V3在语义分割中的应用,包括数据集准备、模型训练、测试和评估,提供了代码和资源链接。
376 0
语义分割笔记(二):DeepLab V3对图像进行分割(自定义数据集从零到一进行训练、验证和测试)
|
3月前
|
机器学习/深度学习 算法 PyTorch
目标检测实战(五): 使用YOLOv5-7.0版本对图像进行目标检测完整版(从自定义数据集到测试验证的完整流程)
本文详细介绍了使用YOLOv5-7.0版本进行目标检测的完整流程,包括算法介绍、环境搭建、数据集准备、模型训练、验证、测试以及评价指标。YOLOv5以其高精度、快速度和模型小尺寸在计算机视觉领域受到广泛应用。
1122 0
目标检测实战(五): 使用YOLOv5-7.0版本对图像进行目标检测完整版(从自定义数据集到测试验证的完整流程)
|
4月前
|
Oracle Java 关系型数据库
Linux下JDK环境的配置及 bash: /usr/local/java/bin/java: cannot execute binary file: exec format error问题的解决
如果遇到"exec format error"问题,文章建议先检查Linux操作系统是32位还是64位,并确保安装了与系统匹配的JDK版本。如果系统是64位的,但出现了错误,可能是因为下载了错误的JDK版本。文章提供了一个链接,指向Oracle官网上的JDK 17 Linux版本下载页面,并附有截图说明。
Linux下JDK环境的配置及 bash: /usr/local/java/bin/java: cannot execute binary file: exec format error问题的解决
|
3月前
|
算法 Java 测试技术
数据结构 —— Java自定义代码实现顺序表,包含测试用例以及ArrayList的使用以及相关算法题
文章详细介绍了如何用Java自定义实现一个顺序表类,包括插入、删除、获取数据元素、求数据个数等功能,并对顺序表进行了测试,最后还提及了Java中自带的顺序表实现类ArrayList。
41 0
|
5月前
|
测试技术
单元测试问题之使用TestMe时利用JUnit 5的参数化测试特性如何解决
单元测试问题之使用TestMe时利用JUnit 5的参数化测试特性如何解决
64 2
|
5月前
|
Unix Shell Linux
在Linux中,什么是 BASH?
在Linux中,什么是 BASH?
|
5月前
|
Kubernetes Linux API
在Linux中,LVS-DR模型的特性是什么?
在Linux中,LVS-DR模型的特性是什么?