Jasmine: Convert tests of parser's "multiLineComment" rule

This commit is contained in:
David Majda 2012-04-20 15:07:33 +02:00
parent 328edf667c
commit dac3b0d8d9
2 changed files with 34 additions and 15 deletions

View file

@ -17,7 +17,7 @@ describe("PEG.js grammar parser", function() {
}; };
this.addMatchers({ this.addMatchers({
toParseAs: function(expected) { toParseAs: function(expected) {
var result; var result;
try { try {
@ -41,10 +41,43 @@ describe("PEG.js grammar parser", function() {
return false; return false;
} }
},
toFailToParse: function() {
var result;
try {
result = PEG.parser.parse(this.actual);
this.message = function() {
return "Expected " + jasmine.pp(this.actual) + " to fail to parse, "
+ "but it parsed as " + jasmine.pp(result) + ".";
};
return false;
} catch (e) {
this.message = function() {
return "Expected " + jasmine.pp(this.actual) + " to parse, "
+ "but it failed with message "
+ jasmine.pp(e.message) + ".";
};
return true;
}
} }
}); });
}); });
// Canonical multiLineComment is "/* comment */".
it("parses multiLineComment", function() {
expect('start =/**/"abcd"' ).toParseAs(trivialGrammar);
expect('start =/*a*/"abcd"' ).toParseAs(trivialGrammar);
expect('start =/*aaa*/"abcd"').toParseAs(trivialGrammar);
expect('start =/***/"abcd"' ).toParseAs(trivialGrammar);
expect('start =/**/*/"abcd"').toFailToParse();
});
/* Canonical eol is "\n". */ /* Canonical eol is "\n". */
it("parses eol", function() { it("parses eol", function() {
expect('start =\n"abcd"' ).toParseAs(trivialGrammar); expect('start =\n"abcd"' ).toParseAs(trivialGrammar);

View file

@ -549,18 +549,4 @@ test("parses singleLineComment", function() {
parserParses('start = "abcd"//', simpleGrammar); parserParses('start = "abcd"//', simpleGrammar);
}); });
// Canonical multiLineComment is "\/* comment *\/".
test("parses multiLineComment", function() {
parserParses('start =/**/"abcd"', simpleGrammar);
parserParses('start =/*a*/"abcd"', simpleGrammar);
parserParses('start =/*aaa*/"abcd"', simpleGrammar);
parserParses('start =/*\n*/"abcd"', simpleGrammar);
parserParses('start =/***/"abcd"', simpleGrammar);
parserParses('start =/*a/*/"abcd"', simpleGrammar);
parserDoesNotParse('start =/*"abcd"');
parserDoesNotParse('start =/*/"abcd"');
parserDoesNotParse('start =/*/**/*/"abcd"');
});
})(); })();