> 웹 프론트엔드 > JS 튜토리얼 > 프런트 엔드 페이지를 테스트하는 방법

프런트 엔드 페이지를 테스트하는 방법

php中世界最好的语言
풀어 주다: 2018-03-14 13:31:53
원래의
3892명이 탐색했습니다.

이번에는 프런트엔드 페이지 테스트 방법을 알려드리겠습니다. 프런트엔드 페이지 테스트의 주의사항은 무엇인가요? 실제 사례를 살펴보겠습니다.

기능 테스트의 경우, 예를 들어 일부 고정된 입력 및 출력이 있는 경우 mocha를 사용하여 테스트할 수 있습니다.

페이지 기능 테스트의 경우 악몽을 권장합니다.

var Nightmare = require('nightmare');var nightmare = Nightmare({ show: true });
nightmare
  .goto('https://www.taobao.com/')  //待测试链接
  .type('#q', '电视机')   //输入框选中,输入值
  .click('form[action*="/search"] [type=submit]')//form表单提交
  .wait(3000)
  .exists('#spulist-grid')
  .evaluate(function () {    return document.querySelector('#spulist-grid .grid-item .info-cont') //获取需返回的值
      .textContent.trim();
  })
  .end()
  .then(function (result) {  //即为return中的数据
    console.log(result);
  })
  .catch(function (error) {  //错误捕捉
    console.error('Search failed:', error);
  });
로그인 후 복사

모카와 함께 사용할 수 있습니다.

var Nightmare = require('nightmare');var expect = require('chai').expect;var fork = require('child_process').fork;
describe('test index.html', function() {  var child;
  before(function (done) {   //钩子函数,测试之前调用
    child = fork('./server.js');
    child.on('message', function (msg) {      if (msg === 'listening') {
        done();
      }
    });
  });
  after(function () { //钩子函数,测试之后调用
    child.kill();
  });
  it('点击后标题改变', function (done) {    var nightmare = Nightmare({ show: true });
    nightmare
      .goto('http://127.0.0.1:8080/index.html')
      .click('h1')
      .wait(1000)
      .evaluate(function () {        return document.querySelector('h1').style.color;
      })
      .end()
      .then(function(color) {        console.log(color)
        expect(color).to.equal('red');
        done();
      })
  });
});
로그인 후 복사

이유는 모르겠지만, 프론트엔드 자동화 테스트는 어느 정도 어렵다는 걸 늘 느껴요. 마스터에게 대중화를 요청하세요...

이 기사의 사례를 읽으신 후 방법을 마스터하셨다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트기타관련 기사를 주목하세요!

추천 도서:

자바스크립트 호출에 대한 자세한 설명

자바스크립트 호출, 적용, 바인딩의 차이점은 무엇인가요

위 내용은 프런트 엔드 페이지를 테스트하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