Javascript 茉莉花链试验

Javascript 茉莉花链试验,javascript,node.js,jasmine,integration-testing,Javascript,Node.js,Jasmine,Integration Testing,我用Jasmine来测试我的项目。我使用它进行集成测试,而不是单元测试 describe("admin", function () { var testUser = { name: 'test', pass: 'pass' }; it("should be able to create a new user", function(done) { needle.post(server + "addUser.php", t

我用Jasmine来测试我的项目。我使用它进行集成测试,而不是单元测试

describe("admin", function () {

    var testUser =  {
        name: 'test',
        pass: 'pass'
    };

    it("should be able to create a new user", function(done) {
        needle.post(server + "addUser.php", testUser, function (err, res) {
            expect(res.statusCode).toBe(200);
            done();
        });  
    });

    it("should be able to delete the user", function(done) {
        needle.post(server + "deletedUser.php", testUser, function (err, res) {
            expect(res.statusCode).toBe(200);
            done();
        });  
    });


});

如何确保删除测试在添加测试之后运行?

好的,答案可能很简单:Jasmine按照测试的外观顺序运行测试,即使是异步测试

为了测试这一点,我尝试了:

it("A", function (done) {
    console.log("A");
    setTimeout(done, 4000); 
});

it("B", function (done) {
    console.log("B");
    setTimeout(done, 20);
});

it("C", function () { 
    console.log("C");
});

输出是ABC,test
B
在调用test
A
中的
done
之前不会启动。

对于任何可能偶然发现这一点的人:使用稍大的测试集表明顺序没有保证(因为jasmine 2.3.0):

跟踪更新(如果有)


更新:这是一个bug,已通过v2.3.4修复。所有测试现在都应该排序。

也许这很愚蠢,但为什么不使用一个小助手方法来创建一个用户实例并在删除测试中运行它呢?我在测试套件方面的经验并不能保证顺序,但谷歌搜索并没有说明jasmine是否这样做。我认为jasmine支持这一点,但我不知道具体是如何做到的。
it('a', function (done) { console.log('a'); setTimeout(done, 100); });
it('b', function (done) { console.log('b'); setTimeout(done, 100); });
it('c', function (done) { console.log('c'); setTimeout(done, 100); });
it('d', function (done) { console.log('d'); setTimeout(done, 100); });
it('e', function (done) { console.log('e'); setTimeout(done, 100); });
it('f', function (done) { console.log('f'); setTimeout(done, 100); });
it('g', function (done) { console.log('g'); setTimeout(done, 100); });
it('h', function (done) { console.log('h'); setTimeout(done, 100); });
it('i', function (done) { console.log('i'); setTimeout(done, 100); });
it('j', function (done) { console.log('j'); setTimeout(done, 100); });
it('k', function (done) { console.log('k'); setTimeout(done, 100); });
it('l', function (done) { console.log('l'); setTimeout(done, 100); });
it('m', function (done) { console.log('m'); setTimeout(done, 100); });
it('n', function (done) { console.log('n'); setTimeout(done, 100); });
it('o', function (done) { console.log('o'); setTimeout(done, 100); });
it('p', function (done) { console.log('p'); setTimeout(done, 100); });
it('q', function (done) { console.log('q'); setTimeout(done, 100); });
it('r', function (done) { console.log('r'); setTimeout(done, 100); });
it('s', function (done) { console.log('s'); setTimeout(done, 100); });
it('t', function (done) { console.log('t'); setTimeout(done, 100); });
it('u', function (done) { console.log('u'); setTimeout(done, 100); });
it('v', function (done) { console.log('v'); setTimeout(done, 100); });
it('w', function (done) { console.log('w'); setTimeout(done, 100); });
it('x', function (done) { console.log('x'); setTimeout(done, 100); });
it('y', function (done) { console.log('y'); setTimeout(done, 100); });
it('z', function (done) { console.log('z'); setTimeout(done, 100); });

// 2.1.0: a b c d e f g h i l k l m n o p q r s t u v w x y z
// 2.2.0: a b c d e f g h i l k l m n o p q r s t u v w x y z
// 2.3.0: a z c d e f g h i j k l m b o p q r s t u v w x y n
// 2.3.1: a z c d e f g h i j k l m b o p q r s t u v w x y n