我有一种情况,我想在拦截中生成 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',
},
});
});
您可能已经想到,accessToken
和 idToken
是空的。
我应该在这里更改什么以等到 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()
工作得很好。
答案 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',
},
});
});