Skip to content

Commit

Permalink
fix(json)!: log more robustly when JSON parsing fails (#1361)
Browse files Browse the repository at this point in the history
* Log more robustly when JSON parsing fails

* changed to error per pr feedback
  • Loading branch information
rotu authored Dec 17, 2022
1 parent 05c7438 commit 1be4b90
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 17 deletions.
3 changes: 1 addition & 2 deletions packages/json/src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,8 +24,7 @@ export default function json(options = {}) {
};
} catch (err) {
const message = 'Could not parse JSON file';
const position = parseInt(/[\d]/.exec(err.message)[0], 10);
this.warn({ message, id, position });
this.error({ message, id, cause: err });
return null;
}
}
Expand Down
27 changes: 12 additions & 15 deletions packages/json/test/test.js
Original file line number Diff line number Diff line change
Expand Up @@ -73,21 +73,18 @@ test('handles JSON objects with no valid keys (#19)', async (t) => {
});

test('handles garbage', async (t) => {
const warns = [];

await rollup({
input: 'fixtures/garbage/main.js',
plugins: [json()],
onwarn: (warning) => warns.push(warning)
}).catch(() => {});

const [{ message, id, position, plugin }] = warns;

t.is(warns.length, 1);
t.is(plugin, 'json');
t.is(position, 1);
t.is(message, 'Could not parse JSON file');
t.regex(id, /(.*)bad.json$/);
const err = await t.throwsAsync(
rollup({
input: 'fixtures/garbage/main.js',
plugins: [json()]
})
);
t.is(err.code, 'PLUGIN_ERROR');
t.is(err.plugin, 'json');
t.is(err.message, 'Could not parse JSON file');
t.is(err.name, 'RollupError');
t.is(err.cause.name, 'SyntaxError');
t.regex(err.id, /(.*)bad.json$/);
});

test('does not generate an AST', async (t) => {
Expand Down

0 comments on commit 1be4b90

Please sign in to comment.