TypeError: не удается прочитать "знак" свойства неопределенного [JWT / Nestjs / e2e-тесты]
Мне нужно создать токен на предъявителя Jwt для моих тестов e2e. Поскольку этот процесс немного утомителен, и поскольку это не то, что я пытаюсь тестировать, я хотел бы обойти его, получая напрямую, а не проходя реальный процесс 2FA.
К сожалению, я получаю следующую ошибку:
TypeError: Cannot read property 'sign' of undefined
150 |
151 | function getBearerToken(candidateId: number) {
> 152 | return jwtService.sign({ sub: candidateId.toString() })
| ^
153 | }
154 | })
155 | })
at getBearerToken (app.e2e-spec.ts:152:25)
at Object.<anonymous> (app.e2e-spec.ts:127:21)
describe('Bookmarks Module', () => {
let bearerToken: string
let jwtService: JwtService
beforeEach(() => {
bearerToken = getBearerToken(1)
jwtService = new JwtService({
secret: process.env.JWT_SECRET,
signOptions: { expiresIn: '1h' },
})
})
test('/v1/bookmarks/ (GET) [auth]', () => {
return expectCorrectAuthenticatedGetResponse(
`${V1_PREFIX}/bookmarks/`,
bearerToken
)
})
test('/v1/bookmarks/{id} (POST) [auth]', () => {
const DATA = { offerId: 19 }
return expectCorrectAuthenticatedPostResponse(
`${V1_PREFIX}/bookmarks/${DATA.offerId}`,
DATA,
bearerToken
)
})
function getBearerToken(candidateId: number) {
return jwtService.sign({ sub: candidateId.toString() })
}
})
3 ответа
Ты звонишь
jwtService.sign()
в
getBearerToken()
который сам называется в
beforeEach()
, как раз перед
jwtService
инициализируется. Так
jwtService
все еще
undefined
когда пытаешься его использовать. Вы должны инвертировать линии в
beforeEach()
:
beforeEach(() => {
jwtService = new JwtService({
secret: process.env.JWT_SECRET,
signOptions: { expiresIn: '1h' },
})
bearerToken = getBearerToken(1)
})
Я столкнулся с той же проблемой при импортеjwt
нравиться:
import { jwt } from "jsonwebtoken";
Поэтому я изменил его на:
var jwt = require('jsonwebtoken');
или
import jwt from "jsonwebtoken";
и это сработало
Я не знаю, почему это сработало.
Для меня это был другой вопрос. [узел v18]
изменил это:import jwt from 'jsonwebtoken'
к этому:import * as jwt from 'jsonwebtoken'
или каждое отдельное свойство:import {sign, verify, JwtPayload} from "jsonwebtoken";
и снова в деле.