一.e2e测试简介

e2e或者端到端(end-to-end)或者UI测试是一种测试方法,它用来测试一个应用从头到尾的流程是否和设计时候所想的一样。简而言之,它从一个用户的角度出发,认为整个系统都是一个黑箱,只有UI会暴露给用户。

想象一下,如果把这些自动化的测试工作换成人工来做,那会多么的令人头疼,尤其是对于那些具有大量交互的应用,手工测试将会以编程不可能的任务。

下文中,将会介绍如何使用Nightmare来进行自动e2e测试.

二.什么是Nightmare?

Nightmare是来自Segement的高级浏览器自动化库。

它公布了一些方法,例如.goto(),.type()和.click()等,通过一个个API的衔接使用,给人感觉每个模块似乎是同步的。最常用于UI测试和爬取。

三.如何使用Nightmare?

个人觉得,相对如单元测试(之前踩过ezyme的坑)的一些配置,Nightmare用起来确实挺方便。

首先,安装相应的依赖(不要问我依赖是什么,其实我也不知道是什么^_^):

  1. npm install --save-dev mocha
  2. npm install --save-dev nightmare
  3. npm install --save-dev assert
  4. npm install --save-dev chai

  1. 在项目根目录下创建test文件夹(一定要是项目根目录),所有的测试用例都需要以'.js'为后缀的格式创建在test文件夹下。

然后,打开根目录下package.json文件,配置测试命令,很简单:

  1. "scripts": {
  2. "test": "mocha"
  3. }
  1.  

准备工作已经完毕,我们来写几个简单的测试用例:

1.访问某站首页,若成功,显示加载时间,否则抛出error

  1. const Nightmare = require('nightmare')
  2. const assert = require('assert')
  3.  
  4. describe('Load a Page', function() {
  5.   // 设置超时时间
  6.   this.timeout('30s')
  7.  
  8.   let nightmare = null
  9.   beforeEach(() => {
  10.     nightmare = new Nightmare()
  11.   })
  12.  
  13.   it('should load locaohos:8000 success', done => {
  14.     // 实际开发中访问的url可能是这`http://localhost:port/path`
  15.     nightmare.goto('http://localhost:8000/')
  16.     .end()
  17.     .then(function (result) { done() })
  18.     .catch(done)
  19.   })
  20.  
  21.   it('should load baidu(/home page) success', done => {
  22.     // 访问百度
  23.     nightmare.goto('http://www.baidu.com/')
  24.     .end()
  25.     .then(function (result) { done() })
  26.     .catch(done)
  27.   })
  28.  
  29.   it('should load without error', done => {
  30.     // 访问谷歌根目录,会error(大家懂的)
  31.     nightmare.goto('https://www.google.com/')
  32.     .end()
  33.     .then(function (result) { done() })
  34.     .catch(done)
  35.   })
  36.  
  37.   it('should load without error', done => {
  38.     // 访问谷歌根目录下的webhp页面,会error(大家懂的)
  39.     nightmare.goto('https://www.google.com/webhp')
  40.     .end()
  41.     .then(function (result) { done() })
  42.     .catch(done)
  43.   })
  44. })
结果如图所示:

2.模拟用户搜索:

  1. const expect = require('chai').expect;
  2. const Nightmare = require('nightmare');
  3. const assert = require('assert');
  4.  
  5. describe('simulate search', function () {
  6.   this.timeout('30s')
  7.  
  8.   let nightmare = null
  9.   beforeEach(() => {
  10.     // 设置显示模拟弹框
  11.     nightmare = new Nightmare({
  12.     show: true,
  13.    })
  14.   })
  15.  
  16.   it('模拟用户搜索', done => {
  17.     nightmare
  18.     .goto('https://www.baidu.com/') //设置搜索引擎
  19.     .viewport(1200, 672)   //设置弹框视口宽高        
  20.     .type('form[action*="/s"] [name=wd]', 'github nightmare') //获取搜索框,自动填充搜索内容
  21.     .click('form[action*="/s"] [type=submit]') //获取点击按钮,模拟点击
  22.     .wait(5000) //等待5s(可为dom节点),获取第一条的信息的内容
  23.     .evaluate(() =>
  24.      document.querySelector('#content_left .c-container a em').innerHTML
  25.     )
  26.     .end()
  27.     .then(content => {
  28.      console.log(content === 'Nightmare','----->true') //输出结果
  29.     })
  30.     .catch(error => {
  31.      console.error('Search failed:', error); //输出捕捉到的错误
  32.     });
  33.   })
  34. })
 结果大概是这样:

3. 模拟用户登录

  1. const Nightmare = require('nightmare')
  2. const assert = require('assert')
  3.  
  4. describe('submit form', function () {
  5.   this.timeout('30s')
  6.  
  7.   let nightmare = null
  8.   beforeEach(() => {
  9.     // 设置显示模拟弹框
  10.     nightmare = new Nightmare({
  11.       show: true
  12.     })
  13.    })
  14.  
  15.   it('模拟用户搜索', done => {
  16.     nightmare
  17.     .goto('登录页url')   //设置登录loginUrl
  18.     .type('selector', '填入用户名') //通过选择器获取登录名文本框节点,自动模拟用户填写用户名
  19.     .type('selector', '填入密码') //通过选择器获取密码文本框节点,自动模拟用户填写密码
  20.     .click('selector')   //获取点击按钮,模拟点击登录
  21.     .wait(5000)     //设置5s之后返回结果页面title
  22.     .evaluate(() => {
  23.       return document.title;
  24.     })
  25.     .end()
  26.     .then(title => {
  27.      console.log(title) //输出结果
  28.     })
  29.     .catch(error => {
  30.      console.error('Search failed:', error); //输出捕捉到的错误
  31.     });
  32.   })
  33. })
