Node.js環(huán)境下Koa2添加travis ci持續(xù)集成工具的方法
前言
因為最近使用koa2做項目測試開發(fā),所以想整合下travis ci,網(wǎng)上資料也比較少,于是自己就整了個,做個記錄。分享出來供大家參考學習,下面來看看詳細的介紹吧。
方法如下:
先來看下travis.yml的配置
language: node_js node_js: - "6" before_script: - ./node_modules/.bin/knex migrate:latest --knexfile='./app/knexfile.js' script: - npm run test
因為是接口測試,所以首先需要做表創(chuàng)建等操作。
測試的命令:
NODE_ENV=production NODE_CONFIG_DIR='./app/config/' ./node_modules/.bin/mocha --require 'babel-polyfill' --compilers js:babel-register ./app/test/**/*.js
主要是測試這里,使用了supertest,大概看下是如何調用的。
const request = require('supertest');
const should = require('should');
const index = require('../../index');
let app = request(index.listen());
describe('/api/persons', function() {
let personId;
it('POST /api/persons - create person success and respond with 200', function(done) {
app.post('/api/persons')
.send({
'firstName': 'Jennifer',
'lastName': 'Lawrence',
'age': 24
})
.expect(200)
.expect(function(res) {
(res.body.id > 0).should.be.true;
})
.end(function(err, res) {
if (err) {
return done(err);
}
let resJson = JSON.parse(res.text);
personId = resJson.id;
done();
})
});
it('GET /api/persons - fetch persons item', function(done) {
app.get('/api/persons')
.expect(200)
.expect(function(res) {
(res.body.length > 0).should.be.true;
})
.end(function(err, res) {
if (err) {
return done(err);
}
done();
})
});
it('GET /api/persons/:id - fetch a person', function(done) {
app.get(`/api/persons/${personId}`)
.expect(200)
.expect(function(res) {
(res.body.id == personId).should.be.true;
})
.end(function(err, res) {
if (err) {
return done(err);
}
done();
})
});
it('DELETE /api/persons/:id - delete a person', function(done) {
app.delete(`/api/persons/${personId}`)
.expect(200)
.end(function(err, res) {
if (err) {
return done(err);
}
done();
})
});
it('GET /api/persons/:id - fetch a person should 404', function(done) {
app.get(`/api/persons/${personId}`)
.expect(404)
.end(function(err, res) {
if (err) {
return done(err);
}
done();
})
});
});
這里主要注意的是
const index = require('../../index');
需要將koa實例暴漏出來,不然在做travis ci的集成后,啟動了項目,測試的時候依然找不到具體訪問地址。
來看下我的index.js
import Knex from 'knex';
import {
Model
} from 'objection';
import knexConfig from './knexfile';
import config from 'config';
import Koa from 'koa';
import koaLogger from 'koa-logger';
import bodyParser from 'koa-bodyparser';
import render from 'koa-ejs';
import co from 'co';
import koaStatic from "koa2-static"
import router from './router';
const path = require('path');
// initial knex
const knex = Knex(knexConfig.development);
Model.knex(knex);
// initial app
const app = new Koa();
// initial render
render(app, {
root: path.join(__dirname + '/view'),
layout: 'template',
viewExt: 'ejs',
cache: true,
debug: true
});
app.context.render = co.wrap(app.context.render);
// initial static
app.use(koaLogger())
.use(bodyParser())
.use(router.routes())
.use(koaStatic({
path: '/web',
root: __dirname + "/../static"
}));
module.exports = app;
需要注意的是這里的
module.exports = app;
暴漏出來,再supertest中才可以獨立啟動server測試。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
Windows下安裝Bun像Node或Deno的現(xiàn)代JS運行時
這篇文章主要為大家介紹了一款像Node或Deno的現(xiàn)代JavaScript運行時的bun在Windows下安裝過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07
深入理解Commonjs規(guī)范及Node模塊實現(xiàn)
本篇文章主要介紹了深入理解Commonjs規(guī)范及Node模塊實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05
node.js基于dgram數(shù)據(jù)報模塊創(chuàng)建UDP服務器和客戶端操作示例
這篇文章主要介紹了node.js基于dgram數(shù)據(jù)報模塊創(chuàng)建UDP服務器和客戶端操作,結合實例形式分析了node.js使用dgram數(shù)據(jù)報模塊創(chuàng)建UDP服務器和客戶端,以及進行UDP廣播、組播相關操作技巧,需要的朋友可以參考下2020-02-02

