IE7 fixes
This commit is contained in:
parent
1b1c2b1998
commit
85d3b2d14b
@ -28,7 +28,8 @@ describe("jasmine.pp", function () {
|
|||||||
it("should stringify objects properly", function() {
|
it("should stringify objects properly", function() {
|
||||||
expect(jasmine.pp({foo: 'bar'})).toEqual("{ foo : 'bar' }");
|
expect(jasmine.pp({foo: 'bar'})).toEqual("{ foo : 'bar' }");
|
||||||
expect(jasmine.pp({foo:'bar', baz:3, nullValue: null, undefinedValue: undefined})).toEqual("{ foo : 'bar', baz : 3, nullValue : null, undefinedValue : undefined }");
|
expect(jasmine.pp({foo:'bar', baz:3, nullValue: null, undefinedValue: undefined})).toEqual("{ foo : 'bar', baz : 3, nullValue : null, undefinedValue : undefined }");
|
||||||
expect(jasmine.pp({foo: function () { }, bar: [1, 2, 3]})).toEqual("{ foo : Function, bar : [ 1, 2, 3 ] }");
|
expect(jasmine.pp({foo: function () {
|
||||||
|
}, bar: [1, 2, 3]})).toEqual("{ foo : Function, bar : [ 1, 2, 3 ] }");
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should indicate circular object references", function() {
|
it("should indicate circular object references", function() {
|
||||||
@ -39,8 +40,18 @@ describe("jasmine.pp", function () {
|
|||||||
|
|
||||||
it("should indicate getters on objects as such", function() {
|
it("should indicate getters on objects as such", function() {
|
||||||
var sampleValue = {id: 1};
|
var sampleValue = {id: 1};
|
||||||
sampleValue.__defineGetter__('calculatedValue', function() { throw new Error("don't call me!"); });
|
if (sampleValue.__defineGetter__) {
|
||||||
expect(jasmine.pp(sampleValue)).toEqual("{ id : 1, calculatedValue : <getter> }");
|
//not supported in IE!
|
||||||
|
sampleValue.__defineGetter__('calculatedValue', function() {
|
||||||
|
throw new Error("don't call me!");
|
||||||
|
});
|
||||||
|
}
|
||||||
|
if (sampleValue.__defineGetter__) {
|
||||||
|
expect(jasmine.pp(sampleValue)).toEqual("{ id : 1, calculatedValue : <getter> }");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
expect(jasmine.pp(sampleValue)).toEqual("{ id : 1 }");
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should stringify HTML nodes properly", function() {
|
it("should stringify HTML nodes properly", function() {
|
||||||
|
@ -56,7 +56,7 @@ jasmine.PrettyPrinter.prototype.format = function(value) {
|
|||||||
jasmine.PrettyPrinter.prototype.iterateObject = function(obj, fn) {
|
jasmine.PrettyPrinter.prototype.iterateObject = function(obj, fn) {
|
||||||
for (var property in obj) {
|
for (var property in obj) {
|
||||||
if (property == '__Jasmine_been_here_before__') continue;
|
if (property == '__Jasmine_been_here_before__') continue;
|
||||||
fn(property, obj.__lookupGetter__(property) != null);
|
fn(property, obj.__lookupGetter__ ? (obj.__lookupGetter__(property) != null) : false);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
36
src/base.js
36
src/base.js
@ -1,6 +1,6 @@
|
|||||||
/**
|
/**
|
||||||
* Top level namespace for Jasmine, a lightweight JavaScript BDD/spec/testing framework.
|
* Top level namespace for Jasmine, a lightweight JavaScript BDD/spec/testing framework.
|
||||||
*
|
*
|
||||||
* @namespace
|
* @namespace
|
||||||
*/
|
*/
|
||||||
var jasmine = {};
|
var jasmine = {};
|
||||||
@ -14,7 +14,7 @@ jasmine.unimplementedMethod_ = function() {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Large or small values here may result in slow test running & "Too much recursion" errors
|
* Large or small values here may result in slow test running & "Too much recursion" errors
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
jasmine.UPDATE_INTERVAL = 250;
|
jasmine.UPDATE_INTERVAL = 250;
|
||||||
|
|
||||||
@ -29,7 +29,14 @@ jasmine.UPDATE_INTERVAL = 250;
|
|||||||
jasmine.bindOriginal_ = function(base, name) {
|
jasmine.bindOriginal_ = function(base, name) {
|
||||||
var original = base[name];
|
var original = base[name];
|
||||||
return function() {
|
return function() {
|
||||||
return original.apply(base, arguments);
|
if (original.apply) {
|
||||||
|
return original.apply(base, arguments);
|
||||||
|
} else {
|
||||||
|
//IE support
|
||||||
|
if (base == window) {
|
||||||
|
return window[name].apply(window, arguments);
|
||||||
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -71,10 +78,10 @@ jasmine.getEnv = function() {
|
|||||||
*/
|
*/
|
||||||
jasmine.isArray_ = function(value) {
|
jasmine.isArray_ = function(value) {
|
||||||
return value &&
|
return value &&
|
||||||
typeof value === 'object' &&
|
typeof value === 'object' &&
|
||||||
typeof value.length === 'number' &&
|
typeof value.length === 'number' &&
|
||||||
typeof value.splice === 'function' &&
|
typeof value.splice === 'function' &&
|
||||||
!(value.propertyIsEnumerable('length'));
|
!(value.propertyIsEnumerable('length'));
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -123,7 +130,7 @@ jasmine.any = function(clazz) {
|
|||||||
* Spies are torn down at the end of every spec.
|
* Spies are torn down at the end of every spec.
|
||||||
*
|
*
|
||||||
* Note: Do <b>not</b> call new jasmine.Spy() directly - a spy must be created using spyOn, jasmine.createSpy or jasmine.createSpyObj.
|
* Note: Do <b>not</b> call new jasmine.Spy() directly - a spy must be created using spyOn, jasmine.createSpy or jasmine.createSpyObj.
|
||||||
*
|
*
|
||||||
* @example
|
* @example
|
||||||
* // a stub
|
* // a stub
|
||||||
* var myStub = jasmine.createSpy('myStub'); // can be used anywhere
|
* var myStub = jasmine.createSpy('myStub'); // can be used anywhere
|
||||||
@ -168,7 +175,8 @@ jasmine.Spy = function(name) {
|
|||||||
/**
|
/**
|
||||||
* The acutal function this spy stubs.
|
* The acutal function this spy stubs.
|
||||||
*/
|
*/
|
||||||
this.plan = function() {};
|
this.plan = function() {
|
||||||
|
};
|
||||||
/**
|
/**
|
||||||
* Tracking of the most recent call to the spy.
|
* Tracking of the most recent call to the spy.
|
||||||
* @example
|
* @example
|
||||||
@ -199,7 +207,7 @@ jasmine.Spy = function(name) {
|
|||||||
* var foo = {
|
* var foo = {
|
||||||
* bar: function() { // do some stuff }
|
* bar: function() { // do some stuff }
|
||||||
* }
|
* }
|
||||||
*
|
*
|
||||||
* // defining a spy on an existing property: foo.bar
|
* // defining a spy on an existing property: foo.bar
|
||||||
* spyOn(foo, 'bar').andCallThrough();
|
* spyOn(foo, 'bar').andCallThrough();
|
||||||
*/
|
*/
|
||||||
@ -302,11 +310,11 @@ jasmine.createSpy = function(name) {
|
|||||||
};
|
};
|
||||||
|
|
||||||
var spy = new jasmine.Spy(name);
|
var spy = new jasmine.Spy(name);
|
||||||
|
|
||||||
for(var prop in spy) {
|
for (var prop in spy) {
|
||||||
spyObj[prop] = spy[prop];
|
spyObj[prop] = spy[prop];
|
||||||
}
|
}
|
||||||
|
|
||||||
spyObj.reset();
|
spyObj.reset();
|
||||||
|
|
||||||
return spyObj;
|
return spyObj;
|
||||||
@ -410,7 +418,7 @@ var waits = function(timeout) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Waits for the latchFunction to return true before proceeding to the next runs()-defined block.
|
* Waits for the latchFunction to return true before proceeding to the next runs()-defined block.
|
||||||
*
|
*
|
||||||
* @param {Number} timeout
|
* @param {Number} timeout
|
||||||
* @param {Function} latchFunction
|
* @param {Function} latchFunction
|
||||||
* @param {String} message
|
* @param {String} message
|
||||||
|
@ -134,25 +134,42 @@ jasmine.Clock = {
|
|||||||
if (jasmine.Clock.installed != jasmine.Clock.defaultFakeTimer) {
|
if (jasmine.Clock.installed != jasmine.Clock.defaultFakeTimer) {
|
||||||
throw new Error("Mock clock is not installed, use jasmine.Clock.useMock()");
|
throw new Error("Mock clock is not installed, use jasmine.Clock.useMock()");
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
installed: null
|
installed: null
|
||||||
};
|
};
|
||||||
jasmine.Clock.installed = jasmine.Clock.real;
|
jasmine.Clock.installed = jasmine.Clock.real;
|
||||||
|
|
||||||
|
//else for IE support
|
||||||
window.setTimeout = function(funcToCall, millis) {
|
window.setTimeout = function(funcToCall, millis) {
|
||||||
return jasmine.Clock.installed.setTimeout.apply(this, arguments);
|
if (jasmine.Clock.installed.setTimeout.apply) {
|
||||||
|
return jasmine.Clock.installed.setTimeout.apply(this, arguments);
|
||||||
|
} else {
|
||||||
|
return jasmine.Clock.installed.setTimeout(funcToCall, millis);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
window.setInterval = function(funcToCall, millis) {
|
window.setInterval = function(funcToCall, millis) {
|
||||||
return jasmine.Clock.installed.setInterval.apply(this, arguments);
|
if (jasmine.Clock.installed.setInterval.apply) {
|
||||||
|
return jasmine.Clock.installed.setInterval.apply(this, arguments);
|
||||||
|
} else {
|
||||||
|
return jasmine.Clock.installed.setInterval(funcToCall, millis);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
window.clearTimeout = function(timeoutKey) {
|
window.clearTimeout = function(timeoutKey) {
|
||||||
return jasmine.Clock.installed.clearTimeout.apply(this, arguments);
|
if (jasmine.Clock.installed.clearTimeout.apply) {
|
||||||
|
return jasmine.Clock.installed.clearTimeout.apply(this, arguments);
|
||||||
|
} else {
|
||||||
|
return jasmine.Clock.installed.clearTimeout(timeoutKey);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
window.clearInterval = function(timeoutKey) {
|
window.clearInterval = function(timeoutKey) {
|
||||||
return jasmine.Clock.installed.clearInterval.apply(this, arguments);
|
if (jasmine.Clock.installed.clearTimeout.apply) {
|
||||||
|
return jasmine.Clock.installed.clearInterval.apply(this, arguments);
|
||||||
|
} else {
|
||||||
|
return jasmine.Clock.installed.clearInterval(timeoutKey);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user