Rewrite |trace| option tests to avoid using |console|
This makes them cleaner and also makes them work in IE 8-10.
This commit is contained in:
parent
cca41e6618
commit
e8b379f945
|
@ -1,4 +1,4 @@
|
||||||
/* global describe, expect, it, PEG, spyOn */
|
/* global describe, expect, it, jasmine, PEG */
|
||||||
|
|
||||||
"use strict";
|
"use strict";
|
||||||
|
|
||||||
|
@ -131,38 +131,34 @@ describe("PEG.js API", function() {
|
||||||
|
|
||||||
describe("when |trace| is not set", function() {
|
describe("when |trace| is not set", function() {
|
||||||
it("generated parser doesn't trace", function() {
|
it("generated parser doesn't trace", function() {
|
||||||
var parser = PEG.buildParser(grammar);
|
var parser = PEG.buildParser(grammar),
|
||||||
|
tracer = jasmine.createSpyObj("tracer", ["trace"]);
|
||||||
|
|
||||||
spyOn(console, "log");
|
parser.parse("a", { tracer: tracer });
|
||||||
|
|
||||||
parser.parse("a");
|
expect(tracer.trace).not.toHaveBeenCalled();
|
||||||
|
|
||||||
expect(console.log).not.toHaveBeenCalled();
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("when |trace| is set to |false|", function() {
|
describe("when |trace| is set to |false|", function() {
|
||||||
it("generated parser doesn't trace", function() {
|
it("generated parser doesn't trace", function() {
|
||||||
var parser = PEG.buildParser(grammar, { trace: false });
|
var parser = PEG.buildParser(grammar, { trace: false }),
|
||||||
|
tracer = jasmine.createSpyObj("tracer", ["trace"]);
|
||||||
|
|
||||||
spyOn(console, "log");
|
parser.parse("a", { tracer: tracer });
|
||||||
|
|
||||||
parser.parse("a");
|
expect(tracer.trace).not.toHaveBeenCalled();
|
||||||
|
|
||||||
expect(console.log).not.toHaveBeenCalled();
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("when |trace| is set to |true|", function() {
|
describe("when |trace| is set to |true|", function() {
|
||||||
it("generated parser traces", function() {
|
it("generated parser traces", function() {
|
||||||
var parser = PEG.buildParser(grammar, { trace: true });
|
var parser = PEG.buildParser(grammar, { trace: true }),
|
||||||
|
tracer = jasmine.createSpyObj("tracer", ["trace"]);
|
||||||
|
|
||||||
spyOn(console, "log");
|
parser.parse("a", { tracer: tracer });
|
||||||
|
|
||||||
parser.parse("a");
|
expect(tracer.trace).toHaveBeenCalled();
|
||||||
|
|
||||||
expect(console.log).toHaveBeenCalledWith("1:1-1:1 rule.enter start");
|
|
||||||
expect(console.log).toHaveBeenCalledWith("1:1-1:2 rule.match start");
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue