summaryrefslogtreecommitdiff
path: root/common/tests/functional
diff options
context:
space:
mode:
authorKris Maglione <maglione.k@gmail.com>2011-02-01 04:02:29 -0500
committerKris Maglione <maglione.k@gmail.com>2011-02-01 04:02:29 -0500
commita21db1858acf8ac472f60b92bc4afefeebec0f41 (patch)
treecdb4f7432b722c3de9b9151ae653abe91f0d59fa /common/tests/functional
parente38f408b5dea231af873ef8c0620439c2651001a (diff)
downloadpentadactyl-a21db1858acf8ac472f60b92bc4afefeebec0f41.tar.gz
Bang on tests some more. Ameliorate some async completion issues.
--HG-- extra : rebase_source : 0f550b1650963e4010e447db2df7d6815627bae2
Diffstat (limited to 'common/tests/functional')
-rw-r--r--common/tests/functional/testCommands.js177
1 files changed, 116 insertions, 61 deletions
diff --git a/common/tests/functional/testCommands.js b/common/tests/functional/testCommands.js
index 44e98a89..6b53e97f 100644
--- a/common/tests/functional/testCommands.js
+++ b/common/tests/functional/testCommands.js
@@ -19,6 +19,10 @@ var teardownModule = function (module) {
dactyl.teardown();
}
+function hasItems(context) context.allItems.items.length;
+function hasntNullItems(context) hasItems(context) &&
+ !context.allItems.items.some(function ({ text, description }) [text, description].some(function (text) /^\[object/.test(text)));
+
var tests = {
"!": {
multiOutput: ["echo foo"]
@@ -32,18 +36,27 @@ var tests = {
noOutput: [""]
},
addons: {
- multiOutput: ["", "dactyl", "-type=extension", "-type=extension dactyl"]
+ multiOutput: ["", "dactyl", "-type=extension", "-type=extension dactyl"],
+ completions: [
+ "",
+ ["-types=", hasItems]
+ ]
},
autocmd: {
multiOutput: ["", "DOMLoad", "DOMLoad foo"],
noOutput: ["DOMLoad foo bar", "-js DOMLoad foo bar"],
- completions: ["", "DOMLoad foo ", "-js DOMLoad foo "]
+ completions: [
+ ["", hasntNullItems],
+ "DOMLoad foo ",
+ "-js DOMLoad foo "
+ ]
},
back: { noOutput: [""] },
bdelete: {
init: ["tabopen about:pentadactyl", "tabopen about:pentadactyl"],
noOutput: [""],
- anyOutput: ["about:pentadactyl"]
+ anyOutput: ["about:pentadactyl"],
+ completions: [["", hasItems]]
},
bmark: {
someOutput: ["bmark", "bmark -tags=foo -titlt=bar -keyword=baz -charset=UTF-8 -post=quux about:pentadactyl"],
@@ -52,7 +65,7 @@ var tests = {
"-max=1 -keyword=",
"-max=1 -keyword=foo -tags=",
"-max=1 -keyword=foo -tags=bar -title=",
- "-max=1 -keyword=foo -tags=bar -title=baz -charset=",
+ ["-max=1 -keyword=foo -tags=bar -title=baz -charset=", hasItems],
"-max=1 -keyword=foo -tags=bar -title=baz -charset= about:"
]
},
@@ -68,7 +81,10 @@ var tests = {
buffer: {
anyOutput: ["", "1"],
noOutput: ["!", "! 1"],
- completions: ["", "1"]
+ completions: [
+ ["", hasItems],
+ ["1", hasItems]
+ ]
},
buffers: {
multiOutput: ["", "1"],
@@ -95,7 +111,10 @@ var tests = {
cookies: {
anyOutput: ["dactyl.sf.net", "dactyl.sf.net list"],
error: [""],
- completions: ["", "dactyl.sf.net "]
+ completions: [
+ "",
+ ["dactyl.sf.net ", hasItems]
+ ]
},
delbmarks: { anyOutput: ["", "about:pentadactyl"] },
delcommand: {
@@ -114,7 +133,9 @@ var tests = {
},
dialog: {
// Skip implementation for now
- completions: ["", "pre"]
+ completions: [
+ ["", hasntNullItems]
+ ]
},
doautoall: {}, // Skip for now
doautocmd: {}, // Skip for now
@@ -147,24 +168,34 @@ var tests = {
emenu: {
noOutput: ["View.Zoom.Zoom In", "View.Zoom.Zoom Out"],
error: [""],
- completions: ["", "View."]
+ completions: [
+ ["", hasItems],
+ ["View.", hasItems]
+ ]
},
endif: {}, // Skip for now
execute: {
noOutput: ["", "'js " + "".quote() + "'"],
- someOutput: ["'ls'"]
+ someOutput: ["'ls'"],
+ completions: [["", hasItems]]
},
extadd: {
- completions: [""],
+ completions: [["", hasItems]],
error: [""]
},
extdelete: {
- completions: [""],
+ completions: [["", hasItems]],
error: [""]
},
get extdisable() this.extdelete,
- get extenable() this.extdelete,
- get extoptions() this.extdelete,
+ extenable: {
+ completions: [""],
+ error: [""]
+ },
+ extoptions: {
+ completions: [""],
+ error: [""]
+ },
get extrehash() this.extdelete,
get exttoggle() this.extdelete,
get extupdate() this.extdelete,
@@ -179,7 +210,10 @@ var tests = {
help: {
noOutput: ["", "intro"],
cleanup: ["tabdelete", "tabdelete"],
- completions: ["", "'wild"]
+ completions: [
+ ["", hasItems],
+ ["'wild", hasItems]
+ ]
},
get helpall() this.help,
highlight: {
@@ -190,34 +224,35 @@ var tests = {
"Help -group=FontCode foo: bar;"
],
completions: [
- "",
- "Help",
- "Help ",
- "Help -group=",
- "Help -group=FontCode ",
- "Help foo: bar; -moz"
+ ["", hasItems],
+ ["Help", hasItems],
+ ["Help ", hasItems],
+ ["Help -group=", hasItems],
+ ["Help -group=FontCode ", hasItems],
+ ["Help foo: bar; -moz", hasItems]
]
},
history: {
+ init: ["open about:pentadactyl"],
anyOutput: ["-max=1", "-max=1 -sort=+date", "-max=1 dactyl"],
completions: [
- "",
- "dactyl",
- "-sort=+",
- "-sort=-",
- "-sort=+date ",
- "-sort=+date dactyl"
+ ["", hasItems],
+ "about:",
+ ["-sort=+", hasItems],
+ ["-sort=-", hasItems],
+ ["-sort=+date ", hasItems],
+ "-sort=+date about:"
]
},
if: {}, // Skip for now
javascript: {
noOutput: ["''", "'\\n'", "<pre>foo bar</pre>", "window"],
completions: [
- "",
- "window",
- "window.",
- "window['",
- "commands.get('"
+ ["", hasItems],
+ ["window", hasItems],
+ ["window.", hasItems],
+ ["window['", hasItems],
+ ["commands.get('", hasItems]
]
},
jumps: {
@@ -231,7 +266,10 @@ var tests = {
let: {}, // Deprecated. Fuck it.
listcommands: {
anyOutput: ["", "in"],
- completions: ["", "in "]
+ completions: [
+ ["", hasItems],
+ "in "
+ ]
},
get listkeys() this.listcommands,
get listoptions() this.listcommands,
@@ -256,14 +294,14 @@ var tests = {
"-gtroup=some-nonexistent-group <C-a> <C-a>"
],
completeions: [
- "",
- "-",
- "-mode=ex ",
- "-mode=",
- "-group=",
- "-builtin i ",
- "-ex i ",
- "-javascript i ",
+ ["", hasItems],
+ ["-", hasItems],
+ ["-mode=ex ", hasItems],
+ ["-mode=", hasItems],
+ ["-group=", hasItems],
+ ["-builtin i ", hasItems],
+ ["-ex i ", hasItems],
+ ["-javascript i ", hasItems]
]
},
mapclear: {
@@ -326,7 +364,9 @@ var tests = {
"some-nonexistent-pentadactyl-dir/",
"some-nonexistent-pentadactyl-dir/foo.vim"
],
- completeions: [""],
+ completeions: [
+ ["", hasItems]
+ ],
cleanup: ["silent !rm -r some-nonexistent-pentadactyl-dir/"]
},
normal: {
@@ -337,20 +377,20 @@ var tests = {
open: {
noOutput: ["about:blank | about:home"],
completions: [
- "",
- "./",
- "./ | ",
- "chrome://",
- "chrome://browser/",
- "chrome://browser/content/",
- "about:",
- "resource://",
- "resource://dactyl/"
+ ["", hasItems],
+ ["./", hasItems],
+ ["./ | ", hasItems],
+ ["chrome://", hasItems],
+ ["chrome://browser/", hasItems],
+ ["chrome://browser/content/", hasItems],
+ ["about:", hasItems],
+ ["resource://", hasItems],
+ ["resource://dactyl/", hasItems]
]
},
pageinfo: {
multiOutput: ["", "fgm"],
- completions: [""],
+ completions: [["", hasItems]],
error: ["abcdefghijklmnopqrstuvwxyz", "f g m"]
},
pagestyle: {
@@ -366,7 +406,10 @@ var tests = {
"m foo bar"
],
error: ["", "#"],
- completions: ["", "m "]
+ completions: [
+ ["", hasItems], // Fails. Why?
+ ["m ", hasItems]
+ ]
},
qmarks: [
{
@@ -376,7 +419,7 @@ var tests = {
{
init: ["qmark x"],
multiOutput: ["", "m", "x"],
- completions: [""]
+ completions: [["", hasItems]]
}
],
quit: {}, // Skip for now
@@ -446,7 +489,10 @@ var tests = {
// "!" Previous sidebar isn't saved until the window loads.
// We don't give it enough time.
],
- completions: ["", "! "]
+ completions: [
+ ["", hasntNullItems],
+ "! "
+ ]
},
silent: {
noOutput: [
@@ -455,7 +501,7 @@ var tests = {
"echoerr 'foo'",
"echoerr " + "foo\nbar".quote()
],
- completions: [""]
+ completions: [["", hasItems]]
},
source: {},
stop: {},
@@ -508,7 +554,7 @@ function runCommands(cmdName, testName, commands, test, forbidErrors) {
commands.forEach(function (val) {
var [cmd, testVal] = Array.concat(val);
- // dump("CMD: " + testName + " " + cmdName + " " + cmd + "\n");
+ dump("CMD: " + testName + " " + cmdName + " " + cmd + "\n");
dactyl.clearMessage();
dactyl.closeMessageWindow();
@@ -529,7 +575,7 @@ function _runCommands(cmdName, testName, commands) {
commands.forEach(function (value) {
var [cmd, test] = Array.concat(value);
- // dump("CMD: " + testName + " " + cmdName + " " + cmd + "\n");
+ dump("CMD: " + testName + " " + cmdName + " " + cmd + "\n");
var res = dactyl.runExCommand(cmd);
controller.waitForPageLoad(controller.tabs.activeTab);
if (test)
@@ -602,12 +648,21 @@ for (var val in Iterator(tests)) (function ([command, paramsList]) {
addTest(command, testName, function () {
commands.forEach(function (val) {
var [cmd, test] = Array.concat(val);
+ cmd = command + cmd.replace(/^(!?) ?/, "$1 ");
dactyl.assertNoErrorMessages(function () {
- dactyl.runExCompletion(command + cmd.replace(/^(!?) ?/, "$1 "));
- if (test)
- jumlib.assert(test(dactyl.modules.commandline.commandSession.completions.context),
- "Initializing for " + cmdName + " tests failed: " + cmd.quote() + " " + test);
+ dump("COMPL: " + cmd + "\n");
+ dactyl.runExCompletion(cmd);
+ if (test) {
+ /* Freezes. :(
+ var context = dactyl.modules.commandline.commandSession.completions.context;
+ */
+ var context = dactyl.modules.CompletionContext(cmd);
+ context.tabPressed = true;
+ context.fork("ex", 0, dactyl.modules.completion, "ex");
+ jumlib.assert(context.wait(5000), "Completion failed: " + cmd.quote());
+ jumlib.assert(test(context), "Completion tests failed: " + cmd.quote() + " " + test);
+ }
});
});
});