From 5639aa971ef3bc650c38e936e42be57e3810fe41 Mon Sep 17 00:00:00 2001 From: Sergi Mansilla Date: Thu, 24 Nov 2011 23:22:49 +0100 Subject: [PATCH] Added tests for `selectAWord` --- lib/ace/selection_test.js | 84 ++++++++++++++++++++++----------------- 1 file changed, 48 insertions(+), 36 deletions(-) diff --git a/lib/ace/selection_test.js b/lib/ace/selection_test.js index fc962a18..3be52b5f 100644 --- a/lib/ace/selection_test.js +++ b/lib/ace/selection_test.js @@ -149,7 +149,7 @@ module.exports = { " Juhu Kinners (abc, 12)", " cde" ].join("\n")); - + var selection = session.getSelection(); selection.moveCursorDown(); @@ -187,7 +187,7 @@ module.exports = { selection.moveCursorWordLeft(); assert.position(selection.getCursor(), 0, 2); }, - + "test: moveCursor word left" : function() { var session = new EditSession(" Fuß Füße"); @@ -195,7 +195,7 @@ module.exports = { selection.moveCursorTo(0, 9) selection.moveCursorWordLeft(); assert.position(selection.getCursor(), 0, 5); - + selection.moveCursorWordLeft(); assert.position(selection.getCursor(), 0, 4); }, @@ -248,6 +248,18 @@ module.exports = { assert.position(range.end, 0, 12); }, + "test: select word with cursor in word including right whitespace should select the word" : function() { + var session = new EditSession("Juhu Kinners 123"); + var selection = session.getSelection(); + + selection.moveCursorTo(0, 8); + selection.selectAWord(); + + var range = selection.getRange(); + assert.position(range.start, 0, 5); + assert.position(range.end, 0, 18); + }, + "test: select word with cursor betwen white space and word should select the word" : function() { var session = new EditSession("Juhu Kinners"); var selection = session.getSelection(); @@ -308,67 +320,67 @@ module.exports = { selection.moveCursorTo(0, 5); assert.notOk(called); }, - + "test: moveWordLeft should move past || and [": function() { var session = new EditSession("||foo["); var selection = session.getSelection(); - + // Move behind || selection.moveCursorWordRight(); assert.position(selection.getCursor(), 0, 2); - + // Move beind foo selection.moveCursorWordRight(); assert.position(selection.getCursor(), 0, 5); - + // Move behind [ selection.moveCursorWordRight(); assert.position(selection.getCursor(), 0, 6); }, - + "test: moveWordRight should move past || and [": function() { var session = new EditSession("||foo["); var selection = session.getSelection(); - + selection.moveCursorTo(0, 6); - + // Move behind [ selection.moveCursorWordLeft(); assert.position(selection.getCursor(), 0, 5); - + // Move beind foo selection.moveCursorWordLeft(); assert.position(selection.getCursor(), 0, 2); - + // Move behind || selection.moveCursorWordLeft(); assert.position(selection.getCursor(), 0, 0); }, - + "test: move cursor to line start should move cursor to end of the indentation first": function() { var session = new EditSession("12\n Juhu\n12"); var selection = session.getSelection(); - + selection.moveCursorTo(1, 6); selection.moveCursorLineStart(); assert.position(selection.getCursor(), 1, 4); }, - + "test: move cursor to line start when the cursor is at the end of the indentation should move cursor to column 0": function() { var session = new EditSession("12\n Juhu\n12"); var selection = session.getSelection(); - + selection.moveCursorTo(1, 4); selection.moveCursorLineStart(); assert.position(selection.getCursor(), 1, 0); }, - + "test: move cursor to line start when the cursor is at column 0 should move cursor to the end of the indentation": function() { var session = new EditSession("12\n Juhu\n12"); var selection = session.getSelection(); - + selection.moveCursorTo(1, 0); selection.moveCursorLineStart(); @@ -379,64 +391,64 @@ module.exports = { "test: move cursor to line start when the cursor is before the initial indentation should move cursor to the end of the indentation": function() { var session = new EditSession("12\n Juhu\n12"); var selection = session.getSelection(); - + selection.moveCursorTo(1, 2); selection.moveCursorLineStart(); assert.position(selection.getCursor(), 1, 4); }, - + "test go line up when in the middle of the first line should go to document start": function() { var session = new EditSession("juhu kinners"); var selection = session.getSelection(); - + selection.moveCursorTo(0, 4); selection.moveCursorUp(); assert.position(selection.getCursor(), 0, 0); }, - + "test: (wrap) go line up when in the middle of the first line should go to document start": function() { var session = new EditSession("juhu kinners"); session.setWrapLimitRange(5, 5); session.adjustWrapLimit(80); - + var selection = session.getSelection(); - + selection.moveCursorTo(0, 4); selection.moveCursorUp(); assert.position(selection.getCursor(), 0, 0); }, - - + + "test go line down when in the middle of the last line should go to document end": function() { var session = new EditSession("juhu kinners"); var selection = session.getSelection(); - + selection.moveCursorTo(0, 4); selection.moveCursorDown(); assert.position(selection.getCursor(), 0, 12); }, - + "test (wrap) go line down when in the middle of the last line should go to document end": function() { var session = new EditSession("juhu kinners"); session.setWrapLimitRange(8, 8); session.adjustWrapLimit(80); var selection = session.getSelection(); - + selection.moveCursorTo(0, 10); selection.moveCursorDown(); assert.position(selection.getCursor(), 0, 12); }, - + "test go line up twice and then once down when in the second should go back to the previous column": function() { var session = new EditSession("juhu\nkinners"); var selection = session.getSelection(); - + selection.moveCursorTo(1, 4); selection.moveCursorUp(); selection.moveCursorUp(); @@ -444,25 +456,25 @@ module.exports = { assert.position(selection.getCursor(), 1, 4); }, - + "test (keyboard navigation) when curLine is not EOL and targetLine is all whitespace new column should be current column": function() { var session = new EditSession("function (a) {\n\ \n\ }"); var selection = session.getSelection(); - + selection.moveCursorTo(2, 0); selection.moveCursorUp(); assert.position(selection.getCursor(), 1, 0); }, - + "test (keyboard navigation) when curLine is EOL and targetLine is shorter dan current column, new column should be targetLine's EOL": function() { var session = new EditSession("function (a) {\n\ \n\ }"); var selection = session.getSelection(); - + selection.moveCursorTo(0, 14); selection.moveCursorDown(); @@ -474,4 +486,4 @@ module.exports = { if (typeof module !== "undefined" && module === require.main) { require("asyncjs").test.testcase(module.exports).exec() -} \ No newline at end of file +}