IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> 基于nodejs的selenium的自动化测试这环境安装 -> 正文阅读

[开发测试]基于nodejs的selenium的自动化测试这环境安装

Selenium 通过使用 WebDriver 支持市场上所有主流浏览器的自动化。每个浏览器都有一个特定的WebDriver,称为驱动程序,用于控制web浏览器的行为。

如下为各浏览器对应的驱动:

Browser                     Component

Chrome                      chromedriver(.exe)

Internet Explorer          IEDriverServer.exe

Edge                          MicrosoftWebDriver.msi

Firefox 47+                 geckodriver(.exe)

PhantomJS                 phantomjs(.exe)

Opera                        operadriver(.exe)

Safari                         SafariDriver.safariextz

1.下载相应的驱动到本地,解压找到以exe结尾的文件,放入相应的文件夹中,然后把路径配置在path中。(ps:驱动要与浏览器的版本相同)

驱动要与浏览器的版本如何查看参考文章:

https://blog.csdn.net/weixin_46308904/article/details/109306234

path查找参考如下图在这里插入图片描述

2.安装node环境,直接去官网下载安装:https://nodejs.org/en/

3.新建一个文件夹,然后在当前文件夹下执行:npm install selenium-webdriver,会多出一个node_modules目录,然后新建一个demo.js文件,在内部执行(webstrom\vsCode中run 这个js内的方法)如下代码:


var webdriver = require('selenium-webdriver'),
By = webdriver.By,
until = webdriver.until;
var driver = new webdriver.Builder().forBrowser('chrome').build();
driver.get('https://www.baidu.com');
driver.findElement(By.id('kw')).sendKeys('webdriver');
 driver.findElement(By.id('su')).click();
driver.wait(until.titleIs('webdriver_百度搜索'), 1000);
driver.quit();

项目结构参考如下图:
在这里插入图片描述

4.运行 node index.js

可以采用的专用的工具进行测试代码编辑:

http://cuketest.com/zh-cn/overview

关于救援的一个demo(仅本人的内网可运行):

const {Builder, By, until} = require('selenium-webdriver');
 
const assert = require('assert');
(async () => {
  let driver = await new Builder().forBrowser('chrome').build();
  // 设置等待时长
  // await driver.manage().setTimeouts( { implicit: 100000 } );
  try{
    // 最大化窗口
    await driver.manage().window().maximize();
 
    await driver.get('http://192.168.3.200:18099/rescure/');
    await driver.sleep(500)
    // 判断是否跳转到登录页
    let curUrl = await driver.getCurrentUrl()
    assert.strictEqual(curUrl, 'http://192.168.3.200:18099/rescure/#/login')
     
     
    // 设置账号密码
    await driver.findElement(By.name('loginName')).sendKeys('rescure')
    await driver.findElement(By.name('password')).sendKeys('888888')
 
    // 点击登录按钮
    // await driver.findElement(By.css('p')).click()
    await driver.wait(until.elementLocated({css: 'p'}), 1000).click()
 
    await driver.sleep(1000)
 
    // 进入首页 判断首页是否正常显示
    let ele = await driver.findElement(By.xpath('//*[@id="app"]/div[1]/div[1]/div/div[2]/div[3]/div/span'))
    assert.strictEqual(await ele.getText(), 'rescure 欢迎你')
 
    await driver.sleep(2000)
    // 点击弹出框的忽略按钮
    await driver.findElement(By.xpath('/html/body/div[3]/div/div[3]/button[1]')).click()
 
     
    // 点击接警管理 菜单
    await driver.findElement(By.xpath('//*[@id="app"]/div[1]/div[2]/div/div[1]/div/ul/div/div/li[1]')).click()
    await driver.sleep(1000)
 
    // 点击未归档菜单
    await driver.findElement(By.xpath('//*[@id="app"]/div[1]/div[2]/div/div[1]/div/ul/div/div/li[1]/ul/a[1]')).click()
     
    // 所属区域下拉选择 --start
    let select_xpath = '//*[@id="app"]/div[1]/div[2]/section/div/div[2]/div[1]/div[1]/form/div/div[1]/div[1]/div/div[4]/div/div/div/div/input'
    await driver.wait(until.elementLocated({xpath: select_xpath}), 3000).click()
 
    let selectItem_xpath = '/html/body/div[4]/div[1]/div[1]/ul/li[3]'
    await driver.wait(until.elementLocated({xpath: selectItem_xpath}), 3000).click()
 
    let search_xpath = '//*[@id="app"]/div[1]/div[2]/section/div/div[2]/div[1]/div[1]/form/div/div[1]/div[2]/div/div[1]/button'
    await driver.findElement({xpath: search_xpath}).click()
     
    // 所属区域下拉选择 --end
 
    await driver.sleep(1000)
 
    // 判断当前页面表格是否有数据  
    await driver.executeScript(function(){
      let ele1 = document.querySelector('.orioc-page-wraper')
      let ele2 = ele1.querySelector('.el-pagination__total').value
      if(ele2 != '共 0 条'){ // 说明有数据 点击第一条的详情
        return
      }
    })
 
    // 找到表格的第一行
    await driver.wait(until.elementLocated({ xpath: '//*[@id="app"]/div[1]/div[2]/section/div/div[2]/div[1]/div[2]/div/div/div[2]/div[5]/div[2]/table/tbody/tr[1]' }), 2000)
 
    // 定位第一行的业务单元素
    let row1_ele = await driver.wait(until.elementLocated({ xpath: '//*[@id="app"]/div[1]/div[2]/section/div/div[2]/div[1]/div[2]/div/div/div[2]/div[4]/div[2]/table/tbody/tr[1]/td[2]/div/p' }), 1000)
 
    // 点击详情按钮
    await driver.wait(until.elementLocated({ xpath: '//*[@id="app"]/div[1]/div[2]/section/div/div[2]/div[1]/div[2]/div/div/div[2]/div[5]/div[2]/table/tbody/tr[1]/td[18]/div/button[2]' }), 5000).click()
     
    // 获取详情页面中业务单编号元素
    let detail_ele = await driver.findElement({ xpath: '//*[@id="app"]/div[1]/div[8]/div/div[2]/div/div/div[1]/div/div/div/div/form/div/div/div/div'})
 
    let txt1 = await row1_ele.getText()
    let txt2 = await detail_ele.getText()
 
    console.log('txt1', txt1)
    console.log('txt2', txt2)
 
    assert.strictEqual(txt1, txt2)
 
    await driver.sleep(1000)
 
 
    // 关闭业务单详情
    // await driver.findElement({xpath: '//*[@id="app"]/div[1]/div[8]/div/div[1]/button'}).click()
 
  }
  finally{
   // driver.quit()
  }
})()

附录相关网站资料

http://www.selenium.org.cn/1694.html

https://www.selenium.dev/zh-cn/documentation/getting_started/

https://www.selenium.dev/selenium/docs/api/javascript/module/selenium-webdriver/lib/until.html

  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2021-09-04 17:50:56  更:2021-09-04 17:51:11 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/21 4:21:52-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码