Katalon Studio 是一款免费的自动化测试工具,可以安装在windows、macOS、linux操作系统上,基于selenium 和 Appium 测试框架,并集成了这些框架的优点。工具使用简单方便,对于编码经验少,能力弱的测试人员也可以很快上手。
2.1、下载
Katalon 官网下载地址:https://www.katalon.com/download/(需要注册账号)。
2.2、安装
下载完毕,解压安装包,双击katalon.exe,打开katalon。

第一次安装,需要输入注册信息,注册成功之后,就可以使用了。

Katalon Studio 的操作界面分布清晰,操作简单,新手使用时很容易上手。
3.1、整体界面介绍

3.2、工具栏操作按钮介绍
主工具栏包含我们通常执行的最常见的操作。



3.3、Tests Explorer
ests Explorer视图,也就是项目初始化后展示的主要界面;允许您浏览项目的结构并快速访问所有测试工件。使用视图上的上下文菜单,您可以创建新的工件,组织视图的项目,或者在需要时将它们拖放到特定的编辑器视图中。

Profiles 配置文件–>当前项目的所有配置文件;
Test Cases 测试用例->当前项目中的所有测试用例;
Object Repository 界面元素->当前项目的所有测试对象;
Test Suites 测试套件->当前项目的所有测试套件和测试套件集合;
Data Files 测试数据文件->当前项目的所有测试数据;
Checkpoints 测试检查点->当前项目的所有测试用例的检查点;
Keywords 关键字函数->当前项目所有编写的关键字;
Test Listeners 测试监听->当前项目的所有测试监听;
Reports 测试报告->当前项目的所有生成报告;
Include 其他配置项;
Plugins 插件。
关键字工具集,该试图显示了Katalon Studio预封装的所有可用关键字。在编写脚本时,您可以将关键字拖放到测试用例编辑器中。



当我们新建一个用例或者打开一个测试用例时,它的详细信息会显示在包含以下选项卡的编辑器中:
Manual tab 通用编辑视图
Script tab 脚本编辑视图
Variables tab 变量编辑视图
Integration tab 集成工具编辑视图
Properties tab 属性选项视图
4.1、Manual tab 通用编辑视图
Manual tab为通用编辑模式,该编辑视图下可以通过操作方法名称检索并且选择需要使用的操作方法,也可以结合左树列关键字视图直接拖动需要使用的关键字到测试用例中。
(1) 通过索引选择关键字;

(2) 通过关键字视图选择关键字。

4.2、Script tab模式
Script tab编辑模式显示了对应的脚本视图,其中有编程基础的操作用户可以使用Groovy或Java语言轻松直接新增、修改、删除测试脚本。保存以后直接生成对应操作步骤的测试案例。

4.3、Variables tab模式
Variables tab模式显示为测试用例定义的所有公共变量,可以通过该界面定义所有变量的默认参数;在该界面新增的变量赋值以后,在执行该案例的时候读取的变量的数据为该部分所输入的数据。

4.4、Integration tab模式
Integration tab模式,该编辑视图显示为测试用例与qTest和JIPRA的集成的信息显示在这个视图中。

4.5、Properties tab模式
Properties tab模式,在该选项卡中显示关于测试用例的一般信息。
描述:用户可以添加或编辑该字段,以提供关于测试用例的详细信息。
注释:这个字段是只读的。内容从测试用例中的Comment关键字中提取并填充。业务用户可以通过提供需求来利用评论字段来参与开发过程。下面的例子展示了一个测试用例执行步骤的描述,以及输出执行结果。

5.1、创建一个测试用例

5.2、创建脚本
创建脚本分组:右击Test Cases——New——Floder;

右击Test——New——Test Case;

5.3、录制脚本
点击Record web;
输入访问地址与选择打开的浏览器,开始进行脚本的录制,直至脚本录制结束,点击下图红框处停止按钮并点击OK;
点击OK;
由于页面加载不确定性的存在,如网络延迟,需要手动配置操作的执行时间或顺序。可以在下图所示两个位置处进行修改:
a.在Manual tab视图中修改;
b.在Script tab视图中修改。
5.4、执行脚本
执行脚本,选择执行浏览器;
5.5、查看执行结果
5.6、创建用例的其他方法
除了以上这个录制脚本的方法,我们还有其他方法可以创建用例。
方法一:Spy web
用Spy Web功能添加对象到对象仓库中,在编写用例时,引用添加的对象。




