使用CMD命令执行测试用例

当我们在ride中设计好测试用例后,我们可以使用ride的界面工具来选择和运行测试用例。

系统也会提供比较好的报告和日志的浏览功能。

但是这样的自动化,毕竟是需要手工介入的。通常,我们是希望能够和Jenkins等配置管理工具结合,实现代码发布,测试自动化运行。

Jenkins本身提供了插件来管理和运行robotframework架构,这里介绍下怎么使用robot工具,通过命令行来管理和运行相应的用例。

其实方法很简单,首先我们打开cmd窗口,输入 robot 命令:robot

如果robot安装正常,他会抛出下列的错误信息:

python执行cmd命令管理员_配置文件

 

根据提示信息,我们在命令中加入 --help来获取帮助: robot --help:

系统会给出所有robot有关的帮助文档:

python执行cmd命令管理员_用例_02

 

 

里面的内容很多,我们也可以将其输出到本地文件中: robot --help > D:\robothelp.txt。

这样我们在文件中预览相关内容会比较方便。

我们经常会用到的一些参数如下:

--test name *   选择执行那些测试用例,这里的参数是用例的名字。

--suite name *    选择执行那些test suite,该参数会和 --test --include --exclude配合使用,过滤出那些用例需要执行。

--include tag *       选择运行那些tag的测试用例,它支持正则表达式,可以使用 *,?来替代用例的名称。 还可以使用 AND,OR,Not等操作符。 例如 --include smoke --include BVT; --inlcude smokeANDB*等等。

--exclude tag *   选择不执行那些tag的测试用例。

--outputdir dir     选择输出的日志和报告的文件夹路径。

--output file     设置输出的文件路径,默认是一个XML文件。

--log file        设置输出HTML的log文件, 可以用NONE来关闭,不推荐。
--report file              设置输出HTML report 文件,也可以使用NONE来关闭,不推荐。 默认文件名字为 report.html。

--timestampoutputs  如果使用了该选项,他会在输出的文件名中间加上一个时间戳 格式为 YYYMMDD-hhmmss。

--maxerrorlines lines 该参数用来设置在报告中,显示多少行错误信息。默认是40行,最小是10行。使用参数NONE,则会显示所有错误信息。

--loglevel level   设置log的输出级别, 默认有TRACE,DEBUG, INFO (default), WARN, NONE (no logging)。 例如 --loglevel DEBUG  --loglevel DEBUG:INFO

 

根据文档,我们基本上可以使用以下格式来用命令启动robot执行用例: robot --options(参数) robot文件目录。 

其中文件目录如果是具体到了robot文件,那么只会执行该文件中的相关用例。

还可以同时执行多个文件, 比如 robot d:\smoke.robot, e:\BVT.robot.

如果路径是个文件夹,robot会执行该目录下的所有robot文件, 比如 project下面有 1.robot, 2.robot, name语句 robot ../project 就是执行1.robothe 2.robot中所有的测试用例。

在一个demo的测试项目中使用的命令如下:

robot --include tag demo -d D:\demo -o output -l log -r report -T --timestampoutputs --maxerrorlines NONE -L DEBUG D:\PUMA_AUTO\RF_PUMA\PUMA\demo.robot

如果想要再进一步,我的解决方案是,新建了一个ini配置文件,写一个python脚本来解析配置文件,这样只要通过修改ini配置文件,就可以灵活的执行你想要用例或者测试套件。

当然如果你想要和CI集成, Jenkins本身就有很好的插件支持,有机会我们可以尝试一下。