[英]How to mock navigator.language for typescript unit test
如何模拟要在单元测试中定义的navigator.language?
下面的代码返回
ReferenceError:导航器未定义
语言service.ts
import { injectable } from "inversify";
@injectable()
export class LanguageService {
public getBrowserLanguage(): string {
return navigator.language.split("-")[0];
}
}
语言service.spec.ts
// import stuff
describe('Language Service tests', () => {
it('should return de', () => {
const language_service = new LanguageService();
expect(language_service.getBrowserLanguage()).to.equal("de");
});
});
这听起来像是一项基本任务,但实际上却不是,因为即使我尝试在window对象上手动定义导航器,打字稿也会引发错误,指出导航器是只读的。
1-安装jsdom软件包
npm install jsdom jsdom-global --save-dev
2-相应地更改单元测试
{
"scripts": {
"test": "mocha -r ts-node/register -r jsdom-global/register src/**/*.spec.ts"
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.