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

作者: 齐小猴 | 来源:发表于2018-03-21 18:11 被阅读352次

           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/

    相关文章

      网友评论

        本文标题:Node.js结合selenium做web自动化测试第七课

        本文链接:https://www.haomeiwen.com/subject/qkabqftx.html