pegjs/test/unit/compiler/passes/report-unused-rules.spec.js
Futago-za Ryuu 8b7bff7ac3 Resolve linting errors
This also temporarliy disables linting '.ts' files due to the fact that the currect '.d.ts' files contain too many errors/warnings that need to be manually fixed, but since I'm going to be rewriting the whole module in TypeScript anyway, resolving these ESLint error's is a pointless waste of time.
2019-09-29 03:24:42 +01:00

65 lines
1.4 KiB
JavaScript

"use strict";
const chai = require( "chai" );
const helpers = require( "./helpers" );
const pass = require( "pegjs" ).compiler.passes.check.reportUnusedRules;
chai.use( helpers );
const expect = chai.expect;
describe( "compiler pass |reportUnusedRules|", function () {
it( "should report rules that are not referenced", function () {
expect( pass ).to.reportWarning(
`
start = .
unused = .
`,
`Rule "unused" is not referenced.`
);
expect( pass ).to.reportWarning(
`
start = .
unused = .
used = .
`,
[
`Rule "used" is not referenced.`,
`Rule "unused" is not referenced.`,
]
);
} );
it( "does not report rules that are referenced", function () {
expect( pass ).not.to.reportWarning( `start = .` );
expect( pass ).not.to.reportWarning( `
start = used
used = .
` );
} );
it( "does not report any rules that the generated parser starts parsing from", function () {
expect( pass ).not.to.reportWarning(
`
a = "x"
b = a
c = .+
`,
null,
{
allowedStartRules: [ "b", "c" ],
}
);
} );
} );