赛普拉斯:如何在“cy.intercept”中等待“cy.task”

时间:2021-03-16 13:55:57

标签: cypress

我有一种情况,我想在拦截中生成 JWT 令牌并将其返回到它的主体中。 问题在于,在该令牌的有效载荷中,应该使用另一个拦截的值。 这意味着我只能在拦截期间生成令牌。

const code = '1234567890ABCDEFGH';
let accessTokenSource, idTokenSource, accessToken, idToken;
cy.fixture('access.token.json').then((source) => (accessTokenSource = source));
cy.fixture('id.token.json').then((source) => (idTokenSource = source));    
cy.intercept('https://****/authorize', (req) => {
  const url = new URL(req.url);

  idTokenSource.claims.nonce = url.searchParams.get('nonce');

  req.redirect(`${Cypress.config().baseUrl}?code=${code}&state=${url.searchParams.get('state')}`);
});    
cy.intercept('https://****/oauth/token', (req) => {
  cy.task('generateToken', accessTokenSource).then((token) => (accessToken = token));
  cy.task('generateToken', idTokenSource).then((token) => (idToken = token));

  console.log('accessToken', accessToken);
  console.log('idToken', idToken);

  req.reply({
    body: {
      access_token: accessToken,
      expires_in: 86400,
      id_token: idToken,
      scope: 'openid profile email',
      token_type: 'Bearer',
    },
    headers: {
      'content-type': 'application/json',
    },
  });
});

您可能已经想到,accessTokenidToken 是空的。

我应该在这里更改什么以等到 generateToken 任务完成才能在 req.reply 中使用它?

附言我已经试过了,但它不起作用:

cy.task('generateToken', accessTokenSource).as('generateAccessToken');
cy.task('generateToken', idTokenSource).as('generateIdToken');

cy.wait('@generateAccessToken').then((token) => (accessToken = token));
cy.wait('@generateIdToken').then((token) => (idToken = token));

console.log('accessToken', accessToken);
console.log('idToken', idToken);

ps2。当我将它放入测试的 generateToken 时,it() 工作得很好。

1 个答案:

答案 0 :(得分:0)

我已经创建了一个解决方法,不再使用插件而是直接执行签名功能。

在 cypress 测试文件之上:

import jwt from 'jsonwebtoken';

const generateToken = function (privateKey, options) {
  return jwt.sign(options.claims, privateKey, { algorithm: 'RS256', expiresIn: options.expires, issuer: options.issuer });
};

测试开始:

let authCode, privateKey, accessTokenSource, idTokenSource, accessToken, idToken;

authCode = Cypress.env('authCode');
cy.readFile(Cypress.env('jwtPrivateKey')).then((key) => (privateKey = key));
cy.fixture('access.token.json').then((source) => (accessTokenSource = source));
cy.fixture('id.token.json').then((source) => (idTokenSource = source));

拦截:

cy.intercept('https://***/oauth/token', (req) => {
  const params = new URLSearchParams(req.body);
  expect(params.get('code')).to.equal(authCode);

  accessToken = generateToken(privateKey, accessTokenSource);
  idToken = generateToken(privateKey, idTokenSource);

  req.reply({
    body: {
      access_token: accessToken,
      expires_in: 86400,
      id_token: idToken,
      scope: 'openid profile email',
      token_type: 'Bearer',
    },
    headers: {
      'content-type': 'application/json',
    },
  });
});