TypeError:方法Promise.Prototype.Then在不兼容的接收方代理上调用

为了执行集成测试,我使用了jasminepuppeteer,由于我正在通过一门教育课程,因此我决定使用js代理来封装测试功能,但在进行测试时会遇到以下错误

TypeError: Method Promise.prototype.then called on incompatible receiver [object Object] 
下面是我的CustomPage类,它将表示一个Chrome选项卡: const puppeteer=REQUIRED(‘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不能将代理视为承诺,但我找不到任何解决方案。

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'

相关文章