Заглушка асинхронной функции в sinon вызывает фактический вызов функции - PullRequest
0 голосов
/ 23 февраля 2019

У меня есть асинхронная функция, когда я запускаю модульное тестирование с mocha, я вижу, что это не заглушка.

// User.js

class User {
  async _getUser(client, email) {
    let result = await new userApi().getUser(new UserInfo(email, email));
    console.log("Get result " + JSON.stringify(result));
    let user = result.users[0];

    console.log("Get User " + JSON.stringify(user));
    return user;
  }
}
module.exports = User;


// Usertest.js

const chai = require("chai");
const sinon = require("sinon");
var chaiAsPromised = require("chai-as-promised");
chai.use(chaiAsPromised).should();
const expect = chai.expect;
const UserInfo = require("../src/model/userInfo");
const User = require("../src/model/user");

describe("Test LogInCommand", function() {
  let user, sandbox;

  beforeEach(() => {
    sandbox = sinon.sandbox.create();
    user = new user();
  });

  afterEach(function afterEach() {
    sandbox.restore();
  });

  it("getUser function", function(done) {
    let User = new UserInfo("email", "email", "station");
    sandbox
      .stub(userApi, "getUser")
      .withArgs(User)
      .returns(
        Promise.resolve({
          users: [
            {
              id: 1
            }
          ]
        })
      );
    sandbox.stub(logger, "info");
    let result = logInCommand._getUser(client, "email", "stationid");
    done();
  });
});

1 Ответ

0 голосов
/ 27 февраля 2019

Я предполагаю, что userApi является классом, поэтому, чтобы заглушить его, мы должны сделать, как показано ниже:

sandbox.stub(userApi.prototype, "getUser").withArgs(User)...

, мы должны добавить prototype, чтобы заглушить метод класса.

Я также нахожу что-то, чтобы исправить в вашем тесте, потому что вы не рассматриваете logInCommand._getUser как асинхронный вызов.Итак, вот код после обновления.

it("getUser function", async function() { // remove `done` and let's use async/await here
  let User = new UserInfo("email", "email", "station");
  sandbox
    .stub(userApi.prototype, "getUser") // add prototype
    .withArgs(User)
    .resolves({ // in new sinon, they have `resolves` method
        users: [
          {
            id: 1
          }
        ]
      });    
  sandbox.stub(logger, "info");
  let result = await logInCommand._getUser(client, "email", "stationid"); // add await because this method is async
  // remove done()
});

Надеюсь, это поможет

...