我有以下JavaScript类包装document.evaluate()
,使用XPath选择DOM元素:
'use strict'
Object.defineProperty(exports, '__esModule', { value: true })
class ElementByXPath {
constructor(elementXPath) {
this.elementXPath = elementXPath
}
element(document) {
return document.evaluate(
this.elementXPath,
document.documentElement,
null,
XPathResult.FIRST_ORDERED_NODE_TYPE,
null,
).singleNodeValue
}
}
exports.ElementByXPath = ElementByXPath
用mocha
编写的以下测试应验证方法element()
:
describe('ElementByXPath function test', () => {
it('should return element of given XPath', () => {
const dom = new JSDOM(`<p id = "test-id"/p>`)
const result = new ElementByXpath('//*[@id="test-id"]').element(
dom.window.document,
)
expect(result.tagName).to.equal('P')
})
})
使用JSDOM,我可以模拟window
元素。不幸的是,我无法嘲笑XPathResult
:
ReferenceError: XPathResult is not defined
有人暗示吗?谢谢。
答案 0 :(得分:1)
在jsdom-global
旁边添加jsdom
(描述为here):
npm i -D jsdom jsdom-global
在jsdom-global
执行测试时注册mocha
mocha -r jsdom-global/register test/**/*.test.js