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,大概看下是如何調(diào)用的。
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測試。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
使用nodejs中httpProxy代理時候出現(xiàn)404異常的解決方法
下面小編就為大家?guī)硪黄褂胣odejs中httpProxy代理時候出現(xiàn)404異常的解決方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-08-08node.js中fs文件系統(tǒng)目錄操作與文件信息操作
本篇文章給大家詳細分析了node.js中fs文件系統(tǒng)目錄操作與文件信息操作的方法以及代碼詳解,需要的讀者可以參考下。2018-02-02Node.js中的HTTP?Server對象與GET、POST請求
這篇文章介紹了Node.js中的HTTP?Server對象與GET、POST請求,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-07-07輕松創(chuàng)建nodejs服務(wù)器(10):處理上傳圖片
這篇文章主要介紹了輕松創(chuàng)建nodejs服務(wù)器(10):處理上傳圖片,本文是系列文章的最后一篇,包含了一個完整的處理上傳圖片的例子,需要的朋友可以參考下2014-12-12詳解nodejs微信公眾號開發(fā)——3.封裝消息響應(yīng)模塊
上一篇文章:nodejs微信公眾號開發(fā)(2)自動回復(fù),實現(xiàn)了簡單的關(guān)注回復(fù)。采用拼接字符串的形式,并不是很方便,這里我們將其封裝承接口。2017-04-04