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

时间:2018-12-20 16:40:27

标签: javascript testing jasmine integration-testing puppeteer

执行集成测试时,我使用了jasminepuppeteer,由于我通过了一个教育课程,因此,我决定使用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,但是我找不到任何解决方案。

1 个答案:

答案 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'