这里的效果就不再展示了。
 
 
如果想了解更多,可以查阅官方文档
 
  1.  
  1.  

e2e测试之Nightmare的更多相关文章

  1. Nightmare基于phantomjs的自动化测试套件

    今天将介绍一款自动化测试套件名叫nightmare,他是一个基于phantomjs的测试框架,一个基于phantomjs之上为测试应用封装的一套high level API.其API以goto, re ...

  2. E2E测试框架

    1. 目前E2E测试工具有哪些? 项目 Web Star puppeteer Chromium (~170Mb Mac, ~282Mb Linux, ~280Mb Win) 41427 nightma ...

  3. 《Google软件测试之道》基础

    <Google软件测试之道>,一直听朋友讲起这本书,出于琐事太多,一直没机会拜读,最近部门架构觉得我们IT部门的技术太low,就给我们挑选了一些书籍,让我们多看看... 个人的一种学习习惯 ...

  4. HDU 1072 Nightmare

    Description Ignatius had a nightmare last night. He found himself in a labyrinth with a time bomb on ...

  5. google软件测试之道--读后笔记

         看完google软件测试之道,以前有认真看过一次,今天又重新看了一遍.   在google,测试人员严格区分为SET和TE.SET前期深度参与项目的开发,推动开发人员的自测,从破坏者的角度寻 ...

  6. HttpClient接口测试之会话保持

    HttpClient接口测试之会话保持     HttpClient4.X自带会话保持功能,使用同一个HttpClient未关闭的连接即可保持登陆会话,如果多个HttpClient想要使用一个登陆会话 ...

  7. angular 调试 js (分 karms protractor / test e2e unit )

    首页订阅 Protractor端到端的AngularJS测试框架教程 2014年01月18日 分类:教程, JavaScript, AngularJS Protractor是一个建立在WebDrive ...

  8. Android自动化测试之Monkeyrunner学习笔记(一)

    Android自动化测试之Monkeyrunner学习笔记(一) 因项目需要,开始研究Android自动化测试方法,对其中的一些工具.方法和框架做了一些简单的整理,其中包括Monkey.Monkeyr ...

  9. iOS 单元测试之XCTest详解(一)

    iOS 单元测试之XCTest详解(一) http://blog.csdn.net/hello_hwc/article/details/46671053 原创blog,转载请注明出处 blog.csd ...

随机推荐

  1. HTML5之window.applicationCache对象

    不知道离线缓存技术的可以参照上一篇文章: HTML5之appcache语法理解/HTML5应用程序缓存/manifest缓存文件官方用法翻译 参考文章 window.applicationCache  ...

  2. WordPress 4.8 安装配置教程 (基于 centos 7.3, php 7.0, mysql 5.7.19, nginx 1.12.1)

    最近想要整个 blog,记录自己工作.学习中的点滴.Wordpress 自然是首选,因为内容才是关键,所以也就不怕别人说太 low.网上大部份都是讲 wordpress 配合 apache 的安装教程 ...

  3. 数据抓取分析(python + mongodb)

    分享点干货!!! Python数据抓取分析 编程模块:requests,lxml,pymongo,time,BeautifulSoup 首先获取所有产品的分类网址: def step(): try: ...

  4. [ACdream]小晴天老师系列——竖式乘

    题目链接:http://acdream.info/contest?cid=1269#problem-C Problem Description 小晴天是ACdream团队中最牛的老师之一,他最擅长数学 ...

  5. LeetCode 530. Minimum Absolute Difference in BST (二叉搜索树中最小绝对差)

    Given a binary search tree with non-negative values, find the minimum absolute difference between va ...

  6. LeetCode 80. Remove Duplicates from Sorted Array II (从有序序列里移除重复项之二)

    Follow up for "Remove Duplicates":What if duplicates are allowed at most twice? For exampl ...

  7. Vim - 常用配置

    基本配置 不用任何插件的情况下,先按如下配置: set nu syntax on set hlsearch set tabstop=4 set shiftwidth=4 set expandtab s ...

  8. [Bayesian] “我是bayesian我怕谁”系列 - Latent Variables

    下一章有意讲讲EM和变分推断的内容. EM和变分推断的内容能Google到很多,虽然质量乘次不齐,但本文也无意再赘述那么些个细节. 此处记录一些核心思想,帮助菜鸡形成整体上的认识.不过,变分推断也不是 ...

  9. c#public、private、protected、internal、protected internal修饰符及访问权限

    c#public.private.protected.internal.protected internal修饰符及访问权限 public 公有访问.不受任何限制. private 私有访问.只限于本 ...

  10. JS框架设计读书笔记之-选择器引擎02

    选择器引擎涉及相关概念 概念 以Sizzle的主函数声明为例,来说明引擎的相关概念. function Sizzle(selector, context, results, seed) { //... ...