diff options
author | Joel Kronqvist <work.joelkronqvist@pm.me> | 2022-03-11 20:46:06 +0200 |
---|---|---|
committer | Joel Kronqvist <work.joelkronqvist@pm.me> | 2022-03-11 20:46:06 +0200 |
commit | 080c5819d87b933816d724a83f3bf4f1686770a7 (patch) | |
tree | 4a2ccc68b27edf7d4cbc586c932cc7542b655e19 /node_modules/collect-v8-coverage/index.js | |
parent | 5ac7049a9d30733165cc212dee308163c2a14644 (diff) | |
parent | d003b82235a9329f912522a2f70aa950dfce4998 (diff) | |
download | LYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.tar.gz LYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.zip |
Merge branch 'master' of https://github.com/JoelHMikael/FoodJS
Updating remote changes
Diffstat (limited to 'node_modules/collect-v8-coverage/index.js')
-rw-r--r-- | node_modules/collect-v8-coverage/index.js | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/node_modules/collect-v8-coverage/index.js b/node_modules/collect-v8-coverage/index.js new file mode 100644 index 0000000..8c4a779 --- /dev/null +++ b/node_modules/collect-v8-coverage/index.js @@ -0,0 +1,37 @@ +'use strict'; + +const { Session } = require('inspector'); +const { promisify } = require('util'); + +class CoverageInstrumenter { + constructor() { + this.session = new Session(); + + this.postSession = promisify(this.session.post.bind(this.session)); + } + + async startInstrumenting() { + this.session.connect(); + + await this.postSession('Profiler.enable'); + + await this.postSession('Profiler.startPreciseCoverage', { + callCount: true, + detailed: true, + }); + } + + async stopInstrumenting() { + const {result} = await this.postSession( + 'Profiler.takePreciseCoverage', + ); + + await this.postSession('Profiler.stopPreciseCoverage'); + + await this.postSession('Profiler.disable'); + + return result; + } +} + +module.exports.CoverageInstrumenter = CoverageInstrumenter; |