Pulls in updates to more recent Rhino.
This commit is contained in:
commit
3fef5237aa
|
@ -22,8 +22,8 @@ public class JasmineTestRunner extends Runner {
|
||||||
|
|
||||||
private JasmineDescriptions jasmineSuite;
|
private JasmineDescriptions jasmineSuite;
|
||||||
|
|
||||||
private final RhinoContext rhinoContext;
|
protected final RhinoContext rhinoContext;
|
||||||
private final JasmineSuite suiteAnnotation;
|
protected final JasmineSuite suiteAnnotation;
|
||||||
private final Class<?> testClass;
|
private final Class<?> testClass;
|
||||||
|
|
||||||
@JasmineSuite
|
@JasmineSuite
|
||||||
|
@ -48,6 +48,9 @@ public class JasmineTestRunner extends Runner {
|
||||||
|
|
||||||
private RhinoContext setUpRhinoScope() {
|
private RhinoContext setUpRhinoScope() {
|
||||||
RhinoContext context = new RhinoContext();
|
RhinoContext context = new RhinoContext();
|
||||||
|
|
||||||
|
pre(context);
|
||||||
|
|
||||||
context.loadEnv(suiteAnnotation.jsRootDir());
|
context.loadEnv(suiteAnnotation.jsRootDir());
|
||||||
setUpJasmine(context);
|
setUpJasmine(context);
|
||||||
|
|
||||||
|
@ -56,6 +59,9 @@ public class JasmineTestRunner extends Runner {
|
||||||
return context;
|
return context;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void pre(RhinoContext context) {
|
||||||
|
}
|
||||||
|
|
||||||
private void setUpJasmine(RhinoContext context) {
|
private void setUpJasmine(RhinoContext context) {
|
||||||
context.load(getJsLibDir() + "jasmine.js");
|
context.load(getJsLibDir() + "jasmine.js");
|
||||||
context.load(getJsLibDir() + "jasmine.delegator_reporter.js");
|
context.load(getJsLibDir() + "jasmine.delegator_reporter.js");
|
||||||
|
@ -138,9 +144,14 @@ public class JasmineTestRunner extends Runner {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
after();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void after() {
|
||||||
this.rhinoContext.exit();
|
this.rhinoContext.exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private Object createTestClassInstance() {
|
private Object createTestClassInstance() {
|
||||||
try {
|
try {
|
||||||
return testClass.newInstance();
|
return testClass.newInstance();
|
||||||
|
|
|
@ -54,10 +54,11 @@
|
||||||
/**
|
/**
|
||||||
* Envjs specific hacks
|
* Envjs specific hacks
|
||||||
* 1) Fix Envjs relative path system to work with Windows path systems
|
* 1) Fix Envjs relative path system to work with Windows path systems
|
||||||
* 2) Fix window.setTimeout() using Rhino specific functions
|
* 2) Fix CSS2Properties support for parsing style attributes: get from raw node context.
|
||||||
* 3) Fix CSS2Properties support for parsing style attributes: get from raw node context.
|
* 3) Fix CSS2Properties support for setting values: all properties have the same objmaps, wtf?
|
||||||
* 4) Fix CSS2Properties support for setting values: all properties have the same objmaps, wtf?
|
* 4) Fix focus() which sets document.activeElement correctly for jQuery:focus
|
||||||
*/
|
* 5) Fix Input click() behavior for checkboxes. Warning: jQ's click() <-> DOM's click (checked value too late set)!
|
||||||
|
**/
|
||||||
(function() {
|
(function() {
|
||||||
|
|
||||||
var oldEnvjsUriFn = Envjs.uri;
|
var oldEnvjsUriFn = Envjs.uri;
|
||||||
|
@ -68,13 +69,6 @@
|
||||||
return oldEnvjsUriFn(path, "file:///" + ("" + Envjs.getcwd()).replace(/\\/g, '/') + "/");
|
return oldEnvjsUriFn(path, "file:///" + ("" + Envjs.getcwd()).replace(/\\/g, '/') + "/");
|
||||||
};
|
};
|
||||||
|
|
||||||
window.setTimeout = function(closure, timeout) {
|
|
||||||
spawn(function() {
|
|
||||||
java.lang.Thread.sleep(timeout);
|
|
||||||
closure();
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
(function(Element) {
|
(function(Element) {
|
||||||
|
|
||||||
var style = "style";
|
var style = "style";
|
||||||
|
@ -98,6 +92,35 @@
|
||||||
|
|
||||||
})(HTMLElement.prototype);
|
})(HTMLElement.prototype);
|
||||||
|
|
||||||
|
(function(input) {
|
||||||
|
var oldClick = input.prototype.click;
|
||||||
|
input.prototype.click = function() {
|
||||||
|
if(this.type === "checkbox") {
|
||||||
|
this.checked = !this.checked;
|
||||||
|
}
|
||||||
|
oldClick.apply(this, arguments);
|
||||||
|
}
|
||||||
|
})(HTMLInputElement);
|
||||||
|
|
||||||
|
(function(Input, Textarea, document) {
|
||||||
|
var activeElement;
|
||||||
|
function fixFocusForPrototype(element) {
|
||||||
|
var originalFocus = element.prototype.focus;
|
||||||
|
element.prototype.focus = function(element) {
|
||||||
|
activeElement = this;
|
||||||
|
originalFocus.apply(this, arguments);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fixFocusForPrototype(Input);
|
||||||
|
fixFocusForPrototype(Textarea);
|
||||||
|
|
||||||
|
document.__defineGetter__("activeElement", function() {
|
||||||
|
return activeElement;
|
||||||
|
});
|
||||||
|
|
||||||
|
})(HTMLInputElement, HTMLTextAreaElement, document);
|
||||||
|
|
||||||
(function(css) {
|
(function(css) {
|
||||||
|
|
||||||
var setCssProperty = css.prototype.setProperty;
|
var setCssProperty = css.prototype.setProperty;
|
||||||
|
@ -111,3 +134,58 @@
|
||||||
}
|
}
|
||||||
})(CSS2Properties);
|
})(CSS2Properties);
|
||||||
})();
|
})();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Envjs timeout fixes which use native Java code to re-implement setTimeout and setInterval
|
||||||
|
* also sets clearTimeout & clearInterval on same level.
|
||||||
|
*/
|
||||||
|
(function() {
|
||||||
|
var threadTimeoutPool = {};
|
||||||
|
|
||||||
|
window.setTimeout = function(closure, timeout) {
|
||||||
|
var thread = spawn(function() {
|
||||||
|
try {
|
||||||
|
java.lang.Thread.sleep(timeout);
|
||||||
|
closure();
|
||||||
|
} catch(e) {
|
||||||
|
// ignore InterruptedExceptions, is probably due to clearTimeout
|
||||||
|
if (!(e.javaException instanceof java.lang.InterruptedException)) {
|
||||||
|
throw(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
threadTimeoutPool[thread.getId()] = thread;
|
||||||
|
return thread.getId();
|
||||||
|
};
|
||||||
|
|
||||||
|
window.setInterval = function(closure, timeout) {
|
||||||
|
var thread = spawn(function() {
|
||||||
|
try {
|
||||||
|
while(true) {
|
||||||
|
java.lang.Thread.sleep(timeout);
|
||||||
|
closure();
|
||||||
|
}
|
||||||
|
} catch(e) {
|
||||||
|
// ignore InterruptedExceptions, is probably due to clearTimeout
|
||||||
|
if (!(e.javaException instanceof java.lang.InterruptedException)) {
|
||||||
|
throw(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
threadTimeoutPool[thread.getId()] = thread;
|
||||||
|
return thread.getId();
|
||||||
|
};
|
||||||
|
|
||||||
|
window.clearTimeout = function(threadId) {
|
||||||
|
if (threadId) {
|
||||||
|
if(threadTimeoutPool[threadId]) {
|
||||||
|
threadTimeoutPool[threadId].interrupt();
|
||||||
|
delete threadTimeoutPool[threadId];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
window.clearInterval = window.clearTimeout;
|
||||||
|
})();
|
||||||
|
|
|
@ -1,6 +1,72 @@
|
||||||
|
|
||||||
describe("envjs fixes", function() {
|
describe("envjs fixes", function() {
|
||||||
|
|
||||||
|
describe("Envjs event handling fixes", function() {
|
||||||
|
beforeEach(function() {
|
||||||
|
loadFixtures("formevents.html");
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("focussing events", function() {
|
||||||
|
it("should set activeElement when focussing an input element", function() {
|
||||||
|
$("#input").focus();
|
||||||
|
expect(document.activeElement.id).toBe("input");
|
||||||
|
expect($(":focus")).toBe("#input");
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should set activeElement when focussing a textarea element", function() {
|
||||||
|
$("#area").focus();
|
||||||
|
expect(document.activeElement.id).toBe("area");
|
||||||
|
expect($(":focus")).toBe("#area");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("form submit events", function() {
|
||||||
|
it("should be able to catch a formsubmit event", function() {
|
||||||
|
var submitted = false;
|
||||||
|
$("#form").submit(function() {
|
||||||
|
submitted = true;
|
||||||
|
});
|
||||||
|
|
||||||
|
$("#form").submit();
|
||||||
|
waitsFor(function() {
|
||||||
|
return submitted === true;
|
||||||
|
});
|
||||||
|
|
||||||
|
runs(function() {
|
||||||
|
expect(submitted).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("Checkbox click events", function() {
|
||||||
|
it("should set the state of the checkbox to checked if not checked when clicked", function() {
|
||||||
|
$("#checkbox").click();
|
||||||
|
expect($("#checkbox")).toBeChecked();
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should set the state of the checkbox to unchecked if checked when clicked", function() {
|
||||||
|
$("#checkbox").attr('checked', true);
|
||||||
|
$("#checkbox").click();
|
||||||
|
expect($("#checkbox")).not.toBeChecked();
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should still fire the click event after clicking on a checkbox", function() {
|
||||||
|
var clicked = false;
|
||||||
|
$("#checkbox").click(function() {
|
||||||
|
clicked = true;
|
||||||
|
});
|
||||||
|
|
||||||
|
waitsFor(function() {
|
||||||
|
return clicked;
|
||||||
|
});
|
||||||
|
$("#checkbox").click();
|
||||||
|
runs(function() {
|
||||||
|
expect(clicked).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
describe("CSS2 style property support for parsing style attributes", function() {
|
describe("CSS2 style property support for parsing style attributes", function() {
|
||||||
beforeEach(function() {
|
beforeEach(function() {
|
||||||
loadFixtures("styleAttributes.html");
|
loadFixtures("styleAttributes.html");
|
||||||
|
@ -52,13 +118,14 @@ describe("envjs fixes", function() {
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("window setTimeout", function() {
|
describe("timer based events", function() {
|
||||||
|
|
||||||
|
describe("setTimeout", function() {
|
||||||
it("should wait one second before executing", function() {
|
it("should wait one second before executing", function() {
|
||||||
var done = false;
|
var done = false;
|
||||||
window.setTimeout(function() {
|
window.setTimeout(function() {
|
||||||
done = true;
|
done = true;
|
||||||
}, 1000);
|
}, 50);
|
||||||
|
|
||||||
waitsFor(function() {
|
waitsFor(function() {
|
||||||
return done === true;
|
return done === true;
|
||||||
|
@ -69,6 +136,96 @@ describe("envjs fixes", function() {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it("should return a unique timerID when the timeout has been set which can be cancelled", function() {
|
||||||
|
var done = false;
|
||||||
|
var timerID = window.setTimeout(function() {
|
||||||
|
done = true;
|
||||||
|
}, 10);
|
||||||
|
var timerID2 = window.setTimeout(function() { }, 10);
|
||||||
|
|
||||||
|
window.clearTimeout(timerID);
|
||||||
|
waits(50);
|
||||||
|
|
||||||
|
runs(function() {
|
||||||
|
expect(typeof(timerID)).toEqual("number");
|
||||||
|
expect(timerID).not.toEqual(timerID2);
|
||||||
|
expect(done).toBeFalsy();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should be able to use clearInterval for timeouts", function() {
|
||||||
|
var done = false;
|
||||||
|
var timerID = window.setTimeout(function() {
|
||||||
|
done = true;
|
||||||
|
}, 10);
|
||||||
|
|
||||||
|
window.clearInterval(timerID);
|
||||||
|
waits(50);
|
||||||
|
|
||||||
|
runs(function() {
|
||||||
|
expect(done).toBeFalsy();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("setInterval", function() {
|
||||||
|
it("should call the callback method x times until the interval has been stopped", function() {
|
||||||
|
var count = 0, storedCount;
|
||||||
|
var intervalId = window.setInterval(function() {
|
||||||
|
count++;
|
||||||
|
}, 20);
|
||||||
|
|
||||||
|
waitsFor(function() {
|
||||||
|
return count > 3;
|
||||||
|
});
|
||||||
|
|
||||||
|
runs(function() {
|
||||||
|
storedCount = count;
|
||||||
|
window.clearInterval(intervalId);
|
||||||
|
});
|
||||||
|
waits(100);
|
||||||
|
|
||||||
|
runs(function() {
|
||||||
|
expect(storedCount).toEqual(count);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should be able to use setTimeout and setInterval which create unique return IDs", function() {
|
||||||
|
var id1 = window.setTimeout(function() {}, 10);
|
||||||
|
var id2 = window.setInterval(function() {}, 10);
|
||||||
|
|
||||||
|
waits(50);
|
||||||
|
this.after(function() {
|
||||||
|
window.clearInterval(id2);
|
||||||
|
});
|
||||||
|
|
||||||
|
runs(function() {
|
||||||
|
expect(id1 < id2).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should be able to use clearTimeout for intervals", function() {
|
||||||
|
var count = 0, storedCount;
|
||||||
|
var intervalId = window.setInterval(function() {
|
||||||
|
count++;
|
||||||
|
}, 10);
|
||||||
|
|
||||||
|
waitsFor(function() {
|
||||||
|
return count > 1;
|
||||||
|
});
|
||||||
|
|
||||||
|
runs(function() {
|
||||||
|
storedCount = count;
|
||||||
|
window.clearTimeout(intervalId);
|
||||||
|
});
|
||||||
|
waits(100);
|
||||||
|
|
||||||
|
runs(function() {
|
||||||
|
expect(storedCount).toEqual(count);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
|
@ -0,0 +1,7 @@
|
||||||
|
|
||||||
|
<form id="form">
|
||||||
|
<input type="text" id="input" value="text"></input>
|
||||||
|
<input type="checkbox" id="checkbox"></input>
|
||||||
|
<textarea id="area"></textarea>
|
||||||
|
<input type="submit" id="submit"></input>
|
||||||
|
</form>
|
Reference in New Issue