Node.js结合selenium做web自动化测试第七课

       hello大家好,看了上节课的promise,那个小猴子老猴子吃桃子打农药的俄罗斯套娃式的程序,有没有剪不断理还乱,如果看懂了,恭喜你,离大神又近了一步,如果绕晕了,没关系,我们今天就来介绍一个优雅的异步问题的办法,好用不粘人,那就是我们之前经常提到的async/await CP组合

还是从昨天老猴子要打农药的故事说起,我们前期设置好了打农药之前的一系列准备环节

昨天的代码是用then去控制这一系列过程,写起来是这样的

今天我们让这段代码休息一下,请出CP组合async/await登场,我们定义这样一个方法run

在它的前面加一个async

run的方法里面肯定是要逐个调用我们上面前期准备的各个方法,有了async,带出方法前别忘了await

但是呢,毕竟方法名相对来说略长,用一个变量代替它

其余几个方法都是一个路子,最后别忘了把方法run()调用出来

搞定!运行一下试试

有没有觉得高端大气上档次,就这么低调奢华有内涵

回头看一眼这里,我们昨天说到过promise里的resolve和reject了是吧,几段函数都是返回了成功的情况,那么这里如果想要传值给reject怎么玩呢,比如说,小猴子去摘桃,发现桃子被隔壁老王都摘走了

我们先定义一个布尔类型值,默认值为true

下面的方法里会有两种情况出现

第一种,小猴子摘到了桃子

如果桃子被隔壁老王摘了,那就放回给reject

如何取这个值呢,这样就是拿到resolve的值

reject说,那我呢,别急,后面加个catch

你猜,这段代码运行出来结果是啥

因为上面的isbool值是true,所以返回的是resolve值,小猴摘到桃

如果你想要让你隔壁老王获胜的话,就把上面的isbool=false,老猴子今天就吃不到桃子了,这就是promise里面的resolve和reject

下面的内容还说一个定位的操作吧,大家有没有留意过百度首页更多产品下的列表,只有鼠标hover到这里的时候才会显示列表下的选项,现在我们如果想直接进入音乐页面,怎么去操作这个鼠标移动并且点击的操作呢

我们先新建一个feature文件把场景填写上

不知道鼠标怎么移动,那我们就去API里找一下相关的操作好了,支持模糊查询的很好用,输入个mouse就给带出来一系列的操作了

附上网址:https://seleniumhq.github.io/selenium/docs/api/javascript/module/selenium-webdriver/lib/actions_exports_LegacyActionSequence.html#mouseMove

嗯,一会儿就这么用,把它移动到哪呢,我们先去定位一下这个元素

class属性值bri,找一下这个值还是唯一的,那就用它好了,第一步,findElement,赋值给gengduo

然后模拟鼠标移动动作,先调用action,这里你会发现我们的工具有代码提示功能,是不是很炫

上面实现了移动到更多按钮,下面移动到音乐

定位的时候大家有没有发现这个列表下的元素非常不好找

原因在这里,看到这里display后面的none了吗,导致我们的元素撒手就找不到了

不用怕,我们把它的值手动改一下none改成block

再去定位一下

接下来撒欢写代码吧,记得后面有个perform一定要加,这是action要调用的方法,不加的话小心它有小情绪不给你执行代码

如果有同学运行到这里报元素找不到的问题,很有可能是时间等待的问题,记得之前的sleep吗,适当的节奏慢一点,没关系的,该sleep就sleep,想等几秒你决定

最后一步添加断言,判断结果和预期是否一致

没毛病

今天的课堂笔记到这里,下期节目预告:nodejs-selenium中的显示等待与隐式等待

https://ke.qq.com/course/281565#tuin=173f40be,周一至周五晚上8:00,欢迎光临

测试工具CukeTest下载地址http://www.cuketest.com/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容