小编Kis*_*iss的帖子

如何使用Jest测试网址更改

我有以下功能要测试

function tradePage() {
  setTimeout(function() {
    window.location.pathname = document
      .getElementById('button')
      .getAttribute('new-page');
  }, 100);
}
Run Code Online (Sandbox Code Playgroud)

而且我编写了以下测试:

test('should change page when button is clicked', () => {
  var button = document.querySelector('#button');

  jest.useFakeTimers();
  button.dispatchEvent(createEvent('click'));
  jest.runAllTimers();

  expect(window.location.pathname).toEqual('/new-url');
});
Run Code Online (Sandbox Code Playgroud)

但是,当我运行测试时,出现以下错误:

    expect(received).toEqual
    Expected value to equal:
    "/new-url"
    Received:
    "blank"
Run Code Online (Sandbox Code Playgroud)

我已经完成/尝试过的事情

  • 我的packages.json已经"testURL"设置好了。
  • 我发现了这个可能的解决方案(不起作用):

    Object.defineProperty(window.location, 'pathname', {
      writable: true,
      value: '/page/myExample/test',
    });
    
    Run Code Online (Sandbox Code Playgroud)

还有什么我可以尝试的想法吗?

javascript unit-testing jestjs

6
推荐指数
2
解决办法
6480
查看次数

标签 统计

javascript ×1

jestjs ×1

unit-testing ×1