rtfeldman/seamless-immutable

Incorrectly identifying promises

Open

#208 建立於 2017年3月18日

在 GitHub 查看
 (6 留言) (0 反應) (0 負責人)JavaScript (5,367 star) (221 fork)batch import
bughelp wanted

描述

I've encountered an issue in the latest (7.1.0) release relating to commit 492d53e705acb6c

The issue is that isPromise makes a huge assumption that any object with a then method is a Promise. If the object is not a Promise, then will be called which may not be desirable.

This can be demonstrated very simply

Immutable({then:function() { console.log("should not be called") }});

I encountered this when using superagent which provides a thenable interface but is not technically a Promise. I suspect there may well be other libraries with a similar approach.

貢獻者指南