test/checks-test.js: Avoid function definitions in loops

Fixes the following JSHint errors:

  ./test/checks-test.js: line 26, col 8, Don't make functions within a loop.
  ./test/checks-test.js: line 31, col 5, Don't make functions within a loop.
  ./test/checks-test.js: line 59, col 8, Don't make functions within a loop.
  ./test/checks-test.js: line 64, col 5, Don't make functions within a loop.
redux
David Majda 13 years ago
parent 96192417d8
commit 0fe5769024

@ -3,6 +3,19 @@
module("PEG.compiler.checks");
test("reports missing referenced rules", function() {
function testGrammar(grammar) {
raises(
function() {
var ast = PEG.parser.parse(grammar);
PEG.compiler.checks.missingReferencedRules(ast);
},
function(e) {
return e instanceof PEG.GrammarError
&& e.message === "Referenced rule \"missing\" does not exist.";
}
);
}
var grammars = [
'start = missing',
'start = missing / "a" / "b"',
@ -18,21 +31,23 @@ test("reports missing referenced rules", function() {
'start = missing { }'
];
for (var i = 0; i < grammars.length; i++) {
for (var i = 0; i < grammars.length; i++) { testGrammar(grammars[i]); }
});
test("reports left recursion", function() {
function testGrammar(grammar) {
raises(
function() {
var ast = PEG.parser.parse(grammars[i]);
PEG.compiler.checks.missingReferencedRules(ast);
var ast = PEG.parser.parse(grammar);
PEG.compiler.checks.leftRecursion(ast);
},
function(e) {
return e instanceof PEG.GrammarError
&& e.message === "Referenced rule \"missing\" does not exist.";
&& e.message === "Left recursion detected for rule \"start\".";
}
);
}
});
test("reports left recursion", function() {
var grammars = [
/* Direct */
'start = start',
@ -51,18 +66,7 @@ test("reports left recursion", function() {
'start = stop; stop = start'
];
for (var i = 0; i < grammars.length; i++) {
raises(
function() {
var ast = PEG.parser.parse(grammars[i]);
PEG.compiler.checks.leftRecursion(ast);
},
function(e) {
return e instanceof PEG.GrammarError
&& e.message === "Left recursion detected for rule \"start\".";
}
);
}
for (var i = 0; i < grammars.length; i++) { testGrammar(grammars[i]); }
});
})();

Loading…
Cancel
Save