>

안녕하세요. 관심을 가져 주셔서 감사합니다.

모카와 수퍼 테스트로 테스트를 실행하려고하는데 문제가 없어도 테스트는 영원히 실행됩니다. 이를 피하기 위해 after () 메소드에 하나의 "process.exit (0)"을 추가하여 올바르게 빌드 할 수는 있지만 "격리"(실제로는 좋지 않은 것처럼 보입니다.-))

내 package.json :

{
  "name": "application-name",
  "version": "0.0.1",
  "private": true,
  "scripts": {
    "start": "nodejs ./bin/www",
    "test": "mocha"
  },
  "dependencies": {
    "body-parser": "~1.0.0",
    "cookie-parser": "~1.0.1",
    "debug": "~0.7.4",
    "ejs": "~0.8.5",
    "express": "~4.0.0",
    "is-my-json-valid": "^2.16.1",
    "knex": "^0.13.0",
    "morgan": "~1.0.0",
    "mysql": "^2.14.1",
    "static-favicon": "~1.0.0"
  },
  "devDependencies": {
    "mocha": "^4.0.0",
    "supertest": "^3.0.0",
    "chai": "^4.1.2",
    "util": "^0.10.3"
  }
}

내 테스트 :

var request = require('supertest');
var util    = require('util');
describe('Endpoints', function () {
  var server;
  beforeEach(function() {
    server = require('../app').listen(3000);
  });
  afterEach(function(done) {
    server.close(done);
  });
  after(function(done){
    process.exit(0); // <-- THIS LOOKS REALLY BAD
  });
  it('Success ', function(done) {
    var deputy = {name:"Meu Nome", uf:"SP", site_id:"1", secondary_site_id:"2"}
    request(server)
      .post('/api/deputy')
      .send(deputy)
      .expect(200, done);
  });
  it('Bad request ', function(done) {
    var deputy = {naonome:"Nao deve funcionar"}
    request(server)
      .post('/api/deputy')
      .send(deputy)
      .expect(400, done);
  });
});

테스트가 끝나지 않는 이유는 무엇입니까?

감사합니다

수정 : Express Generator로 생성 된 내 app.js를 따릅니다

var express = require('express');
var path = require('path');
var favicon = require('static-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var routes = require('./routes/index');
var deputy = require('./routes/deputy');
var db  = require('./server/db');
var app = express();
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');
app.use(favicon());
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded());
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', routes);
app.use('/api/deputy', deputy);
/// catch 404 and forwarding to error handler
app.use(function(req, res, next) {
    var err = new Error('Not Found');
    err.status = 404;
    next(err);
});
/// error handlers
// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
    app.use(function(err, req, res, next) {
        res.status(err.status || 500);
        res.render('error', {
            message: err.message,
            error: err
        });
    });
}
// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
        message: err.message,
        error: {}
    });
});

module.exports = app;

  • 답변 # 1

    데이터베이스 연결과 같은 소리가 여전히 실행 중입니다.

    으로 닫을 수 있습니다
    connection.end(function(err) {
      // The connection is terminated now
    });
    
    

    /server/db 파일에서 연결을 얻을 수 있다고 가정합니다. 아직 내 보내지 않은 경우 내 보냅니다.

    mysql을 직접 사용하지는 않지만 MongoDB를 사용할 때의 내 기능은 다음과 같습니다.

    after(function (done) {
        server.close(function () {
          mongoose.connection.close(done)
        })
    })
    
    

    데이터베이스 연결을 닫지 않으면 테스트는 끝까지 계속 실행되지만 쉘을 끝내고 종료하지는 않습니다.

  • 답변 # 2

    Pass --mocha 프로세스로 빠져 나갑니다.

    mocha --exit
    
    

관련 자료

  • 이전 android - 하나의 LinearLayout에서 10 개의 gridView에 대해 동기 스크롤을 수행하는 방법
  • 다음 vue.js - 동적 비율을 가진 scss의 선형 그라디언트