#node.js #jestjs #ts-jest
Вопрос:
У меня есть функция, которая использует соединение с mysql для выполнения запроса, и я пытаюсь модульно протестировать эту функцию, для этого мне нужно имитировать mysql. Однако, когда я использую функцию jest.mock, чтобы имитировать соединение с mysql, она возвращает следующую ошибку.
Не удается найти модуль «MySQLReplica» из «src/api/таблица лидеров/ранги/популярность.test.ts»
популярность.тест.ts
import { MySQLReplica } from "@services/mysql.service";
import { IEntityLeaderboardQuery } from "./../leaderboard.interface";
import { PopularityRank } from "./popularity";
import { mocked } from "ts-jest/utils";
jest.mock("MySQLReplica");
describe("Leaderboard - Rank - Popularity", () => {
afterAll(() => {
MySQLReplica.end();
});
const mockedMySQLReplica = mocked(MySQLReplica, true);
it("should get popularity scores", async () => {
const query: IEntityLeaderboardQuery = {
top: "10",
entity_types: ["person"],
region: "Europe",
country: "Germany",
end_date: "2021-06-15",
start_date: "2021-06-01",
rank: "popularity",
};
const result = await PopularityRank(query);
console.log(result);
});
});
сервисы/mysql.service.ts
import mysql from "mysql2/promise";
import { Config } from "@config";
export const MySQLReplica = mysql.createPool({
host: Config.db.replica.host,
database: Config.db.replica.database,
user: Config.db.replica.username,
password: Config.db.replica.password,
waitForConnections: true,
connectionLimit: 500,
queueLimit: 0,
});
export const MySQLWrite = mysql.createPool({
host: Config.db.write.host,
database: Config.db.write.database,
user: Config.db.write.username,
password: Config.db.write.password,
waitForConnections: true,
connectionLimit: 100,
queueLimit: 0,
});
export const MySQLPreparedStatement = mysql.format;
Комментарии:
1. Чтобы создать макет модуля, вы должны передать путь к модулю. Попробуйте заменить
jest.mock("MySQLReplica");
наjest.mock("@services/mysql.service");