aboutsummaryrefslogtreecommitdiff
path: root/node_modules/istanbul-lib-instrument/src/read-coverage.js
diff options
context:
space:
mode:
authorJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
committerJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
commit080c5819d87b933816d724a83f3bf4f1686770a7 (patch)
tree4a2ccc68b27edf7d4cbc586c932cc7542b655e19 /node_modules/istanbul-lib-instrument/src/read-coverage.js
parent5ac7049a9d30733165cc212dee308163c2a14644 (diff)
parentd003b82235a9329f912522a2f70aa950dfce4998 (diff)
downloadLYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.tar.gz
LYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.zip
Merge branch 'master' of https://github.com/JoelHMikael/FoodJS
Updating remote changes
Diffstat (limited to 'node_modules/istanbul-lib-instrument/src/read-coverage.js')
-rw-r--r--node_modules/istanbul-lib-instrument/src/read-coverage.js77
1 files changed, 77 insertions, 0 deletions
diff --git a/node_modules/istanbul-lib-instrument/src/read-coverage.js b/node_modules/istanbul-lib-instrument/src/read-coverage.js
new file mode 100644
index 0000000..5b76dbb
--- /dev/null
+++ b/node_modules/istanbul-lib-instrument/src/read-coverage.js
@@ -0,0 +1,77 @@
+const { parseSync, traverse } = require('@babel/core');
+const { defaults } = require('@istanbuljs/schema');
+const { MAGIC_KEY, MAGIC_VALUE } = require('./constants');
+
+function getAst(code) {
+ if (typeof code === 'object' && typeof code.type === 'string') {
+ // Assume code is already a babel ast.
+ return code;
+ }
+
+ if (typeof code !== 'string') {
+ throw new Error('Code must be a string');
+ }
+
+ // Parse as leniently as possible
+ return parseSync(code, {
+ babelrc: false,
+ configFile: false,
+ parserOpts: {
+ allowAwaitOutsideFunction: true,
+ allowImportExportEverywhere: true,
+ allowReturnOutsideFunction: true,
+ allowSuperOutsideMethod: true,
+ sourceType: 'script',
+ plugins: defaults.instrumenter.parserPlugins
+ }
+ });
+}
+
+module.exports = function readInitialCoverage(code) {
+ const ast = getAst(code);
+
+ let covScope;
+ traverse(ast, {
+ ObjectProperty(path) {
+ const { node } = path;
+ if (
+ !node.computed &&
+ path.get('key').isIdentifier() &&
+ node.key.name === MAGIC_KEY
+ ) {
+ const magicValue = path.get('value').evaluate();
+ if (!magicValue.confident || magicValue.value !== MAGIC_VALUE) {
+ return;
+ }
+ covScope =
+ path.scope.getFunctionParent() ||
+ path.scope.getProgramParent();
+ path.stop();
+ }
+ }
+ });
+
+ if (!covScope) {
+ return null;
+ }
+
+ const result = {};
+
+ for (const key of ['path', 'hash', 'gcv', 'coverageData']) {
+ const binding = covScope.getOwnBinding(key);
+ if (!binding) {
+ return null;
+ }
+ const valuePath = binding.path.get('init');
+ const value = valuePath.evaluate();
+ if (!value.confident) {
+ return null;
+ }
+ result[key] = value.value;
+ }
+
+ delete result.coverageData[MAGIC_KEY];
+ delete result.coverageData.hash;
+
+ return result;
+};