mirror of
https://github.com/documentationjs/documentation.git
synced 2026-01-25 14:26:29 +00:00
* Source-sorting by default Many changes * Uses a new version of module-deps that exposes a sort key we use to sort documentation. * Adds inference for methods in objects * Groups events into a separate comment property * Add jsdoc property. Refs https://github.com/documentationjs/documentation/pull/388#issuecomment-215791547 * Namespaces and paths * More powerful paths: paths now include name, kind, and scope * comments now include a 'namespace' property with a formatted namespace * Fix tests * Re-ignore fonts * Nix sourceKey from output * Pin dependency versions * Fix module-deps-sortable ref * Update tests for right deps
111 lines
3.5 KiB
JavaScript
111 lines
3.5 KiB
JavaScript
var test = require('tap').test,
|
|
path = require('path'),
|
|
os = require('os'),
|
|
exec = require('child_process').exec,
|
|
tmp = require('tmp'),
|
|
fs = require('fs-extra');
|
|
|
|
function documentation(args, options, callback, parseJSON) {
|
|
if (!callback) {
|
|
callback = options;
|
|
options = {};
|
|
}
|
|
|
|
if (!options.cwd) {
|
|
options.cwd = __dirname;
|
|
}
|
|
|
|
options.maxBuffer = 1024 * 1024;
|
|
|
|
args.unshift(path.join(__dirname, '../bin/documentation.js'));
|
|
|
|
exec(args.join(' '), options, callback);
|
|
}
|
|
|
|
var UPDATE = !!process.env.UPDATE;
|
|
|
|
test('readme command', function (group) {
|
|
var fixtures = path.join(__dirname, 'fixture/readme');
|
|
var sourceFile = path.join(fixtures, 'index.js');
|
|
|
|
tmp.dir({unsafeCleanup: true}, function (err, d) {
|
|
group.error(err);
|
|
fs.copySync(path.join(fixtures, 'README.input.md'), path.join(d, 'README.md'));
|
|
fs.copySync(path.join(fixtures, 'index.js'), path.join(d, 'index.js'));
|
|
|
|
// run tests after setting up temp dir
|
|
|
|
group.test('--diff-only: changes needed', function (t) {
|
|
t.error(err);
|
|
var before = fs.readFileSync(path.join(d, 'README.md'), 'utf-8');
|
|
documentation(['readme index.js --diff-only -s API'], {cwd: d}, function (err, stdout, stderr) {
|
|
var after = fs.readFileSync(path.join(d, 'README.md'), 'utf-8');
|
|
t.ok(err);
|
|
t.notEqual(err.code, 0, 'exit nonzero');
|
|
t.same(after, before, 'readme unchanged');
|
|
t.end();
|
|
});
|
|
});
|
|
|
|
var expectedFile = path.join(fixtures, 'README.output.md');
|
|
var expectedPath = path.join(fixtures, 'README.output.md');
|
|
var expected = fs.readFileSync(expectedFile, 'utf-8');
|
|
|
|
group.test('updates README.md', function (t) {
|
|
documentation(['readme index.js -s API'], {cwd: d}, function (err, stdout) {
|
|
var outputPath = path.join(d, 'README.md');
|
|
t.error(err);
|
|
|
|
if (UPDATE) {
|
|
fs.writeFileSync(expectedPath, fs.readFileSync(outputPath, 'utf-8'));
|
|
}
|
|
|
|
var actual = fs.readFileSync(outputPath, 'utf-8');
|
|
t.same(actual, expected, 'generated readme output');
|
|
t.end();
|
|
});
|
|
});
|
|
|
|
group.test('--readme-file', function (t) {
|
|
fs.copySync(path.join(fixtures, 'README.input.md'), path.join(d, 'other.md'));
|
|
documentation(['readme index.js -s API --readme-file other.md'], {cwd: d}, function (err, stdout) {
|
|
t.error(err);
|
|
var actual = fs.readFileSync(path.join(d, 'other.md'), 'utf-8');
|
|
t.same(actual, expected, 'generated readme output');
|
|
t.end();
|
|
});
|
|
});
|
|
|
|
group.test('--diff-only: changes NOT needed', function (t) {
|
|
t.error(err);
|
|
fs.copySync(path.join(fixtures, 'README.output.md'), path.join(d, 'uptodate.md'));
|
|
documentation(['readme index.js --diff-only -s API --readme-file uptodate.md'],
|
|
{cwd: d}, function (err, stdout, stderr) {
|
|
t.error(err);
|
|
t.match(stdout, 'is up to date.');
|
|
t.end();
|
|
});
|
|
});
|
|
|
|
group.test('requires -s option', function (t) {
|
|
documentation(['readme index.js'], {cwd: d}, function (err, stdout, stderr) {
|
|
t.ok(err);
|
|
t.ok(err.code !== 0, 'exit nonzero');
|
|
t.match(stderr, 'Missing required argument: s');
|
|
t.end();
|
|
});
|
|
});
|
|
|
|
group.test('errors if specified readme section is missing', function (t) {
|
|
documentation(['readme index.js -s DUMMY'], {cwd: d}, function (err, stdout, stderr) {
|
|
t.ok(err);
|
|
t.ok(err.code !== 0, 'exit nonzero');
|
|
t.end();
|
|
});
|
|
});
|
|
|
|
group.end();
|
|
});
|
|
});
|
|
|