欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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测试。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。