Mas*_*ini 5 javascript testing integration-testing jasmine puppeteer
为了执行我使用的集成测试jasmine,并且puppeteer由于我正在通过教育课程,因此,我决定使用 js 代理来封装测试功能,但是当我进行测试时,我会遇到以下错误
TypeError: Method Promise.prototype.then called on incompatible receiver [object Object]
Run Code Online (Sandbox Code Playgroud)
这是我的 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;
Run Code Online (Sandbox Code Playgroud)
这是我的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()
})
})
Run Code Online (Sandbox Code Playgroud)
我实际上已经确信我的问题出在指定的行上。似乎js不能将代理视为Promise,但是我找不到任何解决方案。
小智 4
为了后代,我发现使用代理你需要重新绑定 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'
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2696 次 |
| 最近记录: |