执行集成测试时,我使用了jasmine
和puppeteer
,由于我通过了一个教育课程,因此,我决定使用js Proxy封装测试功能,但是当我进行测试时我将遇到以下错误
TypeError: Method Promise.prototype.then called on incompatible receiver [object Object]
这是我的CustomPage类,它将代表chrome标签: const puppeteer = require('puppeteer');
class CustomPage{
static async build(){
const browser =await puppeteer.launch({headless:false});
const page = browser.newPage();
var customPage = new CustomPage(page);
console.log("harchi run mishe")
return new Proxy(customPage,{
get:function(target,property){
return (customPage[property]||page[property]||browser[property])
}
})
//return proxy;
}
constructor(page){
this.page = page
}
}
module.exports=CustomPage;
这是我的header.spec.js
文件,这是我的测试文件。
const Page = require('./helpers/page');
var tab;
describe('header representation',()=>{
beforeEach(async(done)=>{
tab =await Page.build();****here is the problem********
await tab.goto('localhost:3000');
})
it('should show header logo',async()=>{
const text = await tab.$eval('a.brand-logo',(el)=>el.innerHTML);
expect(text).toEqual('Blogster');
//done()
})
})
我实际上已经确定我的问题与指定的行有关。看来js不能将代理视为Promise,但是我找不到任何解决方案。
答案 0 :(得分:1)
为了后代,我发现使用代理服务器需要重新绑定javascript的this
关键字。示例:
function validator(promise, prop) {
if (prop in promise || promise.hasOwnProperty(prop)) {
if (typeof promise[prop] === 'function') {
return promise[prop].bind(promise); // << Important part!
}
return promise[prop];
}
return 'Fake!';
}
const proxy = new Proxy(
Promise.resolve('Testing 1 2 3'),
validator
);
console.log(proxy.someFakeThing); // prints 'Fake!'
proxy.then(console.log); // Prints 'Testing 1 2 3'