Node.js环境下Koa2添加travis ci持续集成工具的方法
程序员文章站
2022-06-24 17:05:31
前言
因为最近使用koa2做项目测试开发,所以想整合下travis ci,网上资料也比较少,于是自己就整了个,做个记录。分享出来供大家参考学习,下面来看看详细的介绍吧。...
前言
因为最近使用koa2做项目测试开发,所以想整合下travis ci,网上资料也比较少,于是自己就整了个,做个记录。分享出来供大家参考学习,下面来看看详细的介绍吧。
方法如下:
先来看下travis.yml的配置
language: node_js node_js: - "6" before_script: - ./node_modules/.bin/knex migrate:latest --knexfile='./app/knexfile.js' script: - npm run test
因为是接口测试,所以首先需要做表创建等操作。
测试的命令:
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测试。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
上一篇: angularjs下拉框空白的解决办法
下一篇: 解决Extjs下拉框不显示的问题