javascript - TypeError : Method Promise.原型(prototype)。然后在不兼容的接收器代理上调用

标签 javascript testing jasmine integration-testing puppeteer

为了执行集成测试,我使用了 jasminepuppeteer并且由于我正在通过教育类(class),因此,我决定使用 js 代理来封装测试功能,但是当我进行测试时,我会遇到以下错误

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,但我找不到任何解决方案。

最佳答案

为了后代,我发现使用代理你需要重新绑定(bind) 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'

关于javascript - TypeError : Method Promise.原型(prototype)。然后在不兼容的接收器代理上调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53872760/

相关文章:

svn - 使用暂存环境处理网络发布的最佳方式?

测试使用 Immutable.js 更改多个属性的 reducer

javascript - 自定义 Jasmine Matcher 中已解决和已拒绝的 promise

angular - 在 Angular 项目中使用 Jasmine 进行单元测试订阅方法

javascript - Jasmine测试私有(private)回调函数

javascript - 获取天气预报数据以加载到 amcharts 数据加载器中

javascript - 制作一个简单的实时图表

Bash 流量控制问题

javascript - 为什么 setTimeout 在 Chrome 中会触发两次,而在 IE 或 Firefox 中却不会?

java - 如何在将光标放在 HTML 元素上时获取其属性?