mirror of https://github.com/zulip/zulip.git
check-openapi: Improve error handling.
Previously a YAML syntax error resulted in an UnhandledPromiseRejectionWarning and a successful exit code; now it gives a clear message and a failing exit code. Signed-off-by: Anders Kaseorg <anders@zulip.com>
This commit is contained in:
parent
d1694564b4
commit
7f52329256
|
@ -4,24 +4,31 @@ const fs = require('fs');
|
||||||
const jsyaml = require('js-yaml');
|
const jsyaml = require('js-yaml');
|
||||||
const SwaggerParser = require('swagger-parser');
|
const SwaggerParser = require('swagger-parser');
|
||||||
|
|
||||||
async function validate_swagger(file) {
|
|
||||||
try {
|
|
||||||
await SwaggerParser.validate(file);
|
|
||||||
} catch (err) {
|
|
||||||
// There is something wrong. Display the validation errors
|
|
||||||
console.error('In', file + ':');
|
|
||||||
console.error(err.message);
|
|
||||||
process.exitCode = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
(async () => {
|
(async () => {
|
||||||
// Iterate through the changed files, passed in the arguments.
|
// Iterate through the changed files, passed in the arguments.
|
||||||
// The two first arguments are the call to the Node interpreter and this
|
// The two first arguments are the call to the Node interpreter and this
|
||||||
// script, hence the starting point at 2.
|
// script, hence the starting point at 2.
|
||||||
for (const file of process.argv.slice(2)) {
|
for (const file of process.argv.slice(2)) {
|
||||||
if (jsyaml.safeLoad(await fs.promises.readFile(file, 'utf8')).openapi !== undefined) {
|
try {
|
||||||
await validate_swagger(file);
|
if (
|
||||||
|
jsyaml.safeLoad(await fs.promises.readFile(file, 'utf8'), {
|
||||||
|
filename: file,
|
||||||
|
}).openapi !== undefined
|
||||||
|
) {
|
||||||
|
await SwaggerParser.validate(file);
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
if (error instanceof jsyaml.YAMLException) {
|
||||||
|
console.error(error.message);
|
||||||
|
} else if (error instanceof SyntaxError) {
|
||||||
|
console.error(`${file}: ${error.message}`);
|
||||||
|
} else {
|
||||||
|
throw error;
|
||||||
|
}
|
||||||
|
process.exitCode = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})();
|
})().catch((error) => {
|
||||||
|
console.error(error);
|
||||||
|
process.exit(1);
|
||||||
|
});
|
||||||
|
|
Loading…
Reference in New Issue