canonical
Version:
Canonical code style linter and formatter for JavaScript, SCSS, CSS and JSON.
70 lines (49 loc) • 2.06 kB
JavaScript
/**
* This script is used to inline assertions into the README.md documents.
*/
import _ from 'lodash';
import glob from 'glob';
import path from 'path';
import fs from 'fs';
const formatCodeSnippet = (setup) => {
const paragraphs = [];
if (setup.options) {
paragraphs.push('// Options: ' + JSON.stringify(setup.options));
}
paragraphs.push(setup.code);
if (setup.errors) {
paragraphs.push('// Message: ' + setup.errors[0].message);
}
return paragraphs.join('\n');
};
const getAssertions = () => {
const assertionFiles = glob.sync(path.resolve(__dirname, './../tests/rules/assertions/*.js'));
const assertionNames = _.map(assertionFiles, (filePath) => {
return path.basename(filePath, '.js');
});
const assertionCodes = _.map(assertionFiles, (filePath) => {
const codes = require(filePath).default;
return {
valid: _.map(codes.valid, formatCodeSnippet),
invalid: _.map(codes.invalid, formatCodeSnippet)
};
});
return _.zipObject(assertionNames, assertionCodes);
};
const updateDocuments = (assertions) => {
const readmeDocumentPath = path.join(__dirname, './../README.md');
let documentBody = fs.readFileSync(readmeDocumentPath, 'utf8');
documentBody = documentBody.replace(/<!-- assertions ([a-z]+?) -->/ig, (assertionsBlock) => {
let ruleName,
ruleAssertions;
ruleName = assertionsBlock.match(/assertions ([a-z]+)/i)[1];
ruleAssertions = assertions[ruleName];
if (!ruleAssertions) {
throw new Error('No assertions available for rule "' + ruleName + '".');
return assertionsBlock;
}
return 'The following patterns are considered problems:\n\n```js\n' + ruleAssertions.invalid.join('\n\n') + '\n```\n\nThe following patterns are not considered problems:\n\n```js\n' + ruleAssertions.valid.join('\n\n') + '\n```\n';
});
fs.writeFileSync(readmeDocumentPath, documentBody);
};
updateDocuments(getAssertions());