fix all tests to run with node.js

This commit is contained in:
Fabian Jakobs 2010-12-14 15:09:24 +01:00
commit f07745839c
15 changed files with 181 additions and 125 deletions

View file

@ -47,7 +47,7 @@ var Range = require("ace/range").Range;
var Document = function(text, mode) {
this.modified = true;
this.lines = [""];
this.lines = [];
this.selection = new Selection(this);
this.$breakpoints = [];
@ -623,7 +623,7 @@ var Document = function(text, mode) {
};
this.indentRows = function(range, indentString) {
indentString.replace("\t", this.getTabString());
indentString = indentString.replace("\t", this.getTabString());
for (var row=range.start.row; row<=range.end.row; row++) {
this.$insert({row: row, column:0}, indentString);
}

View file

@ -35,14 +35,17 @@
*
* ***** END LICENSE BLOCK ***** */
require({
paths: {
"ace": "../src/ace"
}},
["ace/test/assertions", "ace/test/ChangeDocumentTest"],
function(a) {
console.log(a)
alert("a " + a)
}
);
require("../../../support/paths");
var async = require("async");
async.concat(
require("./change_document_test"),
require("./document_test"),
require("./event_emitter_test"),
require("./navigation_test"),
require("./range_test"),
require("./search_test"),
require("./selection_test"),
require("./text_edit_test")
).exec();

View file

@ -36,20 +36,12 @@
* ***** END LICENSE BLOCK ***** */
require("../../../support/paths");
require("./mockdom");
var dom = require('jsdom/level2/html').dom.level2.html;
var browser = require('jsdom/browser/index').windowAugmentation(dom);
global.document = browser.document;
global.window = browser.window;
global.self = browser.self;
global.navigator = browser.navigator;
global.location = browser.location;
var Document = require("../document"),
Editor = require("../editor"),
Text = require("../mode/text"),
JavaScriptMode = require("../mode/javascript"),
var Document = require("../document").Document,
Editor = require("../editor").Editor,
Text = require("../mode/text").Mode,
JavaScriptMode = require("../mode/javascript").Mode,
MockRenderer = require("./mockrenderer"),
assert = require("./assertions");

View file

@ -36,12 +36,12 @@
* ***** END LICENSE BLOCK ***** */
require("../../../support/paths");
require("./mockdom");
var Document = require("../document"),
UndoManager = require("../undomanager"),
//Editor = require("../editor"),
var Document = require("../document").Document,
UndoManager = require("../undomanager").UndoManager,
MockRenderer = require("./mockrenderer"),
Range = require("../range"),
Range = require("../range").Range,
assert = require("./assertions"),
async = require("async");
@ -83,9 +83,7 @@ var Test = {
"test: move lines down" : function() {
var doc = new Document(["1", "2", "3", "4"]);
console.log(doc.toString().replace(/\n/g, "\\n"));
doc.moveLinesDown(0, 1);
console.log(doc.toString().replace(/\n/g, "\\n"));
assert.equal(doc.toString(), ["3", "1", "2", "4"].join("\n"));
doc.moveLinesDown(1, 2);
@ -98,12 +96,10 @@ var Test = {
assert.equal(doc.toString(), ["3", "4", "2", "1"].join("\n"));
},
"__test: move lines up" : function() {
"test: move lines up" : function() {
var doc = new Document(["1", "2", "3", "4"]);
console.log(doc.toString().replace(/\n/g, "\\n"));
doc.moveLinesUp(2, 3);
console.log(doc.toString().replace(/\n/g, "\\n"));
assert.equal(doc.toString(), ["1", "3", "4", "2"].join("\n"));
doc.moveLinesUp(1, 2);
@ -178,49 +174,6 @@ var Test = {
assert.equal(["4", "5", "6"].join("\n"), doc.toString());
},
"__test: undo/redo for delete line" : function() {
var doc = new Document(["111", "222", "333"]);
var undoManager = new UndoManager();
doc.setUndoManager(undoManager);
var initialText = doc.toString();
var editor = new Editor(new MockRenderer(), doc);
editor.removeLines();
var step1 = doc.toString();
assert.equal(step1, "222\n333");
doc.$informUndoManager.call();
editor.removeLines();
var step2 = doc.toString();
assert.equal(step2, "333");
doc.$informUndoManager.call();
editor.removeLines();
var step3 = doc.toString();
assert.equal(step3, "");
doc.$informUndoManager.call();
undoManager.undo();
doc.$informUndoManager.call();
assert.equal(doc.toString(), step2);
undoManager.undo();
doc.$informUndoManager.call();
assert.equal(doc.toString(), step1);
undoManager.undo();
doc.$informUndoManager.call();
assert.equal(doc.toString(), initialText);
undoManager.undo();
doc.$informUndoManager.call();
assert.equal(doc.toString(), initialText);
},
"test: convert document to screen coordinates" : function() {
var doc = new Document("01234\t567890\t1234");
doc.setTabSize(4);

View file

@ -37,17 +37,17 @@
require("../../../support/paths");
var oop = require("../lib/oop");
MEventEmitter = require("../event_emitter"),
var oop = require("pilot/oop").oop;
EventEmitter = require("pilot/event_emitter").EventEmitter,
assert = require("./assertions");
var EventEmitter = function() {};
var Emitter = function() {};
oop.implement(EventEmitter.prototype, EventEmitter);
oop.implement(Emitter.prototype, EventEmitter);
var Test = {
"test: dispatch event with no data" : function() {
var emitter = new EventEmitter();
var emitter = new Emitter();
var called = false;
emitter.addEventListener("juhu", function(e) {
@ -55,7 +55,7 @@ var Test = {
assert.equal(e.type, "juhu");
});
emitter.$dispatchEvent("juhu");
emitter._dispatchEvent("juhu");
assert.true(called);
}
};

8
lib/ace/test/mockdom.js Normal file
View file

@ -0,0 +1,8 @@
var dom = require('jsdom/level2/html').dom.level2.html;
var browser = require('jsdom/browser/index').windowAugmentation(dom);
global.document = browser.document;
global.window = browser.window;
global.self = browser.self;
global.navigator = browser.navigator;
global.location = browser.location;

View file

@ -116,6 +116,9 @@ MockRenderer.prototype.setBreakpoints = function() {
MockRenderer.prototype.updateFull = function() {
};
MockRenderer.prototype.updateText = function() {
};
MockRenderer.prototype.showCursor = function() {
};

View file

@ -36,21 +36,12 @@
* ***** END LICENSE BLOCK ***** */
require("../../../support/paths");
require("./mockdom");
var dom = require('jsdom/level2/html').dom.level2.html;
var browser = require('jsdom/browser/index').windowAugmentation(dom);
global.document = browser.document;
global.window = browser.window;
global.self = browser.self;
global.navigator = browser.navigator;
global.location = browser.location;
var Document = require("../Document"),
Editor = require("../Editor"),
var Document = require("../Document").Document,
Editor = require("../Editor").Editor,
MockRenderer = require("./mockrenderer"),
assert = require("./assertions");
var Test = {
createTextDocument : function(rows, cols) {

View file

@ -37,7 +37,7 @@
require("../../../support/paths");
var Range = require("../range"),
var Range = require("../range").Range,
assert = require("./assertions");
var Test = {

View file

@ -37,8 +37,8 @@
require("../../../support/paths");
var Document = require("../document"),
Search = require("../search"),
var Document = require("../document").Document,
Search = require("../search").Search,
assert = require("./assertions");
var Test = {

View file

@ -37,7 +37,7 @@
require("../../../support/paths");
var Document = require("../document"),
var Document = require("../document").Document,
assert = require("./assertions");
var Test = {

View file

@ -36,19 +36,12 @@
* ***** END LICENSE BLOCK ***** */
require("../../../support/paths");
require("./mockdom");
var dom = require('jsdom/level2/html').dom.level2.html;
var browser = require('jsdom/browser/index').windowAugmentation(dom);
global.document = browser.document;
global.window = browser.window;
global.self = browser.self;
global.navigator = browser.navigator;
global.location = browser.location;
var Document = require("../document"),
Editor = require("../editor"),
var Document = require("../document").Document,
Editor = require("../editor").Editor,
JavaScriptMode = require("../mode/javascript").Mode,
UndoManager = require("../undomanager").UndoManager,
MockRenderer = require("./mockrenderer"),
assert = require("./assertions");
@ -119,7 +112,7 @@ var Test = {
editor.moveCursorTo(1, 3);
editor.getSelection().selectDown();
editor.blockIndent(" ");
editor.indent();
assert.equal(["a12345", " b12345", " c12345"].join("\n"),
doc.toString());
@ -135,26 +128,25 @@ var Test = {
var doc = new Document([" a12345", " b12345", " c12345"].join("\n"));
var editor = new Editor(new MockRenderer(), doc);
editor.moveCursorTo(0, 3);
editor.moveCursorTo(0, 5);
editor.getSelection().selectDown();
editor.getSelection().selectDown();
editor.blockOutdent(" ");
editor.blockOutdent();
assert.equal(doc.toString(), [" a12345", "b12345", " c12345"].join("\n"));
assert.position(editor.getCursorPosition(), 2, 0);
assert.position(editor.getCursorPosition(), 2, 1);
var range = editor.getSelectionRange();
assert.position(range.start, 0, 1);
assert.position(range.end, 2, 1);
editor.blockOutdent(" ");
editor.blockOutdent();
assert.equal(doc.toString(), ["a12345", "b12345", "c12345"].join("\n"));
var range = editor.getSelectionRange();
assert.position(range.start, 0, 1);
assert.position(range.end, 2, 1);
assert.position(range.start, 0, 0);
assert.position(range.end, 2, 0);
},
"test: outent without a selection should update cursor" : function() {
@ -340,6 +332,49 @@ var Test = {
editor.onTextInput("\t");
assert.equal(doc.toString(), "\t");
},
"test: undo/redo for delete line" : function() {
var doc = new Document(["111", "222", "333"]);
var undoManager = new UndoManager();
doc.setUndoManager(undoManager);
var initialText = doc.toString();
var editor = new Editor(new MockRenderer(), doc);
editor.removeLines();
var step1 = doc.toString();
assert.equal(step1, "222\n333");
doc.$informUndoManager.call();
editor.removeLines();
var step2 = doc.toString();
assert.equal(step2, "333");
doc.$informUndoManager.call();
editor.removeLines();
var step3 = doc.toString();
assert.equal(step3, "");
doc.$informUndoManager.call();
undoManager.undo();
doc.$informUndoManager.call();
assert.equal(doc.toString(), step2);
undoManager.undo();
doc.$informUndoManager.call();
assert.equal(doc.toString(), step1);
undoManager.undo();
doc.$informUndoManager.call();
assert.equal(doc.toString(), initialText);
undoManager.undo();
doc.$informUndoManager.call();
assert.equal(doc.toString(), initialText);
}
};

View file

@ -36,10 +36,11 @@
* ***** END LICENSE BLOCK ***** */
require("../../../support/paths");
require("./mockdom");
var Document = "../document",
VirtualRenderer = "../virtual_renderer",
assert = "../assertions";
var Document = require("../document").Document,
VirtualRenderer = require("../virtual_renderer").VirtualRenderer,
assert = require("./assertions");
var Test = {
"test: screen2text the column should be rounded to the next character edge" : function() {

View file

@ -1,4 +1,6 @@
require("./requireJS-node");
require.paths.unshift(__dirname + "/../lib");
require.paths.unshift(__dirname + "/../plugins");
require.paths.unshift(__dirname + "/async/lib");
require.paths.unshift(__dirname + "/node-htmlparser/lib");
require.paths.unshift(__dirname + "/jsdom/lib");

View file

@ -1,6 +1,6 @@
var path = require("path");
var fs = require("fs");
var currentModule, defaultCompile = module.constructor.prototype._compile;
//console.log(module.id);
module.constructor.prototype._compile = function(content, filename){
currentModule = this;
@ -21,15 +21,29 @@ global.define = function (id, injects, factory) {
var module = currentModule;
var req = function(relativeId) {
var req = function(relativeId, callback) {
if (Array.isArray(relativeId)) {
// async require
return callback.apply(this, relativeId.map(req))
}
var chunks = relativeId.split("!");
if (chunks.length >= 2) {
var prefix = chunks[0];
relativeId = chunks.slice(1).join("!")
}
if (relativeId.charAt(0) === '.') {
var rootPath = path.dirname(path.dirname(requireModule.filename)) + "/",
absolutePath = path.dirname(module.filename) + "/" + relativeId;
relativeId = "../" + absolutePath.match(new RegExp(rootPath + "(.*)"))[1];
}
return require(relativeId);
if (prefix == "text") {
return fs.readFileSync(findModulePath(relativeId))
} else
return require(relativeId);
};
if (!factory) {
// two or less arguments
@ -77,3 +91,57 @@ global.define = function (id, injects, factory) {
module.exports = returned;
}
};
// slighly modified version of
// https://github.com/ry/node/blob/1dad95a3a960c645ffec28f9ec023dad6a17c0d4/src/node.js#L159
//
// given a module name, and a list of paths to test, returns the first
// matching file in the following precedence.
//
// require("a.<ext>")
// -> a.<ext>
//
// require("a")
// -> a
// -> a.<ext>
// -> a/index.<ext>
function findModulePath(request) {
var fs = require('fs'),
exts = ["js"],
paths = ['.'].concat(require.paths)
paths = request.charAt(0) === '/' ? [''] : paths;
// check if the file exists and is not a directory
var tryFile = function(requestPath) {
try {
var stats = fs.statSync(requestPath);
if (stats && !stats.isDirectory()) {
return requestPath;
}
} catch (e) {}
return false;
};
// given a path check a the file exists with any of the set extensions
var tryExtensions = function(p, extension) {
for (var i = 0, EL = exts.length; i < EL; i++) {
f = tryFile(p + exts[i]);
if (f) { return f; }
}
return false;
};
// For each path
for (var i = 0, PL = paths.length; i < PL; i++) {
var p = paths[i],
// try to join the request to the path
f = tryFile(path.join(p, request)) ||
// try it with each of the extensions
tryExtensions(path.join(p, request)) ||
// try it with each of the extensions at "index"
tryExtensions(path.join(p, request, 'index'));
if (f) { return f; }
}
return false;
}