茉莉花节点期望未执行

Jasmine-node expect not executed

我今天开始使用 Jasmine 进行测试,这对我来说是新的。由于我使用的是使用 NodeJS 开发的 GraphQL 服务器,因此我使用的是 jasmine-node.

以下是我自己编写的第一个规范,我认为它有效:

const request = require('request');
const config = require('../sources/config');

const base_url = `http://localhost:${config.graphqlPort}/${config.graphqlRoute}`;

describe("GraphQLServer.", () => {
it("Should expect something.", () => {
    expect(1).not.toEqual(2);
    expect(1).toEqual(1);
    expect(true).toBe(true);
    expect(false).not.toBe(true);
});

describe('When request is made.', () => {
    it('Returns statuscode 200.', () => {
        request.get(base_url, (error, response, body) => {
            console.log('Error: ', error);
            console.log(base_url);
            console.log('StatusCode: ', response && response.statusCode);
            console.log('Body:', body);
            expect(true).toBe(true);
            expect(true).toBe(false);
            expect(response.statusCode).toBe(200);
            expect(response.statusCode).toBe(400);
            done();
            });
        });
    });
});

结果如下:

    ..

Finished in 0.018 seconds
2 tests, 4 assertions, 0 failures, 0 skipped


Error:  null
http://localhost:8000/graphql
StatusCode:  400
Body: {"errors":[{"message":"Must provide query string."}]}

很多这正是我所期望的。我做了一个没有查询字符串的请求,所以正文中的错误是预料之中的。

问题是:it("Should expect something") 中的 4 个无用(明显)expects 工作正常。这些是结果中的 4 assertionsit("Returns statuscode 200.") 内的其他 4 个 expect 根本不在结果中(它们没有失败,也没有通过),但 console.log 是。

我在网上找到的每个示例似乎都与我在这里所做的完全一样,但我无法让它发挥作用。

我忘记了 Jasmine 中建议修复的确切语法,但我相信我知道答案:这是使用 promises 进行测试的经典案例。结果会在测试完成后返回,因此您的 expect 调用不会再影响测试的上下文中发生。

我注意到你的代码和 jasmine-node 文档之间的一个区别是传递给 it 的函数应该将 done 作为参数,但是你有 () => (done) => 个。这可能会导致您看到的行为。

Kev 是对的,但 Jasmine 中的语法涉及在异步执行完成后将 expect 语句放入 promise 结果中。它看起来像这样:

it ("should do a thing with promises", function(done) {
            myObject.doAThingWithPromises('')
                .then(function (promiseResult) {
                    expect(promiseResult).toBeDefined();
                    done();
                })
        });