本文是最近在学习 Node.js 测试方面的总结,包括单元测试、集成测试、基准测试以及代码覆盖率测试等多方面的的内容。对于中大型项目,完备的测试用例有助于保证项目的持续集成能力和代码的健壮性。
Unit Test 单元测试,又称模块测试,针对程序中的最小执行单元进行正确性测试。常见的开发模式包括 TDD 和 BDD 两类。
TDD(Test-driven development,测试驱动开发),先编写测试用例,然后针对测试用例开发模块,当测试用例不足时,补充测试用例;当模块无法通过测试时,持续更新模块代码,直到完全通过测试用例。其开发核心围绕测试用例展开,即测试用例的完整性决定了开发模块的健壮性和正确性,这容易由边界条件引发单元测试覆盖度不够的问题。
BDD(Behavior-driven development,行为驱动开发),用语义化的编程语言开发紧贴业务需求的测试用例,继而驱动相关模块的开发。
AVA 是 JavaScript 生态中最新潮的测试框架,其内置了 Babel,可以直接使用 ES6 语法,具有轻量高效、并发执行、强制隔离等优点,安装方法:
npm install --save-dev ava
|
package.json에서 스크립트 필드 설정:
{{
"scripts": {
"test": "ava",
"test:watch": "ava --watch"
}
}
|
"스크립트": {
"테스트": "아바",
"test:watch": "ava --watch"
}
}
|
npm test
# or
npm test:watch
|
실행:
npm 테스트
# 또는import test from 'ava';
const fibonacci = (n) => {
if (n === 0 || n === 1) {
return n;
}
return fibonacci(n - 1) fibonacci(n - 2);
}
test('Test Fibonacci(0)', t => {
t.is(fibonacci(0), 0);
});
test('Test Fibonacci(1)', t => {
t.is(fibonacci(1), 1);
});
// HOOK CALLS
test.before('Before', t => {
console.log('before');
});
test.after('After', t => {
console.log('after');
});
test.beforeEach('BeforeEach', t => {
console.log(' beforeEach');
});
test.afterEach('AfterEach', t => {
console.log(' afterEach');
});
|
npm 테스트:보기
|
기본 테스트 코드는 다음과 같습니다.
'ava'에서 테스트 가져오기;
const 피보나치 = (n) =>
if (n === 0 || n === 1) {
n 반환;
}
피보나치 반환(n - 1) 피보나치(n - 2);
}
test('피보나치 테스트(0)', t => {
t.is(피보나치(0), 0);
});
test('피보나치 테스트(1)', t => {
t.is(피보나치(1), 1);
});
// 훅 호출
test.before('이전', t => {
console.log('이전');
});
test.after('이후', t => {
console.log('이후');
});
test.beforeEach('BeforeEach', t => {
console.log(' beforeEach');
});
test.afterEach('AfterEach', t => {
console.log(' afterEach');
});
|
위 코드에서는 먼저 AVA 모듈을 도입한 다음 테스트할 fibonacci 함수를 생성한 다음 두 가지 테스트 사례, 마지막으로 네 가지 후크 메서드(before() / after() / beforeEach())를 만들었습니다. /각각().
AVA는 테스트 실행 방법을 지정하기 위한 몇 가지 수정 방법을 제공합니다.
1. Skip(), Skip()이 추가된 테스트 케이스 건너뛰기
2. only()가 추가된 테스트만 실행;
3. todo(), 향후 추가해야 할 테스트 케이스를 나타내는 자리 표시자
4. , 테스트 케이스를 직렬로 실행합니다. 기본적으로 AVA는 테스트 케이스를 병렬로 실행합니다.
test('피보나치 테스트(0)', t => {test('Test Fibonacci(0)', t => {
t.is(fibonacci(0), 0);
});
|
t.is(피보나치(0), 0);
});
|
위 코드의 콜백 함수에 있는 t를 어설션 실행 개체라고 하며, 여기에는 다음 메서드가 포함되어 있습니다.
· t.end(), 테스트 종료, test.cb()에서만 유효
· t.plan(count), 실행 횟수 지정
· t.pass([message]), 테스트 통과
· t.fail([메시지]), 테스트 실패
· t.ok(값, [메시지] ]), value의 값이 true인지 확인
· t.notOK(value, [message]), value의 값이 false인지 확인
· t.true(value, [message])는 값이 참이라고 주장합니다
· t .false(value, [message]), value의 값이 false임을 주장
· t.is(value, Expect, [ message]), 값 주장 === 예상
· t.not(value, Expect, [message]), 값 주장 !== 예상
· t.same(value, Expect, [message])는 값과 예상 깊이가 동일하다고 주장합니다
· t .notSame(value, Expect, [message])는 값과 기대의 깊이가 동일하지 않다고 주장합니다
· t.throws(function | promise, [error, [ message]]), 함수가 예외 또는 promisereject 오류를 발생시키는지 확인
· t.notThrows (함수 | 약속, [메시지]), 함수가 예외를 발생시키지 않을 것이라고 주장하거나 해결을 약속합니다
· t.regex(contents, regex, [ message]), 내용이 정규식과 일치하는지 확인
· t.ifError(error, [message]), 오류가 거짓 값이라고 확인
통합 테스트
마이크로 모듈 중심의 단위 테스트에 비해 통합 테스트는 거시적 전체 관점에서 문제를 발견하므로 어셈블리 테스트, 조인트 테스트라고도 합니다. Travis CI는 Github 프로젝트 업데이트를 모니터링하고 오픈 소스 소프트웨어의 통합 테스트를 용이하게 할 수 있는 탁월한 연속 통합 도구입니다. Travis CI를 사용하려면 프로젝트의 루트 디렉터리에 .travis.yml 구성 파일을 생성해야 합니다(Node.js를 예로 사용):
language: node_js
node_js:
- "6"
- "5"
before_script:
script:
- npm test
- node benchmark/index.js
after_script:
|
언어: node_js
node_js:
- "6"
- "5"
before_script:
스크립트:
- npm 테스트
- 노드 벤치마크/index.js
after_script:
|
기본적으로 Travis CI는 종속성을 자동으로 설치하고 npm test 명령을 실행합니다. 스크립트 필드는 실행해야 하는 명령을 사용자 정의하는 데 사용할 수 있습니다.
·적절한 애드온 설치
·설치 전
·설치
·before_script
·script
·after_success 또는 after_failure
·선택 사항 before_deploy
·배포 선택 사항
·배포 후 선택 사항
· after_script
벤치마크 테스트 벤치마크 테스트는 엄격한 테스트 방법, 테스트 도구 또는 테스트 시스템을 사용하여 제품의 성능을 평가합니다. target 모듈은 소프트웨어 및 하드웨어 환경 변경 후 성능을 관찰하는 데 자주 사용되며 결과는 재현 가능합니다. Node.js 환경에서 가장 일반적으로 사용되는 벤치마킹 도구는 Benchmark.js입니다. 설치 방법:
npm install --save-dev 벤치마크npm install --save-dev benchmark
|
|
기본 예:
const Benchmark = require('benchmark');const Benchmark = require('benchmark');
const suite = new Benchmark.Suite;
suite.add('RegExp#test', function() {
/o/.test('Hello World!');
})
.add('String#indexOf', function() {
'Hello World!'.indexOf('o') > -1;
})
.on('cycle', function(event) {
console.log(String(event.target));
})
.on('complete', function() {
console.log('Fastest is ' this.filter('fastest').map('name'));
})
// run async
.run({ 'async': true });
|
const suite = 새로운 Benchmark.Suite;
suite.add('RegExp#test', function() {
/o/.test('Hello World!');
})
.add('String#indexOf', function() {
'Hello World!'.indexOf('o') >
})
.on('사이클', function(이벤트) {
console.log(String(event.target));
})
.on('완료', function() {
console.log('가장 빠른 것은 '입니다. this.filter('가장 빠른').map('name'));
})npm install nyc --save-dev
|
// 비동기 실행
.run({ 'async': true });
|
node_modules
coverage
.nyc_output
| 코드 커버리지 코드 커버리지 도구는 테스트 케이스에서 다루는 코드 라인 수와 분기 수를 기반으로 모듈의 무결성을 판단합니다. . AVA는 코드 적용 범위를 테스트하기 위해 nyc를 사용할 것을 권장합니다.
{
"scripts": {
"test": "nyc ava"
}
}
|
npm install nyc --save-dev
|
관련 파일을 무시하도록 .gitignore 수정:
➜ test-in-action (master) ✔ npm test
> test-in-action@1.0.0 test /Users/sean/Desktop/test-in-action
> nyc ava
2 passed
----------|----------|----------|----------|----------|----------------|
File | % Stmts | % Branch | % Funcs | % Lines |Uncovered Lines |
----------|----------|----------|----------|----------|----------------|
----------|----------|----------|----------|----------|----------------|
All files | 100 | 100 | 100 | 100 | |
----------|----------|----------|----------|----------|----------------|
|
node_modules
취재
.nyc_output
|
package.json에서 테스트 필드 수정:
{
"스크립트": {
"테스트": "nyc ava"
}
}
|
npm 테스트를 실행하고 다음을 얻습니다:
➜ 테스트 중(마스터) ✔ npm 테스트
> test-in-action@1.0.0 테스트 /Users/sean/Desktop/test-in-action
>뉴욕
2개 합격
----------|----------|----------|----------|------ ----|----------------|
파일 | % Stmts | % Funcs % 라인 | 발견되지 않은 라인 |
----------|----------|----------|----------|------ ----|----------------|
----------|----------|----------|----------|------ ----|----------------|
모든 파일 | 100 | 100 |
----------|----------|----------|----------|------ ----|----------------|
|
첨부파일 및 텍스트 업로드 제한으로 인해 일부 사진 및 텍스트가 표시되지 않을 수 있습니다. 자세한 내용은 http://mp.weixin.qq.com/s?__biz=MzI5ODI3NzY2MA==&mid=100000510&idx=2&sn=8339d4fca5f54ab3a9ec305eae756436#rd
모두의 소통을 환영합니다.
아래 QR코드를 스캔하시면 더 많은 아름다운 글들을 만나보실 수 있습니다! (QR코드를 스캔하시면 예상치 못한 놀라움을 만나보실 수 있습니다!!)
WeChat 구독 계정(uniguytech100)과 서비스 계정(uniguytech)을 팔로우하고 더 많은 아름다운 기사를 받아보세요!
[모두 기술 네트워크 토론 QQ 그룹], 그룹 번호: 256175955에도 참여하실 수 있습니다. 개인 소개를 꼭 적어주세요! 그것에 대해 함께 이야기합시다!
|