2016-01-22 14:00:55 +01:00
|
|
|
/* eslint no-console: 0 */
|
2016-01-29 14:36:56 +01:00
|
|
|
/* global PEG, console */
|
2015-06-08 20:21:19 +02:00
|
|
|
|
|
|
|
"use strict";
|
|
|
|
|
2014-05-23 15:07:22 +02:00
|
|
|
describe("generated parser API", function() {
|
|
|
|
describe("parse", function() {
|
|
|
|
it("parses input", function() {
|
|
|
|
var parser = PEG.buildParser('start = "a"');
|
|
|
|
|
|
|
|
expect(parser.parse("a")).toBe("a");
|
|
|
|
});
|
|
|
|
|
|
|
|
it("throws an exception on syntax error", function() {
|
|
|
|
var parser = PEG.buildParser('start = "a"');
|
|
|
|
|
|
|
|
expect(function() { parser.parse("b"); }).toThrow();
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("start rule", function() {
|
|
|
|
var parser = PEG.buildParser([
|
|
|
|
'a = "x" { return "a"; }',
|
|
|
|
'b = "x" { return "b"; }',
|
|
|
|
'c = "x" { return "c"; }'
|
|
|
|
].join("\n"), { allowedStartRules: ["b", "c"] });
|
|
|
|
|
|
|
|
describe("when |startRule| is not set", function() {
|
|
|
|
it("starts parsing from the first allowed rule", function() {
|
|
|
|
expect(parser.parse("x")).toBe("b");
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("when |startRule| is set to an allowed rule", function() {
|
2014-12-05 15:33:29 +01:00
|
|
|
it("starts parsing from specified rule", function() {
|
2014-05-23 15:07:22 +02:00
|
|
|
expect(parser.parse("x", { startRule: "b" })).toBe("b");
|
|
|
|
expect(parser.parse("x", { startRule: "c" })).toBe("c");
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("when |startRule| is set to a disallowed start rule", function() {
|
|
|
|
it("throws an exception", function() {
|
|
|
|
expect(
|
|
|
|
function() { parser.parse("x", { startRule: "a" }); }
|
|
|
|
).toThrow();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2015-02-24 05:12:24 +01:00
|
|
|
describe("tracing", function() {
|
|
|
|
var parser = PEG.buildParser([
|
|
|
|
'start = a / b',
|
|
|
|
'a = "a"',
|
|
|
|
'b = "b"'
|
|
|
|
].join("\n"), { trace: true });
|
|
|
|
|
|
|
|
describe("default tracer", function() {
|
2015-08-21 17:24:49 +02:00
|
|
|
it("traces using console.log (if console is defined)", function() {
|
|
|
|
if (typeof console === "object") {
|
|
|
|
spyOn(console, "log");
|
|
|
|
}
|
2015-02-24 05:12:24 +01:00
|
|
|
|
|
|
|
parser.parse("b");
|
|
|
|
|
2015-08-21 17:24:49 +02:00
|
|
|
if (typeof console === "object") {
|
|
|
|
expect(console.log).toHaveBeenCalledWith("1:1-1:1 rule.enter start");
|
|
|
|
expect(console.log).toHaveBeenCalledWith("1:1-1:1 rule.enter a");
|
|
|
|
expect(console.log).toHaveBeenCalledWith("1:1-1:1 rule.fail a");
|
|
|
|
expect(console.log).toHaveBeenCalledWith("1:1-1:1 rule.enter b");
|
|
|
|
expect(console.log).toHaveBeenCalledWith("1:1-1:2 rule.match b");
|
|
|
|
expect(console.log).toHaveBeenCalledWith("1:1-1:2 rule.match start");
|
|
|
|
}
|
2015-02-24 05:12:24 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("custom tracers", function() {
|
|
|
|
describe("trace", function() {
|
|
|
|
it("receives tracing events", function() {
|
2015-08-21 17:36:34 +02:00
|
|
|
var tracer = jasmine.createSpyObj("tracer", ["trace"]);
|
2015-02-24 05:12:24 +01:00
|
|
|
|
|
|
|
parser.parse("b", { tracer: tracer });
|
|
|
|
|
|
|
|
expect(tracer.trace).toHaveBeenCalledWith({
|
2015-08-21 17:38:04 +02:00
|
|
|
type: "rule.enter",
|
|
|
|
rule: "start",
|
2015-04-03 17:28:48 +02:00
|
|
|
location: {
|
|
|
|
start: { offset: 0, line: 1, column: 1 },
|
|
|
|
end: { offset: 0, line: 1, column: 1 }
|
|
|
|
}
|
2015-02-24 05:12:24 +01:00
|
|
|
});
|
|
|
|
expect(tracer.trace).toHaveBeenCalledWith({
|
2015-08-21 17:38:04 +02:00
|
|
|
type: "rule.enter",
|
|
|
|
rule: "a",
|
2015-04-03 17:28:48 +02:00
|
|
|
location: {
|
|
|
|
start: { offset: 0, line: 1, column: 1 },
|
|
|
|
end: { offset: 0, line: 1, column: 1 }
|
|
|
|
}
|
2015-02-24 05:12:24 +01:00
|
|
|
});
|
|
|
|
expect(tracer.trace).toHaveBeenCalledWith({
|
2015-08-21 17:38:04 +02:00
|
|
|
type: "rule.fail",
|
|
|
|
rule: "a",
|
2015-04-03 17:28:48 +02:00
|
|
|
location: {
|
|
|
|
start: { offset: 0, line: 1, column: 1 },
|
|
|
|
end: { offset: 0, line: 1, column: 1 }
|
|
|
|
}
|
2015-02-24 05:12:24 +01:00
|
|
|
});
|
|
|
|
expect(tracer.trace).toHaveBeenCalledWith({
|
2015-08-21 17:38:04 +02:00
|
|
|
type: "rule.enter",
|
|
|
|
rule: "b",
|
2015-04-03 17:28:48 +02:00
|
|
|
location: {
|
|
|
|
start: { offset: 0, line: 1, column: 1 },
|
|
|
|
end: { offset: 0, line: 1, column: 1 }
|
|
|
|
}
|
2015-02-24 05:12:24 +01:00
|
|
|
});
|
|
|
|
expect(tracer.trace).toHaveBeenCalledWith({
|
2015-08-21 17:38:04 +02:00
|
|
|
type: "rule.match",
|
|
|
|
rule: "b",
|
|
|
|
result: "b",
|
2015-04-03 17:28:48 +02:00
|
|
|
location: {
|
|
|
|
start: { offset: 0, line: 1, column: 1 },
|
|
|
|
end: { offset: 1, line: 1, column: 2 }
|
|
|
|
}
|
2015-02-24 05:12:24 +01:00
|
|
|
});
|
|
|
|
expect(tracer.trace).toHaveBeenCalledWith({
|
2015-08-21 17:38:04 +02:00
|
|
|
type: "rule.match",
|
|
|
|
rule: "start",
|
|
|
|
result: "b",
|
2015-04-03 17:28:48 +02:00
|
|
|
location: {
|
|
|
|
start: { offset: 0, line: 1, column: 1 },
|
|
|
|
end: { offset: 1, line: 1, column: 2 }
|
|
|
|
}
|
2015-02-24 05:12:24 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-05-23 15:07:22 +02:00
|
|
|
it("accepts custom options", function() {
|
|
|
|
var parser = PEG.buildParser('start = "a"');
|
|
|
|
|
|
|
|
parser.parse("a", { foo: 42 });
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|