включает библиотеку локализации, и у меня есть объект даты в моем компоненте, который выглядит следующим образом:
getDate = () => {
const { t } = this.props;
return new Date().toLocaleString(t('locale.name'), {
weekday: "long",
month: "long",
day: "numeric",
});
};
Когда я пытаюсь запустить тест, я получаю ошибку:
RangeError: Invalid language tag: language.name at Date.toLocaleString ()
15 | getDate = () => {
16 | const { t } = this.props;
> 17 | return new Date().toLocaleString(t('language.name'), {
| ^
18 | weekday: "long",
19 | month: "long",
20 | day: "numeric",
Таким образом, он не распознает локаль i18n. Связано ли это с тем, как я издеваюсь над i18n?
Моя текущая настройка:
Reaction-i18next.ts:
jest.mock('i18next', () => ({
use: () => {
return {
init: () => { }
};
},
t: k => k
}));
Мой jest.config:
module.exports = {
verbose: true,
roots: ["<rootDir>"],
testRegex: "/__tests__/.*\\.(test|spec)\\.tsx?",
transform: {
"^.+\\.tsx?$": "ts-jest",
},
moduleNameMapper: {
"react-i18next": "<rootDir>/__tests__/__mock__/react-i18next.ts"
},
};
i18n.ts
import i18n from "i18next";
import {initReactI18next} from "react-i18next";
import english from "./locales/en/common.json";
import french from "./locales/fr/common.json";
i18n.use(initReactI18next).init({
lng: 'en',
resources: {
fr: {
translation: french,
},
en: {
translation: english,
},
},
interpolation: {
escapeValue: false,
},
fallbackLng: ["en"]
});
export default i18n;