方法二:编辑脚本
如果你有比较好的代码能力,可以直接编辑脚本来写测试用例。

最后:下方这份完整的软件测试视频学习教程已经整理上传完成,朋友们如果需要可以自行免费领取 【保证100%免费】


很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
我有一个围绕一些对象的包装类,我想将这些对象用作散列中的键。包装对象和解包装对象应映射到相同的键。一个简单的例子是这样的:classAattr_reader:xdefinitialize(inner)@inner=innerenddefx;@inner.x;enddef==(other)@inner.x==other.xendenda=A.new(o)#oisjustanyobjectthatallowso.xb=A.new(o)h={a=>5}ph[a]#5ph[b]#nil,shouldbe5ph[o]#nil,shouldbe5我试过==、===、eq?并散列所有无济于事。
我有一些Ruby代码,如下所示:Something.createdo|x|x.foo=barend我想编写一个测试,它使用double代替block参数x,这样我就可以调用:x_double.should_receive(:foo).with("whatever").这可能吗? 最佳答案 specify'something'dox=doublex.should_receive(:foo=).with("whatever")Something.should_receive(:create).and_yield(x)#callthere
Sinatra新手;我正在运行一些rspec测试,但在日志中收到了一堆不需要的噪音。如何消除日志中过多的噪音?我仔细检查了环境是否设置为:test,这意味着记录器级别应设置为WARN而不是DEBUG。spec_helper:require"./app"require"sinatra"require"rspec"require"rack/test"require"database_cleaner"require"factory_girl"set:environment,:testFactoryGirl.definition_file_paths=%w{./factories./test/
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我收到这个错误:RuntimeError(自动加载常量Apps时检测到循环依赖当我使用多线程时。下面是我的代码。为什么会这样?我尝试多线程的原因是因为我正在编写一个HTML抓取应用程序。对Nokogiri::HTML(open())的调用是一个同步阻塞调用,需要1秒才能返回,我有100,000多个页面要访问,所以我试图运行多个线程来解决这个问题。有更好的方法吗?classToolsController0)app.website=array.join(',')putsapp.websiteelseapp.website="NONE"endapp.saveapps=Apps.order("
我已经构建了一些serverspec代码来在多个主机上运行一组测试。问题是当任何测试失败时,测试会在当前主机停止。即使测试失败,我也希望它继续在所有主机上运行。Rakefile:namespace:specdotask:all=>hosts.map{|h|'spec:'+h.split('.')[0]}hosts.eachdo|host|begindesc"Runserverspecto#{host}"RSpec::Core::RakeTask.new(host)do|t|ENV['TARGET_HOST']=hostt.pattern="spec/cfengine3/*_spec.r
我在app/helpers/sessions_helper.rb中有一个帮助程序文件,其中包含一个方法my_preference,它返回当前登录用户的首选项。我想在集成测试中访问该方法。例如,这样我就可以在测试中使用getuser_path(my_preference)。在其他帖子中,我读到这可以通过在测试文件中包含requiresessions_helper来实现,但我仍然收到错误NameError:undefinedlocalvariableormethod'my_preference'.我做错了什么?require'test_helper'require'sessions_hel
只是想确保我理解了事情。据我目前收集到的信息,Cucumber只是一个“包装器”,或者是一种通过将事物分类为功能和步骤来组织测试的好方法,其中实际的单元测试处于步骤阶段。它允许您根据事物的工作方式组织您的测试。对吗? 最佳答案 有点。它是一种组织测试的方式,但不仅如此。它的行为就像最初的Rails集成测试一样,但更易于使用。这里最大的好处是您的session在整个Scenario中保持透明。关于Cucumber的另一件事是您(应该)从使用您的代码的浏览器或客户端的角度进行测试。如果您愿意,您可以使用步骤来构建对象和设置状态,但通常您