1

Restifyを使用した単一のPOSTサービスを備えた単純なNode.jsRestサーバーがあります。簡単なMochaテストを作成しようとしていますが、REST Consoleテスト(ブラウザープラグイン)では成功しますが、タイムアウトで失敗します。

私のサーバーコード:

/**
 * Module dependencies
 */

var restify = require('restify');
var events = require('events');
var util = require('util');


/**
 * Create App
 */

var server = restify.createServer({
  name: 'test',
    version: '0.0.1'
    });

var eventsEmitter = new events.EventEmitter();

/**
 * Configuraion
 */

server.use(restify.acceptParser(server.acceptable));
server.use(restify.queryParser());
server.use(restify.bodyParser());


/**
 * Routes
 */


server.post('/post', function (req, res, next) {
  var text = "";
  req.setEncoding("utf8");

  req.on("data", function (chunk) {
    text += chunk;
  });
  req.on("end", function () {
    res.send(200, {ok: 'ok'});   
  });

  return next();
});


/**
 * Listen
 */ 

server.listen(8080, function () {
  console.log('%s listening at %s', server.name, server.url);
});

モカテストは次のとおりです。

var restify = require('restify');
var assert = require('assert');

// init the test client
var client = restify.createJsonClient({
  url: 'http://127.0.0.1:8080',
  version: '*'
});

describe('service: post endpoint', function() {

// Test #1
describe('200 response check', function() {
    it('should get a 200 response', function(done) {
        client.post('/post', { hello: 'world' }, function(err, req, res, data) {                
            if (err) {
                throw new Error(err);
            }
            else {

                if (data.code != 200) {
                    throw new Error('invalid response from /post');
                }
                done();
            }
        });
    });
});

});

テストがタイムアウトする理由を誰かにアドバイスできますか(私はMochaでタイムアウトを増やしてテストしました)、ブラウザーを介して成功しますか?

4

1 に答える 1

5

server.post('/post', handler)問題は、リクエストの受信が終了したときにRestifyが関数を呼び出すことです。dataendイベントを待つ必要はありません。これは、Restify(およびそのような他のライブラリ(Expressなど))があなたのために行うことです。だからあなたがする必要があるのは書くことだけです

server.post('/post', function (req, res, next) {
    res.send(200, {ok: 'ok'});
});

そして、タイムアウトが発生しないようにする必要があります。ハンドラーがすでに発生したイベントを待機していたため、タイムアウトが発生していました。

于 2012-10-20T16:51:22.427 に答える