Merge branch 'prettyPrintCustomConstructortoString' of https://github.com/mbildner/jasmine into mbildner-prettyPrintCustomConstructortoString

- Fixes #1019
- Merges #1099
This commit is contained in:
Gregg Van Hove
2016-08-15 15:50:21 -07:00
3 changed files with 32 additions and 2 deletions

View File

@@ -156,7 +156,12 @@ getJasmineRequireObj().base = function(j$, jasmineGlobal) {
};
j$.fnNameFor = function(func) {
return func.name || func.toString().match(/^\s*function\s*(\w*)\s*\(/)[1];
if (func.name) {
return func.name;
}
var matches = func.toString().match(/^\s*function\s*(\w*)\s*\(/);
return matches ? matches[1] : '<anonymous>';
};
j$.any = function(clazz) {

View File

@@ -189,6 +189,26 @@ describe("jasmineUnderTest.pp", function () {
expect(jasmineUnderTest.pp(obj)).toEqual("my toString");
});
it("should stringify objects from named constructors with custom toString", function () {
var MyNamedConstructor = function MyNamedConstructor () {};
MyNamedConstructor.toString = function () { return ""; };
var a = {};
a.constructor = MyNamedConstructor;
expect(jasmineUnderTest.pp(a)).toEqual("MyNamedConstructor({ constructor: Function })");
});
it("should stringify objects from anonymous constructors with custom toString", function () {
var MyAnonymousConstructor = function () {};
MyAnonymousConstructor.toString = function () { return ""; };
var a = {};
a.constructor = MyAnonymousConstructor;
expect(jasmineUnderTest.pp(a)).toEqual("<anonymous>({ constructor: Function })");
});
it("should handle objects with null prototype", function() {
if (jasmine.getEnv().ieVersion < 9) { return; }

View File

@@ -38,7 +38,12 @@ getJasmineRequireObj().base = function(j$, jasmineGlobal) {
};
j$.fnNameFor = function(func) {
return func.name || func.toString().match(/^\s*function\s*(\w*)\s*\(/)[1];
if (func.name) {
return func.name;
}
var matches = func.toString().match(/^\s*function\s*(\w*)\s*\(/);
return matches ? matches[1] : '<anonymous>';
};
j$.any = function(clazz) {