Не удается смоделировать метод проверки подлинности паспорта ("локальный") с помощью sinon

Я пытаюсь издеваться над passport.authenticate('local'):

 app.post('/login', passport.authenticate('local'), (req, res, next) => {console.log('should enter');})

Я использую Sinon, но метод не выполняет console.log внутри маршрута входа

beforeEach(function (done) {
      aut = sinon.stub(server.passport, 'authenticate').returns(() => {});
      server.app.on('appStarted', function () {
        done();
      });
    });

afterEach(() => {
  aut.restore();
});

describe('Login', () => {
  it('should login', (done) => {
    chai.request(server.app)
      .post('/login')
      .send({
        username: 'user',
        password: 'pas'
      })
      .end(function (error, response, body) {
        return done();
      });
  });
});

Кроме того, когда я помещаю макет в настоящий passport.authenticate ('local') следующим образом:

app.post('/login', () => {}, (req, res, next) => {console.log('should enter');})

Он по-прежнему не входит в маршрут, что означает, что sinon callFake не поможет вообще. Только если я удалю

passport.authenticate ('местный')

из маршрута /login будет проходить тест "следует войти".

Реализовать sinon в beforeEach

let server = require('../../../app.js');
let expect = chai.expect;
chai.use(chaiHttp);

var aut;
beforeEach(() => {
  aut = sinon.stub(server.passport, 'authenticate').returns((req, res, next) => next());
});

app.js

const app = express();

middleware.initMiddleware(app, passport);

const dbName = 'dbname';
const connectionString = 'connect string';

mongo.mongoConnect(connectionString).then(() => {
        console.log('Database connection successful');
        app.listen(5000, () => console.log('Server started on port 5000'));
    })
    .catch(err => {
        console.error('App starting error:', err.stack);
        process.exit(1);
    });

// If the Node process ends, close the Mongoose connection
process.on('SIGINT', mongo.mongoDisconnect).on('SIGTERM', mongo.mongoDisconnect);

register.initnulth(app);

login.initfirst(app, passport);
logout.initsecond(app);


module.exports = app;

1 ответ

Решение

Кажется, вы хотите использовать обратный вызов промежуточного программного обеспечения, который ничего не делает, а просто позволяет обрабатывать запрос последующим промежуточным программным обеспечением. Такой обратный вызов будет:

(req, res, next) => next()

Промежуточное программное обеспечение должно позвонить next() для запроса продолжают обрабатываться более поздними промежуточными программами. Поэтому вы должны настроить свою заглушку следующим образом:

aut = sinon.stub(server.passport, 'authenticate').returns((req, res, next) => next());
Другие вопросы по тегам