/*! For license information please see testutils.cjs.LICENSE.txt */ (()=>{"use strict";var e,s,t={55:(e,s,t)=>{t.r(s),t.d(s,{TestRunner:()=>n.O,TestTracker:()=>a.b,argv:()=>o.D,colors:()=>l.O9,figures:()=>l.iI,isNumeric:()=>c.kE,pluralize:()=>c._6,sleep:()=>c._v,withColor:()=>l.I$,writeErrorsAreOk:()=>c.pT,writeInfo:()=>c.yZ});var o=t(887),i=t(654),r={};for(const e in i)["default","TestRunner","TestTracker","argv"].indexOf(e)<0&&(r[e]=()=>i[e]);t.d(s,r);var c=t(488),l=t(381),n=t(837),a=t(901)},227:()=>{},208:()=>{},654:(e,s,t)=>{t.r(s);var o=t(227),i={};for(const e in o)"default"!==e&&(i[e]=()=>o[e]);t.d(s,i);var r=t(208);i={};for(const e in r)"default"!==e&&(i[e]=()=>r[e]);t.d(s,i);var c=t(885);i={};for(const e in c)"default"!==e&&(i[e]=()=>c[e]);t.d(s,i);var l=t(446);i={};for(const e in l)"default"!==e&&(i[e]=()=>l[e]);t.d(s,i)},885:()=>{},446:()=>{},837:(e,s,t)=>{t.d(s,{O:()=>b});const o=require("nyc");var i=t.n(o);const r=require("resolve-from");var c=t.n(r);const l=require("fs"),n=require("path"),a=async e=>{const s=Object.assign({},u(e),e.coverage.config),o=new(i())(s);o.wrap();const r=new RegExp(`${e.moduleName}[\\/\\\\]${e.moduleBuildDir}[\\/\\\\]`),l=r.test.bind(r);if(Object.keys(t.c).filter(l).length>5&&console.warn("NYC initialized after modules were loaded",Object.keys(t.c).filter(l)),e.coverage.clean)try{await o.reset()}catch{await o.createTempDirectory()}else await o.createTempDirectory();const a={NYC_CONFIG:JSON.stringify(s),NYC_CWD:s.cwd};if(!1===s.babelCache&&(a.BABEL_DISABLE_CACHE=process.env.BABEL_DISABLE_CACHE="1"),!s.useSpawnWrap){const e=[require.resolve("nyc/lib/register-env"),...o.require.map((e=>c().silent(o.cwd,e)||e))];t(523).push(...e,require.resolve("nyc/lib/wrap")),Object.assign(process.env,a),e.forEach((e=>{require(e)}))}if(s.all&&await o.addAllFiles(),s.useSpawnWrap){const e=t(272);(0,n.relative)(__dirname,(0,n.resolve)(o.cwd,"node_modules","nyc","bin")).replace(/\\/g,"/"),e.runMain(),a.SPAWN_WRAP_SHIM_ROOT=process.env.SPAWN_WRAP_SHIM_ROOT||process.env.XDG_CACHE_HOME||t(37).homedir(),e([require.resolve("nyc/bin/wrap.js")],a)}return o},u=e=>{let s=(0,n.join)(e.projectRoot,".nycrc.json");if((0,l.existsSync)(s))try{return JSON.parse((0,l.readFileSync)(s,"utf8"))}catch{}if(s=(0,n.join)(e.projectRoot,".nycrc"),(0,l.existsSync)(s))try{return JSON.parse((0,l.readFileSync)(s,"utf8"))}catch{}if(s=(0,n.join)(e.projectRoot,"nycrc.json"),(0,l.existsSync)(s))try{return JSON.parse((0,l.readFileSync)(s,"utf8"))}catch{}return{extends:"@istanbuljs/nyc-config-typescript",cwd:e.projectRoot,hookRequire:!0,hookRunInContext:!0,hookRunInThisContext:!0,instrument:!0,reportDir:"./.coverage",silent:!1,reporter:["text-summary","html"],include:["dist/**/*.js"],exclude:["dist/**/test/**","node_modules/**"]}},h=require("glob"),g=require("mocha");var p=t.n(g);const m=e=>{const s=Object.assign({},d(e),e.framework.config),t=new(p())(s),o=e.framework.suite;let i="**/*.{spec,test}.js";o&&o.length>0&&(i=o.length>1?"{":"",o.forEach((e=>{i.length>1&&(i+=","),i+=`**/${e}.{spec,test}.js`})),i+=o.length>1?"}":"");const r=e.framework.root,c=e.framework.sortGroup,l=h.sync(i,{cwd:e.framework.root});return c?l.sort(((e,s)=>(c.includes((0,n.relative)(r,e))?(0,n.relative)(r,e):(0,n.basename)(e))<(c.includes((0,n.relative)(r,s))?(0,n.relative)(r,s):(0,n.basename)(s))?-1:1)):l.sort(((e,s)=>(0,n.basename)(e)<(0,n.basename)(s)?-1:1)),l.forEach((e=>t.addFile((0,n.resolve)(r,e)))),t},d=e=>{let s=(0,n.join)(e.projectRoot,".mocharc.json");if((0,l.existsSync)(s))try{return JSON.parse((0,l.readFileSync)(s,"utf8"))}catch{}if(s=(0,n.join)(e.projectRoot,".mocharc"),(0,l.existsSync)(s))try{return JSON.parse((0,l.readFileSync)(s,"utf8"))}catch{}if(s=(0,n.join)(e.projectRoot,"mocharc.json"),(0,l.existsSync)(s))try{return JSON.parse((0,l.readFileSync)(s,"utf8"))}catch{}return{ui:"tdd",color:!0,timeout:3e4,retries:0,slow:250}};var w=t(488);const _=e=>new Promise((s=>setTimeout(s,e))),T=async e=>{let s=process.stdout.write,t="";process.stdout.write=e=>(t+=e,!0);try{await e()}catch(e){S(e)}finally{process.stdout.write=s}return t},S=async e=>{if("EPIPE"!==e.code)throw e},y=async()=>{if("linux"===process.platform){const e=t(224);e.getWindowSize||(e.getWindowSize=()=>[80,75])}};var I=t(887),f=Object.defineProperty,$=(e,s,t)=>(((e,s,t)=>{s in e?f(e,s,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[s]=t})(e,"symbol"!=typeof s?s+"":s,t),t);class b{constructor(e){$(this,"_options"),$(this,"run",(()=>(async e=>{const s=await(async e=>{const s=!JSON.parse(process.env.xArgs||"[]").includes("--no-coverage");if(s&&((e.isTypescript||e.register.tsNode)&&t(58),e.register.sourceMapSupport&&t(501)),e.coverage.config&&(e.coverage.config.cwd=e.coverage.config.cwd||__dirname,!(0,l.existsSync)((0,n.join)(e.projectRoot,"package.json"))||!(0,l.existsSync)((0,n.join)(e.coverage.config.cwd,"package.json")))){let s=__dirname;for(;s.length>3&&!(0,l.existsSync)((0,n.join)(s,"package.json"));)s=(0,n.resolve)(s,"..");e.projectRoot=s,e.coverage.config.cwd=s}return{nyc:s?await a(e):void 0,mocha:m(e)}})(e),o=e.coverage.htmlReportDark&&"nyc"===e.coverage.tool&&e.coverage.config?.reporter?.includes("html");if(y(),o)try{const s=(0,n.resolve)(e.projectRoot,"node_modules","istanbul-reports","lib"),t=(0,n.resolve)(s,"html","assets"),o=(0,n.join)(t,"base.css");(0,l.copyFileSync)(o,(0,n.join)(t,"_base.css")),(0,l.copyFileSync)((0,n.resolve)(__dirname,"..","..","res","runner","istanbul","html","base.css"),t)}catch{}let i,r=0;try{r=await new Promise((e=>s.mocha.run(e)))}catch(e){i=e}if(s.nyc)try{await _(5*s.mocha.files.length),s.nyc.writeCoverageFile(),await _(20*s.mocha.files.length),await s.nyc.writeProcessIndex(),s.nyc.maybePurgeSourceMapCache(),console.log(await T(s.nyc.report.bind(s.nyc)))}catch(e){console.log("!!!"),console.log("!!! Error writing coverage file:"),console.log("!!! "+e),console.log("!!!");try{await s.nyc.showProcessTree()}catch{}}if(o)try{const s=(0,n.resolve)(e.projectRoot,"node_modules","istanbul-reports","lib","html","assets");(0,l.copyFileSync)((0,n.join)(s,"_base.css"),(0,n.join)(s,"base.css")),(0,l.copyFileSync)((0,n.resolve)(__dirname,"..","..","res","runner","istanbul","html","base.css"),s)}catch{}if(r>0||i){let e=i?i.message:`${r} ${(0,w._6)("test",r)} failed.`;throw process.env.TEST_UTILS_FAILURE_EXCEPTION&&(e=`${e}\n${process.env.TEST_UTILS_FAILURE_EXCEPTION}`),new Error(e)}})(Object.assign(this._options,(0,I.D)())))),this._options={coverage:{clean:!1,config:{},htmlReportDark:!1,tool:void 0},isTypescript:!1,moduleBuildDir:"dist",moduleName:"",projectRoot:"",register:{sourceMapSupport:!0,tsNode:!1},framework:{config:{},root:"",suite:void 0,type:void 0},verbose:!1},e&&(this._options=Object.assign(this._options,e))}}},901:(e,s,t)=>{t.d(s,{b:()=>d});var o=t(887),i=t(488),r=Object.defineProperty,c=(e,s,t)=>(((e,s,t)=>{s in e?r(e,s,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[s]=t})(e,"symbol"!=typeof s?s+"":s,t),t);class l{constructor(e){c(this,"_testTimer",0),c(this,"_inst"),c(this,"_results"),c(this,"_options"),c(this,"getSuccessCount",(e=>{const s=(e.test||e.currentTest).parent,t=this.getSuiteKey(s.title);return this._results.suiteResults[t].successCount})),c(this,"endRollingCount",((e,s)=>{const t=(s?e.currentTest:e.test).parent,o=this.getSuiteKey(t.title),r=this._results.suiteResults[o];++r.successCount,r.runTime=Date.now()-this._testTimer,r.runTimeFmt=`${Math.floor(r.runTime/1e3)} s, ${r.runTime%1e3} ms`,this._options.printSuiteRuntimes&&this._testTimer>0&&(0,i.yZ)(`suite runtime : ${r.runTimeFmt}`),this._testTimer=0})),c(this,"exitRollingCount",((e,s,t)=>{const o=s||t?e.currentTest:e.test,i=o.parent,r=this.getSuiteKey(i.title);this._results.suiteResults[r]||(this._results.suiteResults[r]={timeStarted:Date.now(),numTests:i.tests.length,success:!1,successCount:-1,suiteName:this.getSuiteFriendlyName(i.title),timeFinished:0,numTestsFailed:0},i.parent&&(this._options.isSingleSuiteTest=i.parent.suites.length<=2));const c=this._results.suiteResults[r],l=s||t?s?-1:i.tests.length:i.tests.findIndex((e=>e.title===o.title&&!e.isFailed()&&!e.isPassed()));try{if(c.successCount!==l)throw new Error(`Expected success count to be ${c.successCount}, got ${l}`)}catch(e){this._inst.setFailed(e,i,Object.assign({index:l},o))}return this._testTimer=Date.now(),this._inst.isRollingCountError})),c(this,"getSuiteKey",((e,s="")=>s?s+this.properCase(e.replace(" Tests","")).replace(/[ \W]/g,""):this.lowerCaseFirstChar(this.properCase(e.replace(" Tests","")),!0).replace(/\W/g,""))),c(this,"getSuiteFriendlyName",(e=>e.replace(" Tests",""))),c(this,"properCase",((e,s)=>e?e.replace(/(?:^\w|[A-Z]|\b\w)/g,(e=>e.toUpperCase())).replace(/[ ]+/g,s?"":" "):"")),c(this,"lowerCaseFirstChar",((e,s)=>{let t="";return e&&(t=e[0].toString().toLowerCase(),e.length>1&&(t+=e.substring(1)),s&&(t=t.replace(/ /g,""))),t})),c(this,"sleep",(async e=>new Promise((s=>setTimeout(s,e))))),c(this,"suiteFinished",(e=>{const s=e.currentTest?.parent;if(s){const e=s.tests.filter((e=>e.isFailed())).length,t=this.getSuiteKey(s.title),o=this._results.suiteResults[t];this._results.numTestsFail+=e,this._results.numTestsSuccess+=s.tests.filter((e=>e.isPassed())).length,this._results.numSuites++,this._results.numTests+=s.tests.length,e>0?this._results.numSuitesFail++:this._results.numSuitesSuccess++,this._results.suiteResults[t]=Object.assign(o,{success:0===e,timeFinished:Date.now(),numTestsFailed:e})}})),this._inst=e,this._options=e.options,this._results=e.results}get writeConsole(){return i.yZ}}var n=t(381);const a=require("readline");let u,h;const g=async(e,s)=>{s.meta?s.name:s.ctrl&&"c"===s.name&&h()};var p=Object.defineProperty,m=(e,s,t)=>(((e,s,t)=>{s in e?p(e,s,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[s]=t})(e,"symbol"!=typeof s?s+"":s,t),t);class d{constructor(e){var s;m(this,"_symbols"),m(this,"_timeStarted",0),m(this,"_caughtControlC",!1),m(this,"_hasRollingCountError"),m(this,"_results"),m(this,"_utils"),m(this,"_options"),m(this,"_timeSep","----------------------------------------------------------------------------------------------------"),m(this,"suiteResults",(e=>this._results.suiteResults[e])),m(this,"clearProcessTimeStorage",(async(e,s)=>{const t=async()=>{await this._options.store.updateStoreValue(e,void 0),await this._options.store.updateStoreValue(e+"Fmt",void 0),await this._options.store.updateStoreValue(e+"NumTests",void 0),await this._options.store.updateStoreValue(e+"Slow",void 0),await this._options.store.updateStoreValue(e+"SlowFmt",void 0),await this._options.store.updateStoreValue(e+"SlowNumTests",void 0)};(this._options.clearBestTime||this._options.clearAllBestTimes||this._options.clearBestTimesOnTestCountChange&&await this._options.store.getStoreValue(e+"NumTests",0)e+(this._options.isMultiRootWorkspace?"MWS":""))),m(this,"getTimeElapsedFmt",(e=>`${Math.floor(e/1e3/60)} minutes, ${Math.floor(e/1e3%60)} seconds, ${Math.round(e%1e3)} milliseconds`)),m(this,"logBestTime",(async(e,s,t)=>{let o,i=this._options.isMultiRootWorkspace?"multi-root":"single-root";const r=` The previous fastest time recorded for a ${i} workspace was ${await this._options.store.getStoreValue(s+"Fmt","")}`,c=` The slowest time recorded for a ${i} workspace was ${await this._options.store.getStoreValue(s+"SlowFmt","")}`,l=` ${n.iI.color.info} ${n.iI.withColor("!!!",n.iI.colors.cyan)}`;i=this._options.isMultiRootWorkspace?"Multi-Root":"Single-Root",o=e?e.includes("Logging")?` New Fastest Time with ${e} (${i} workspace) ${n.iI.withColor(t,n.iI.colors.cyan)}`:this._results.numSuites>1?` New Fastest Time for Suite '${e}' (${i} workspace) ${n.iI.withColor(t,n.iI.colors.cyan)}`:` New Fastest Time for Suite '${e}' (Single Test)(${i} workspace) ${n.iI.withColor(t,n.iI.colors.cyan)}`:` New Fastest Time for 'All Tests' (${i} workspace) ${n.iI.withColor(t,n.iI.colors.cyan)}`,console.log(l+n.iI.withColor(o,n.iI.colors.grey)),console.log(l+n.iI.withColor(r,n.iI.colors.grey)),console.log(l+n.iI.withColor(c,n.iI.colors.grey))})),m(this,"logSlowestTime",(async(e,s,t)=>{let o,i=this._options.isMultiRootWorkspace?"multi-root":"single-root";const r=await this._options.store.getStoreValue(s+"Fmt",""),c=` The previous slowest time recorded for a ${i} workspace was ${await this._options.store.getStoreValue(s+"SlowFmt","")}`,l=` The fastest time recorded for a ${i} workspace was ${r}`,a=` ${n.iI.color.info} ${n.iI.withColor("!!!",n.iI.colors.red)}`;i=this._options.isMultiRootWorkspace?"Multi-Root":"Single-Root",o=e?e.includes("Logging")?` New Slowest Time with ${e} (${i} workspace) ${n.iI.withColor(t,n.iI.colors.red)}`:this._results.numSuites>1?` New Slowest Time for Suite '${e}' (${i} workspace) ${n.iI.withColor(t,n.iI.colors.red)}`:` New Slowest Time for Suite '${e}' (Single Test)(${i} workspace) ${n.iI.withColor(t,n.iI.colors.red)}`:` New Slowest Time for 'All Tests' (${i} workspace) ${n.iI.withColor(t,n.iI.colors.cyan)}`,console.log(a+n.iI.withColor(o,n.iI.colors.grey)),console.log(a+n.iI.withColor(c,n.iI.colors.grey)),console.log(a+n.iI.withColor(l,n.iI.colors.grey))})),m(this,"processBestTime",(async(e,s,t,o)=>{const i=!e||e.includes("Logging")?"All Tests "+e:e,r=n.iI.withColor("-- ",n.iI.colors.magenta)+n.iI.withColor(i.toUpperCase(),n.iI.colors.white)+n.iI.withColor(` ${this._timeSep.substring(0,this._timeSep.length-i.length-4)}`,n.iI.colors.magenta);console.log(` ${n.iI.color.info} ${r}`),await this.clearProcessTimeStorage(s,o);let c=await this._options.store.getStoreValue(s,0);0===c&&(c=t+1);const l=await this._options.store.getStoreValue(`${s}Slow`,0);let a=l;0===a&&(a=t+1);const u=this.getTimeElapsedFmt(t);if(t>0&&t0&&(t>a||0===l))await this.logSlowestTime(e,s,u),await this.saveProcessTimeToStorage(`${s}Slow`,t,u,o);else{let e=await this._options.store.getStoreValue(s+"Fmt",""),i=await this._options.store.getStoreValue(s+"SlowFmt","");const r=this._options.isMultiRootWorkspace?"multi-root":"single-root",c=`The time elapsed was ${u}`,l=t>0?`The fastest time recorded for a ${r} workspace is ${e}`:"Fastest time tracking not available for tests running at 0 ms";if(e||(await this.saveProcessTimeToStorage(s,t,u,o),e=u),i||(await this.saveProcessTimeToStorage(`${s}Slow`,t,u,o),i=u),console.log(` ${n.iI.color.info} ${n.iI.withColor(c,n.iI.colors.grey)}`),console.log(` ${n.iI.color.info} ${n.iI.withColor(l,n.iI.colors.grey)}`),t>0){const e=`The slowest time recorded for a ${r} workspace is ${i}`;console.log(` ${n.iI.color.info} ${n.iI.withColor(e,n.iI.colors.grey)}`)}}})),m(this,"processSuiteTimes",(async()=>{const e=Object.values(this._results.suiteResults).filter((e=>"Deactivate Extension"!==e.suiteName));for(const s of e){const e=1===this._results.numSuites?"Single":"",t=this._utils.getSuiteKey(s.suiteName,this.getStorageKey("bestTimeElapsedSuite"+e));if(this._options.clearAllBestTimes&&(await this.clearProcessTimeStorage(t,this._results.numTests),await this.clearProcessTimeStorage(`${t}Slow`,this._results.numTests)),s.timeFinished&&s.timeStarted){const e=s.timeFinished-s.timeStarted;await this.processBestTime(s.suiteName,t,e,this._results.numTests)}}})),m(this,"processTimesWithLogEnabled",(async e=>{this._options.clearAllBestTimes&&(await this.clearProcessTimeStorage(this.getStorageKey("bestTimeElapsedWithLogging"),this._results.numTests),await this.clearProcessTimeStorage(this.getStorageKey("bestTimeElapsedWithLoggingFile"),this._results.numTests),await this.clearProcessTimeStorage(this.getStorageKey("bestTimeElapsedWithLoggingOutput"),this._results.numTests),await this.clearProcessTimeStorage(this.getStorageKey("bestTimeElapsedWithLoggingConsole"),this._results.numTests),await this.clearProcessTimeStorage(this.getStorageKey("slowTimeElapsedWithLogging"),this._results.numTests),await this.clearProcessTimeStorage(this.getStorageKey("slowTimeElapsedWithLoggingFile"),this._results.numTests),await this.clearProcessTimeStorage(this.getStorageKey("slowTimeElapsedWithLoggingOutput"),this._results.numTests),await this.clearProcessTimeStorage(this.getStorageKey("slowTimeElapsedWithLoggingConsole"),this._results.numTests)),this._options.isLogEnabled&&(await this.processBestTime("Logging Enabled",this.getStorageKey("bestTimeElapsedWithLogging"),e,this._results.numTests),await this.processBestTime("Logging Enabled",this.getStorageKey("slowTimeElapsedWithLogging"),e,this._results.numTests),this._options.isFileLogEnabled&&(await this.processBestTime("File Logging Enabled",this.getStorageKey("bestTimeElapsedWithLoggingFile"),e,this._results.numTests),await this.processBestTime("File Logging Enabled",this.getStorageKey("slowTimeElapsedWithLoggingFile"),e,this._results.numTests)),this._options.isOutputWindowLogEnabled&&(await this.processBestTime("Output Window Logging Enabled",this.getStorageKey("bestTimeElapsedWithLoggingOutput"),e,this._results.numTests),await this.processBestTime("Output Window Logging Enabled",this.getStorageKey("slowTimeElapsedWithLoggingOutput"),e,this._results.numTests)),this._options.isConsoleLogEnabled&&(await this.processBestTime("Console Logging Enabled",this.getStorageKey("bestTimeElapsedWithLoggingConsole"),e,this._results.numTests),await this.processBestTime("Console Logging Enabled",this.getStorageKey("slowTimeElapsedWithLoggingConsole"),e,this._results.numTests)))})),m(this,"processTimes",(async()=>{const e=Date.now()-this._timeStarted,s=6e4*(new Date).getTimezoneOffset(),t=new Date(Date.now()-s).toISOString().slice(0,-1).replace("T"," ").replace(/[\-]/g,"/");if(this._hasRollingCountError&&this._symbols&&(this._symbols.ok=n.iI.color.success),this._caughtControlC&&console.log(` ${n.iI.color.info} ${n.iI.withColor("User cancelled (caught CTRL+C)",n.O9.grey)}`),u&&(process.stdin.off("keypress",g),u.close(),u=void 0),console.log(` ${n.iI.color.info} ${n.iI.withColor("Time Finished: "+t,n.iI.colors.grey)}`),console.log(` ${n.iI.color.info} ${n.iI.withColor("Time Elapsed: "+this.getTimeElapsedFmt(e),n.iI.colors.grey)}`),0!==this._results.numTestsFail||this._hasRollingCountError){const e=this._results.numTestsFail>0?`There were ${this._results.numTestsFail} failed tests, best time processing skipped`:"There was a rolling count failure, best time processing skipped";console.log(` ${n.iI.color.info} ${n.iI.withColor(e,n.iI.colors.grey)}`)}else this._results.numSuites>3&&(await this.processBestTime("",this.getStorageKey("bestTimeElapsed"),e,this._results.numTests),await this.processTimesWithLogEnabled(e)),await this.processSuiteTimes();console.log(` ${n.iI.color.info} ${n.iI.withColor(this._timeSep,n.iI.colors.magenta)}`)})),m(this,"saveProcessTimeToStorage",(async(e,s,t,o)=>{await this._options.store.updateStoreValue(e,s),await this._options.store.updateStoreValue(e+"Fmt",t),await this._options.store.updateStoreValue(e+"NumTests",o)})),m(this,"setFailed",((e,s,o)=>{if(!this._hasRollingCountError){const r=e instanceof Error;if(this._caughtControlC="boolean"==typeof e,this._hasRollingCountError={suite:s.title,test:o.title,testIdx:o.index},"mocha"===this._options.framework){const{symbols:e}=t(899);this._symbols=e,e.ok=n.iI.withColor(n.iI.pointer,n.O9.blue)+n.iI.withColor(" [Skipped]",n.O9.grey)}if(!o)throw new Error("Caught CTRL-C");if((0,i.yZ)(`rolling success count failure @ test ${o.index+1}, skipping remaining tests`),0===s?.tests.filter((e=>e.isFailed())).length)throw process.env.TEST_UTILS_FAILURE_EXCEPTION=r?e.message:"",new Error("Rolling count error: "+process.env.TEST_UTILS_FAILURE_EXCEPTION)}})),this._results={numSuites:0,numSuitesFail:0,numSuitesSuccess:0,numTests:0,numTestsFail:0,numTestsSuccess:0,suiteResults:{}},this._options={clearAllBestTimes:!1,clearBestTime:!1,clearBestTimesOnTestCountChange:!1,framework:"mocha",isConsoleLogEnabled:!1,isFileLogEnabled:!1,isLogEnabled:!1,isMultiRootWorkspace:!1,isOutputWindowLogEnabled:!1,isSingleSuiteTest:!1,printSuiteRuntimes:!1,store:{async updateStoreValue(...e){},getStoreValue:async(...e)=>0}},Object.assign(this._options,e||{},(0,o.D)()),s=()=>{this.setFailed(!0)},!u&&process.stdin.isTTY&&(h=s,u=a.createInterface({input:process.stdin,escapeCodeTimeout:50}),process.stdin.setRawMode(!0),a.emitKeypressEvents(process.stdin,u),process.stdin.on("keypress",g)),this._timeStarted=Date.now(),this._utils=new l(this)}get isRollingCountError(){return!!this._hasRollingCountError}get options(){return this._options}set options(e){this._timeStarted=Date.now(),Object.assign(this._options,e)}get results(){return this._results}get utils(){return this._utils}}},887:(e,s,t)=>{t.d(s,{D:()=>i});var o=t(488);const i=()=>{const e={};return process.argv.forEach(((s,t,i)=>{s.startsWith("--tu-")&&(i[t+1]&&!i[t+1].startsWith("--")?(e[r(s)]=i[t+1],(0,o.kE)(e[s])&&(e[s]=parseInt(i[t+1],10))):e[s]=!0)}),void 0),e},r=e=>e.replace(/(?:^\w|[A-Z]|\b\w)/g,((e,s)=>0!==s?e.toLowerCase():e.toUpperCase())).replace(/[\s\-]+/g,"")},381:(e,s,t)=>{t.d(s,{I$:()=>c,O9:()=>r,iI:()=>l});var o=Object.defineProperty,i=(e,s,t)=>(((e,s,t)=>{s in e?o(e,s,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[s]=t})(e,"symbol"!=typeof s?s+"":s,t),t);const r=new class{constructor(){i(this,"bold",[1,22]),i(this,"italic",[3,23]),i(this,"underline",[4,24]),i(this,"inverse",[7,27]),i(this,"white",[37,39]),i(this,"grey",[90,39]),i(this,"black",[30,39]),i(this,"blue",[34,39]),i(this,"cyan",[36,39]),i(this,"green",[32,39]),i(this,"magenta",[35,39]),i(this,"red",[31,39]),i(this,"yellow",[33,39])}},c=(e,s)=>"["+s[0]+"m"+e+"["+s[1]+"m",l={colors:r,withColor:c,success:"✔",info:"ℹ",warning:"⚠",error:"✘",pointer:"❯",start:"▶",end:"◀",nodejs:"⬢",star:"★",checkboxOn:"☒",checkboxOff:"☐",pointerSmall:"›",bullet:"●",up:"△",color:{success:c("✔",r.green),successBlue:c("✔",r.blue),info:c("ℹ",r.magenta),infoTask:c("ℹ",r.blue),warning:c("⚠",r.yellow),warningTests:c("⚠",r.blue),error:c("✘",r.red),errorTests:c("✘",r.blue),start:c("▶",r.green),end:c("◀",r.green),pointer:c("❯",r.grey),up:c("△",r.green)}}},488:(e,s,t)=>{t.d(s,{_6:()=>r,_v:()=>c,kE:()=>i,pT:()=>n,yZ:()=>l});var o=t(381);const i=e=>!isNaN(parseFloat(e))&&isFinite(e),r=(e,s)=>1!==s?e+"s":e,c=async e=>new Promise((s=>setTimeout(s,e))),l=(e,s,t="")=>console.log(` ${t}${s||o.iI.color.info}${e?" "+o.iI.withColor(e,o.iI.colors.grey):""}`),n=()=>{console.log(` ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success}`),console.log(` ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.up} ${o.iI.withColor(" THESE ERRORS WERE SUPPOSED TO HAPPEN!!! ",o.iI.colors.green)} ${o.iI.color.up} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success}`),console.log(` ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success} ${o.iI.color.success}`)}},899:e=>{e.exports=require("mocha/lib/reporters/base")},523:e=>{e.exports=require("node-preload")},501:e=>{e.exports=require("source-map-support/register")},272:e=>{e.exports=require("spawn-wrap")},58:e=>{e.exports=require("ts-node/register")},37:e=>{e.exports=require("os")},224:e=>{e.exports=require("tty")}},o={};function i(e){var s=o[e];if(void 0!==s)return s.exports;var r=o[e]={id:e,loaded:!1,exports:{}};return t[e](r,r.exports,i),r.loaded=!0,r.exports}i.m=t,i.c=o,i.n=e=>{var s=e&&e.__esModule?()=>e.default:()=>e;return i.d(s,{a:s}),s},i.d=(e,s)=>{for(var t in s)i.o(s,t)&&!i.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:s[t]})},i.f={},i.e=e=>Promise.all(Object.keys(i.f).reduce(((s,t)=>(i.f[t](e,s),s)),[])),i.u=e=>{},i.o=(e,s)=>Object.prototype.hasOwnProperty.call(e,s),i.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},i.X=(e,s,t)=>{var o=s;t||(s=e,t=()=>i(i.s=o)),s.map(i.e,i);var r=t();return void 0===r?e:r},e={924:1},s=s=>{var t=s.modules,o=s.ids,r=s.runtime;for(var c in t)i.o(t,c)&&(i.m[c]=t[c]);r&&r(i);for(var l=0;l{e[t]||s(require("./"+i.u(t)))},module.exports=i,i.C=s;var r=i(55);module.exports=r})(); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"testutils.cjs","mappings":";uBAIIA,EAMAC,myBCVJ,MAAM,EAA+BC,QAAQ,oBCA7C,MAAM,EAA+BA,QAAQ,6BCA7C,MAAM,EAA+BA,QAAQ,MCAvC,EAA+BA,QAAQ,QCgB7C,QAAqBC,IAEjB,MAAMC,EAAYC,OAAOC,OAAO,CAAC,EAAGC,EAAcJ,GAAUA,EAAQK,SAASC,QAK1EC,EAAM,IAAI,IAAJ,CAAQN,GACpBM,EAAIC,OAKJ,MAAMC,EAAe,IAAIC,OAAO,GAAGV,EAAQW,sBAAsBX,EAAQY,2BACtEC,EAAWJ,EAAaK,KAAKC,KAAKN,GAUrC,GARIP,OAAOc,KAAK,KAAeC,OAAOJ,GAAUK,OADvB,GAGxBC,QAAQC,KAAK,4CAA6ClB,OAAOc,KAAK,KAAeC,OAAOJ,IAMxFb,EAAQK,SAASgB,MAKrB,UACOd,EAAIe,OACX,aAEOf,EAAIgB,qBACX,YARMhB,EAAIgB,sBAaX,MAAMC,EAAW,CAChBC,WAAYC,KAAKC,UAAU1B,GAC3B2B,QAAS3B,EAAU4B,KAapB,IAP6B,IAAzB5B,EAAU6B,aAEbN,EAAIO,oBAAsBC,QAAQR,IAAIO,oBAAsB,MAKxD9B,EAAUgC,aACf,CAIC,MAAMC,EAAiB,CAGtBC,YAAYC,YAAY,2BACrB7B,EAAIR,QAAQsC,KAAKC,GAAgB,WAAmB/B,EAAIsB,IAAKS,IAAQA,KAGrD,EAAQ,KAChBC,QACRL,EAGHC,YAAYC,YAAY,iBAEzBlC,OAAOC,OAAO6B,QAAQR,IAAKA,GAC3BU,EAAeM,SAAQF,IAASG,gBAAgBH,EAAI,GACrD,CAWA,GAPIrC,EAAUyC,WAEPnC,EAAIoC,cAKP1C,EAAUgC,aACd,CAgBC,MAAMW,EAAK,EAAQ,MACH,IAAAC,UAASC,WAAW,IAAAC,SAAQxC,EAAIsB,IAAK,eAAgB,MAAO,QAAQmB,QAAQ,MAAO,KACnGJ,EAAGK,UACHzB,EAAI0B,qBAAuBlB,QAAQR,IAAI0B,sBAAwBlB,QAAQR,IAAI2B,gBAAkB,gBAC7FP,EAAG,CAAET,YAAYC,YAAY,oBAAsBZ,EACpD,CAEA,OAAOjB,CACP,EAgBKH,EAAiBJ,IAEtB,IAAIoD,GAAU,IAAAC,MAAKrD,EAAQsD,YAAa,eACxC,IAAI,IAAAC,YAAWH,GACd,IAAM,OAAgC1B,KAAK8B,OAAM,IAAAC,cAAaL,EAAS,QAAU,CAAE,MAAO,CAI3F,GADAA,GAAU,IAAAC,MAAKrD,EAAQsD,YAAa,WAChC,IAAAC,YAAWH,GACd,IAAM,OAAgC1B,KAAK8B,OAAM,IAAAC,cAAaL,EAAS,QAAU,CAAE,MAAO,CAI3F,GADAA,GAAU,IAAAC,MAAKrD,EAAQsD,YAAa,eAChC,IAAAC,YAAWH,GACd,IAAM,OAAgC1B,KAAK8B,OAAM,IAAAC,cAAaL,EAAS,QAAU,CAAE,MAAO,CAG3F,MAAO,CACNM,QAAS,oCACT7B,IAAK7B,EAAQsD,YACbK,aAAa,EACbC,kBAAkB,EAClBC,sBAAsB,EACtBC,YAAY,EACZC,UAAW,cACXC,QAAQ,EACRC,SAAU,CAAE,eAAgB,QAC5BC,QAAS,CAAE,gBACXC,QAAS,CAAE,kBAAmB,mBAC9B,EC5KI,EAA+BpE,QAAQ,QCAvC,EAA+BA,QAAQ,sBCY7C,QAAgBC,IAEf,MAAMM,EAAuBJ,OAAOC,OAAO,CAAC,EAAG,EAAcH,GAAkCA,EAAQoE,UAAU9D,QAC9G+D,EAAQ,IAAI,IAAJ,CAAU/D,GAClBgE,EAAQtE,EAAQoE,UAAUE,MAE7B,IAAIC,EAAc,sBACdD,GAASA,EAAMpD,OAAS,IAE3BqD,EAAeD,EAAMpD,OAAS,EAAI,IAAM,GACxCoD,EAAM9B,SAASgC,IAEVD,EAAYrD,OAAS,IACxBqD,GAAe,KAEhBA,GAAe,MAAMC,kBAAkB,IAExCD,GAAgBD,EAAMpD,OAAS,EAAI,IAAM,IAM1C,MAAMuD,EAAezE,EAAQoE,UAAUK,KACpCC,EAAY1E,EAAQoE,UAAUM,UAC9BC,EAAQ,OAAUJ,EAAa,CAAE1C,IAAK7B,EAAQoE,UAAUK,OAgB3D,OAfKC,EAMJC,EAAMC,MAAK,CAACJ,EAAWK,KAEXH,EAAUI,UAAS,IAAAjC,UAAS4B,EAAMD,KAAM,IAAA3B,UAAS4B,EAAMD,IAAK,IAAAO,UAASP,KACxEE,EAAUI,UAAS,IAAAjC,UAAS4B,EAAMI,KAAM,IAAAhC,UAAS4B,EAAMI,IAAK,IAAAE,UAASF,KAC3D,EAAI,IARvBF,EAAMC,MAAK,CAACJ,EAAWK,KAAc,IAAAE,UAASP,IAAK,IAAAO,UAASF,IAAM,EAAI,IAWvEF,EAAMnC,SAAQwC,GAAKX,EAAMY,SAAQ,IAAAlC,SAAQ0B,EAAMO,MAExCX,CACP,EAGK,EAAiBrE,IAEtB,IAAIoD,GAAU,IAAAC,MAAKrD,EAAQsD,YAAa,iBACxC,IAAI,IAAAC,YAAWH,GACd,IAAM,OAAwB1B,KAAK8B,OAAM,IAAAC,cAAaL,EAAS,QAAU,CAAE,MAAO,CAInF,GADAA,GAAU,IAAAC,MAAKrD,EAAQsD,YAAa,aAChC,IAAAC,YAAWH,GACd,IAAM,OAAwB1B,KAAK8B,OAAM,IAAAC,cAAaL,EAAS,QAAU,CAAE,MAAO,CAInF,GADAA,GAAU,IAAAC,MAAKrD,EAAQsD,YAAa,iBAChC,IAAAC,YAAWH,GACd,IAAK,OAAwB1B,KAAK8B,OAAM,IAAAC,cAAaL,EAAS,QAAU,CAAE,MAAO,CAGlF,MAAO,CACN8B,GAAI,MACJC,OAAO,EACPC,QAAS,IACTC,QAAS,EACTC,KAAM,IAaN,eChFK,MAmEDC,EAASC,GAAe,IAAIC,SAAQ1C,GAAW2C,WAAW3C,EAASyC,KAGnEG,EAAgBC,MAAOC,IAGzB,IAAIC,EAAI9D,QAAQ+D,OAAOC,MAAOC,EAAS,GACvCjE,QAAQ+D,OAAOC,MAASE,IAAgBD,GAAkBC,GAAU,GACpE,UACUL,GACV,OACOM,GACHC,EAAcD,EAClB,SAEInE,QAAQ+D,OAAOC,MAAQF,CAC3B,CACA,OAAOG,CAAM,EAIXG,EAAgBR,MAAOS,IAIzB,GAAmB,UAAfA,EAAMC,KAAoB,MAAMD,CAAO,EAIzCE,EAAkBX,UAKpB,GAAyB,UAArB5D,QAAQwE,SACZ,CACI,MAAMC,EAAM,EAAQ,KACfA,EAAIC,gBAELD,EAAIC,cAAgB,IAAgB,CAAE,GAAI,IAElD,4KC9GG,MAAMC,EAMTC,YAAY5G,GAJZ,OAAiB,YAEjB,cAAM,IDFS4F,OAAO5F,IAEtB,MAAM6G,OEFV,OAAqB7G,IAEjB,MACM8G,GADQpF,KAAK8B,MAAMxB,QAAQR,IAAIuF,OAAS,MACzBjC,SAAS,iBAc9B,GAZIgC,KAEI9G,EAAQgH,cAAgBhH,EAAQiH,SAASC,SAEzC,EAAQ,IAERlH,EAAQiH,SAASE,kBAEjB,EAAQ,MAIZnH,EAAQK,SAASC,SAEjBN,EAAQK,SAASC,OAAOuB,IAAM7B,EAAQK,SAASC,OAAOuB,KAAOiB,YACxD,IAAAS,aAAW,IAAAF,MAAKrD,EAAQsD,YAAa,oBAAqB,IAAAC,aAAW,IAAAF,MAAKrD,EAAQK,SAASC,OAAOuB,IAAK,kBAC5G,CACI,IAAIuF,EAAatE,UACjB,KAAOsE,EAAWlG,OAAS,KAAM,IAAAqC,aAAW,IAAAF,MAAK+D,EAAY,kBACzDA,GAAa,IAAArE,SAAQqE,EAAY,MAErCpH,EAAQsD,YAAc8D,EACtBpH,EAAQK,SAASC,OAAOuB,IAAMuF,CAClC,CAGJ,MAAO,CACH7G,IAAKuG,QAAc,EAAI9G,QAAW,EAClCqE,MAAO,EAAMrE,GAEpB,EFjCwB,CAAUA,GACzBqH,EAAiBrH,EAAQK,SAASgH,gBAA4C,QAA1BrH,EAAQK,SAASiH,MAAkBtH,EAAQK,SAASC,QAAQ2D,UAAUa,SAAS,QAIzI,GAFAyB,IAEIc,EAEA,IACI,MAAME,GAAqB,IAAAxE,SAAQ/C,EAAQsD,YAAa,eAAgB,mBAAoB,OACtFkE,GAAyB,IAAAzE,SAAQwE,EAAoB,OAAQ,UAC7DE,GAA4B,IAAApE,MAAKmE,EAAwB,aAC/D,IAAAE,cAAaD,GAA2B,IAAApE,MAAKmE,EAAwB,eACrE,IAAAE,eAAa,IAAA3E,SAAQD,UAAW,KAAM,KAAM,MAAO,SAAU,WAAY,OAAQ,YAAa0E,EAClG,OACO,CAGX,IAAIG,EACAC,EAAW,EACf,IAEIA,QAAiB,IAAInC,SAAQ1C,GAAW8D,EAAOxC,MAAMwD,IAAI9E,IAC7D,OACOoD,GAAKwB,EAAaxB,CAAG,CAE5B,GAAIU,EAAOtG,IAEP,UACUgF,EAAkC,EAA5BsB,EAAOxC,MAAMM,MAAMzD,QAC/B2F,EAAOtG,IAAIuH,0BACLvC,EAAkC,GAA5BsB,EAAOxC,MAAMM,MAAMzD,cACzB2F,EAAOtG,IAAIwH,oBACjBlB,EAAOtG,IAAIyH,2BACX7G,QAAQ8G,UAAUtC,EAAckB,EAAOtG,IAAI2H,OAAOnH,KAAK8F,EAAOtG,MAClE,OACO4F,GACHhF,QAAQ8G,IAAI,OACZ9G,QAAQ8G,IAAI,oCACZ9G,QAAQ8G,IAAI,UAAY9B,GACxBhF,QAAQ8G,IAAI,OACZ,UAAYpB,EAAOtG,IAAI4H,iBAAmB,CAAE,MAAO,CACvD,CAGJ,GAAId,EAEA,IACI,MAAMG,GAAyB,IAAAzE,SAAQ/C,EAAQsD,YAAa,eAAgB,mBAAoB,MAAO,OAAQ,WAC/G,IAAAoE,eAAa,IAAArE,MAAKmE,EAAwB,cAAc,IAAAnE,MAAKmE,EAAwB,cACrF,IAAAE,eAAa,IAAA3E,SAAQD,UAAW,KAAM,KAAM,MAAO,SAAU,WAAY,OAAQ,YAAa0E,EAClG,OACO,CAGX,GAAII,EAAW,GAAKD,EACpB,CACI,IAAIS,EAAWT,EAAoEA,EAAWS,QAAlE,GAAGR,MAAY,QAAU,OAAQA,aAI7D,MAHI5F,QAAQR,IAAI6G,+BACZD,EAAU,GAAGA,MAAYpG,QAAQR,IAAI6G,gCAEnC,IAAIC,MAAMF,EACpB,GC7DYP,CAAI3H,OAAOC,OAAOoI,KAAKC,UAAU,EAAAC,EAAA,SAIzCF,KAAKC,SAAW,CACZnI,SAAU,CACNgB,OAAO,EACPf,OAAQ,CAAC,EACT+G,gBAAgB,EAChBC,UAAM,GAEVN,cAAc,EACdpG,eAAgB,OAChBD,WAAY,GACZ2C,YAAa,GACb2D,SAAU,CACNE,kBAAkB,EAClBD,QAAQ,GAEZ9C,UAAW,CACP9D,OAAQ,CAAC,EACTmE,KAAM,GACNH,WAAO,EACPoE,UAAM,GAEVC,SAAS,GAGT3I,IACAuI,KAAKC,SAAWtI,OAAOC,OAAOoI,KAAKC,SAAUxI,GAErD,qNEnCG,MAAM4I,EAQThC,YAAYiC,GANZ,OAAQ,aAAa,GACrB,OAAiB,SACjB,OAAiB,YACjB,OAAiB,YAcjB,0BAAmBC,IAEf,MACMxE,GADQwE,EAAShI,MAAQgI,EAASC,aACpBC,OACdC,EAAWV,KAAKW,YAAY5E,EAAM6E,OAExC,OADqBZ,KAAKa,SAASC,aAAaJ,GAC5BK,YAAY,IAIpC,0BAAkB,CAACR,EAAyBS,KAGxC,MACIjF,GADYiF,EAA0BT,EAASC,YAAzBD,EAAShI,MACjBkI,OACdC,EAAWV,KAAKW,YAAY5E,EAAM6E,OAClCE,EAAed,KAAKa,SAASC,aAAaJ,KAC5CI,EAAaC,aACfD,EAAaG,QAAUC,KAAKC,MAAQnB,KAAKoB,WACzCN,EAAaO,WAAa,GAAGC,KAAKC,MAAMT,EAAaG,QAAU,WAAYH,EAAaG,QAAU,SAC9FjB,KAAKC,SAASuB,oBAAsBxB,KAAKoB,WAAa,IACtD,QAAU,oBAAoBN,EAAaO,cAE/CrB,KAAKoB,WAAa,CAAC,IAIvB,2BAAmB,CAACb,EAAyBS,EAAmBS,KAE5D,MAAMC,EAAUV,GAAYS,EAA6BlB,EAASC,YAAzBD,EAAShI,KAC5CwD,EAAQ2F,EAAMjB,OACdC,EAAWV,KAAKW,YAAY5E,EAAM6E,OAEnCZ,KAAKa,SAASC,aAAaJ,KAE5BV,KAAKa,SAASC,aAAaJ,GAAY,CACnCiB,YAAaT,KAAKC,MAClBS,SAAU7F,EAAM8F,MAAMlJ,OACtBmJ,SAAS,EACTf,cAAe,EACfgB,UAAW/B,KAAKgC,qBAAqBjG,EAAM6E,OAC3CqB,aAAc,EACdC,eAAgB,GAEhBnG,EAAM0E,SACNT,KAAKC,SAASkC,kBAAoBpG,EAAM0E,OAAO2B,OAAOzJ,QAAU,IAIxE,MAAMmI,EAAed,KAAKa,SAASC,aAAaJ,GAC1C2B,EAAWrB,GAAYS,EAEZT,GAAW,EAAIjF,EAAM8F,MAAMlJ,OAD5BoD,EAAM8F,MAAMS,WAAUC,GAAKA,EAAE3B,QAAUc,EAAMd,QAAU2B,EAAEC,aAAeD,EAAEE,aAE1F,IACI,GAAI3B,EAAaC,eAAiBsB,EAC9B,MAAM,IAAItC,MAAM,gCAAgCe,EAAaC,qBAAqBsB,IAE1F,OACOzE,GACHoC,KAAK0C,MAAMC,UAAU/E,EAAG7B,EAAOpE,OAAOC,OAAO,CAAEgL,MAAOP,GAAWX,GACrE,CAGA,OADA1B,KAAKoB,WAAaF,KAAKC,MAChBnB,KAAK0C,MAAMG,mBAAmB,IAIzC,sBAAc,CAACd,EAAmBe,EAAS,KAEnCA,EACOA,EAAS9C,KAAK+C,WAAWhB,EAAUtH,QAAQ,SAAU,KAAKA,QAAQ,SAAU,IAEhFuF,KAAKgD,mBAAmBhD,KAAK+C,WAAWhB,EAAUtH,QAAQ,SAAU,MAAM,GAAMA,QAAQ,MAAO,MAI1G,+BAAwBsH,GAAsBA,EAAUtH,QAAQ,SAAU,MAG1E,OAAQ,cAAa,CAACwI,EAA0BC,IAEvCD,EAGEA,EAAKxI,QAAQ,uBAAwB0I,GAAQA,EAAIC,gBAC5C3I,QAAQ,QAAUyI,EAAqB,GAAN,KAHlC,KAOf,OAAQ,sBAAqB,CAACvF,EAAWuF,KAErC,IAAIG,EAAK,GAWT,OAVI1F,IAEA0F,EAAK1F,EAAE,GAAG2F,WAAWC,cACjB5F,EAAEhF,OAAS,IACX0K,GAAM1F,EAAE6F,UAAU,IAElBN,IACAG,EAAKA,EAAG5I,QAAQ,KAAM,MAGvB4I,CAAE,IAIb,gBAAQhG,MAAOJ,GAAe,IAAIC,SAAQ1C,GAAW2C,WAAW3C,EAASyC,OAGzE,wBAAiBsD,IAEb,MAAMxE,EAAQwE,EAASC,aAAaC,OACpC,GAAI1E,EACJ,CACI,MAAM0H,EAA0B1H,EAAM8F,MAAMnJ,QAAO6J,GAAKA,EAAEC,aAAY7J,OAChE+H,EAAWV,KAAKW,YAAY5E,EAAM6E,OAClCE,EAAed,KAAKa,SAASC,aAAaJ,GAChDV,KAAKa,SAAS6C,cAAgBD,EAC9BzD,KAAKa,SAAS8C,iBAAmB5H,EAAM8F,MAAMnJ,QAAO6J,GAAKA,EAAEE,aAAY9J,OACvEqH,KAAKa,SAAS+C,YACd5D,KAAKa,SAASe,UAAY7F,EAAM8F,MAAMlJ,OAClC8K,EAA0B,EAC1BzD,KAAKa,SAASgD,gBAGd7D,KAAKa,SAASiD,mBAElB9D,KAAKa,SAASC,aAAaJ,GAAY/I,OAAOC,OAAOkJ,EACrD,CACIgB,QAAqC,IAA5B2B,EACTxB,aAAcf,KAAKC,MACnBe,eAAgBuB,GAExB,KA9IAzD,KAAK0C,MAAQpC,EACbN,KAAKC,SAAWK,EAAc7I,QAC9BuI,KAAKa,SAAWP,EAAcyD,OAClC,CAGIC,mBAAiB,OAAO,IAAW,eC1B3C,MAAM,EAA+BxM,QAAQ,YCO7C,IAAIyM,EACAtB,EAGG,MAGDuB,EAAQ7G,MAAM8G,EAAaC,KAEzBA,EAAIC,KAEMD,EAAInB,KAQTmB,EAAIE,MAEQ,MAAbF,EAAInB,MAEJN,GAER,kKCnBG,MAAM4B,EAaTlG,YAAY5G,GDUU,IAAC+M,ECrBvB,OAAQ,YACR,OAAQ,eAAe,GACvB,OAAQ,mBAAkB,GAC1B,OAAQ,yBAER,OAAiB,YACjB,OAAiB,UACjB,OAAiB,YACjB,OAAiB,WAAW,wGAuD5B,uBAAgBzC,GAAyC/B,KAAKa,SAASC,aAAaiB,KAGpF,OAAQ,2BAA0B1E,MAAOoH,EAAoB7C,KAEzD,MAAM8C,EAAOrH,gBACH2C,KAAKC,SAAS0E,MAAMC,iBAAiBH,OAAY,SACjDzE,KAAKC,SAAS0E,MAAMC,iBAAiBH,EAAa,WAAO,SACzDzE,KAAKC,SAAS0E,MAAMC,iBAAiBH,EAAa,gBAAY,SAC9DzE,KAAKC,SAAS0E,MAAMC,iBAAiBH,EAAa,YAAQ,SAC1DzE,KAAKC,SAAS0E,MAAMC,iBAAiBH,EAAa,eAAW,SAC7DzE,KAAKC,SAAS0E,MAAMC,iBAAiBH,EAAa,oBAAgB,EAAU,GAElFzE,KAAKC,SAAS4E,eAAiB7E,KAAKC,SAAS6E,mBAIxC9E,KAAKC,SAAS8E,uCAEQ/E,KAAKC,SAAS0E,MAAMK,cAAsBP,EAAa,WAAY,GAC3E7C,UALb8C,GAQV,IAIJ,OAAQ,iBAAiBO,GAAoBA,GAAWjF,KAAKC,SAASiF,qBAAuB,MAAQ,MAGrG,OAAQ,qBAAqBC,GAKlB,GAHG7D,KAAKC,MAAM4D,EAAc,IAAO,gBAClC7D,KAAKC,MAAM4D,EAAc,IAAO,gBAC/B7D,KAAK8D,MAAMD,EAAc,sBAKtC,OAAQ,eAAc9H,MAAOuD,EAAe6D,EAAoBY,KAE5D,IAAIC,EACAC,EAAYvF,KAAKC,SAASiF,qBAAuB,aAAe,cACpE,MAEIM,EAAU,6CAA6CD,yBAFtBvF,KAAKC,SAAS0E,MAAMK,cAAsBP,EAAa,MAAO,MAG/FgB,EAAU,oCAAoCF,yBAFvBvF,KAAKC,SAAS0E,MAAMK,cAAsBP,EAAa,UAAW,MAGzFiB,EAAS,OAAOC,EAAA,GAAQ/I,MAAMgJ,QAAQD,EAAA,GAAQE,UAAU,MAAOF,EAAA,GAAQG,OAAOC,QAClFR,EAAYvF,KAAKC,SAASiF,qBAAuB,aAAe,cAIxDI,EAHJ1E,EAEIA,EAAMrE,SAAS,WACT,0BAA0BqE,MAAU2E,gBAAwBI,EAAA,GAAQE,UAAUR,EAAgBM,EAAA,GAAQG,OAAOC,QAG/G/F,KAAKa,SAAS+C,UAAY,EACpB,gCAAgChD,OAAW2E,gBAAwBI,EAAA,GAAQE,UAAUR,EAAgBM,EAAA,GAAQG,OAAOC,QAGpH,gCAAgCnF,oBAAwB2E,gBAAwBI,EAAA,GAAQE,UAAUR,EAAgBM,EAAA,GAAQG,OAAOC,QAKzI,sCAAsCR,gBAAwBI,EAAA,GAAQE,UAAUR,EAAgBM,EAAA,GAAQG,OAAOC,QAGzHnN,QAAQ8G,IAAIgG,EAASC,EAAA,GAAQE,UAAUP,EAAKK,EAAA,GAAQG,OAAOE,OAC3DpN,QAAQ8G,IAAIgG,EAASC,EAAA,GAAQE,UAAUL,EAASG,EAAA,GAAQG,OAAOE,OAC/DpN,QAAQ8G,IAAIgG,EAASC,EAAA,GAAQE,UAAUJ,EAASE,EAAA,GAAQG,OAAOE,MAAM,IAKzE,OAAQ,kBAAiB3I,MAAOuD,EAAe6D,EAAoBY,KAE/D,IAAIC,EACAC,EAAYvF,KAAKC,SAASiF,qBAAuB,aAAe,cACpE,MAAMe,QAA+BjG,KAAKC,SAAS0E,MAAMK,cAAsBP,EAAa,MAAO,IAE/Fe,EAAU,6CAA6CD,yBADhCvF,KAAKC,SAAS0E,MAAMK,cAAsBP,EAAa,UAAW,MAEzFyB,EAAU,oCAAoCX,mBAA2BU,IACzEP,EAAS,OAAOC,EAAA,GAAQ/I,MAAMgJ,QAAQD,EAAA,GAAQE,UAAU,MAAOF,EAAA,GAAQG,OAAOK,OAClFZ,EAAYvF,KAAKC,SAASiF,qBAAuB,aAAe,cAIxDI,EAHJ1E,EAEIA,EAAMrE,SAAS,WACT,0BAA0BqE,MAAU2E,gBAAwBI,EAAA,GAAQE,UAAUR,EAAgBM,EAAA,GAAQG,OAAOK,OAG/GnG,KAAKa,SAAS+C,UAAY,EACpB,gCAAgChD,OAAW2E,gBAAwBI,EAAA,GAAQE,UAAUR,EAAgBM,EAAA,GAAQG,OAAOK,OAGpH,gCAAgCvF,oBAAwB2E,gBAAwBI,EAAA,GAAQE,UAAUR,EAAgBM,EAAA,GAAQG,OAAOK,OAKzI,sCAAsCZ,gBAAwBI,EAAA,GAAQE,UAAUR,EAAgBM,EAAA,GAAQG,OAAOC,QAGzHnN,QAAQ8G,IAAIgG,EAASC,EAAA,GAAQE,UAAUP,EAAKK,EAAA,GAAQG,OAAOE,OAC3DpN,QAAQ8G,IAAIgG,EAASC,EAAA,GAAQE,UAAUL,EAASG,EAAA,GAAQG,OAAOE,OAC/DpN,QAAQ8G,IAAIgG,EAASC,EAAA,GAAQE,UAAUK,EAASP,EAAA,GAAQG,OAAOE,MAAM,IAKzE,OAAQ,mBAAkB3I,MAAO+I,EAAkB3B,EAAoBU,EAAqBvD,KAExF,MAAMhB,GAASwF,GAAYA,EAAS7J,SAAS,WAAa,aAAe6J,EAAWA,EAChFd,EAAOK,EAAA,GAAQE,UAAU,MAAOF,EAAA,GAAQG,OAAOO,SACvCV,EAAA,GAAQE,UAAUjF,EAAMwC,cAAeuC,EAAA,GAAQG,OAAOQ,OACtDX,EAAA,GAAQE,UAAU,IAAI7F,KAAKuG,SAAS/C,UAAU,EAAGxD,KAAKuG,SAAS5N,OAASiI,EAAMjI,OAAS,KAAMgN,EAAA,GAAQG,OAAOO,SACxHzN,QAAQ8G,IAAI,OAAOiG,EAAA,GAAQ/I,MAAMgJ,QAAQN,WAEnCtF,KAAKwG,wBAAwB/B,EAAY7C,GAE/C,IAAI6E,QAAwBzG,KAAKC,SAAS0E,MAAMK,cAAsBP,EAAY,GAC1D,IAApBgC,IACAA,EAAkBtB,EAAc,GAEpC,MAAMuB,QAA+B1G,KAAKC,SAAS0E,MAAMK,cAAsB,GAAGP,QAAkB,GACpG,IAAIkC,EAAmBD,EACE,IAArBC,IACAA,EAAmBxB,EAAc,GAGrC,MAAME,EAAiBrF,KAAK4G,kBAAkBzB,GAC9C,GAAIA,EAAc,GAAKA,EAAcsB,QAE3BzG,KAAK6G,YAAYT,EAAU3B,EAAYY,SACvCrF,KAAK8G,yBAAyBrC,EAAYU,EAAaE,EAAgBzD,GAC9C,IAA3B8E,SACM1G,KAAK8G,yBAAyB,GAAGrC,QAAkBU,EAAaE,EAAgBzD,QAE9F,GACSuD,EAAc,IAAMA,EAAcwB,GAA+C,IAA3BD,SAErD1G,KAAK+G,eAAeX,EAAU3B,EAAYY,SAC1CrF,KAAK8G,yBAAyB,GAAGrC,QAAkBU,EAAaE,EAAgBzD,OAG1F,CACI,IAAIoF,QAA2BhH,KAAKC,SAAS0E,MAAMK,cAAsBP,EAAa,MAAO,IACzFwC,QAA4BjH,KAAKC,SAAS0E,MAAMK,cAAsBP,EAAa,UAAW,IAClG,MAAMc,EAAYvF,KAAKC,SAASiF,qBAAuB,aAAe,cAClEgC,EAAO,wBAAwB7B,IAC/B8B,EAAOhC,EAAc,EAAI,mCAAmCI,kBAA0ByB,IAC9D,gEAW5B,GAVKA,UACKhH,KAAK8G,yBAAyBrC,EAAYU,EAAaE,EAAgBzD,GAC7EoF,EAAqB3B,GAEpB4B,UACKjH,KAAK8G,yBAAyB,GAAGrC,QAAkBU,EAAaE,EAAgBzD,GACtFqF,EAAsB5B,GAE1BzM,QAAQ8G,IAAI,OAAOiG,EAAA,GAAQ/I,MAAMgJ,QAAQD,EAAA,GAAQE,UAAUqB,EAAMvB,EAAA,GAAQG,OAAOE,SAChFpN,QAAQ8G,IAAI,OAAOiG,EAAA,GAAQ/I,MAAMgJ,QAAQD,EAAA,GAAQE,UAAUsB,EAAMxB,EAAA,GAAQG,OAAOE,SAC5Eb,EAAc,EAClB,CACI,MAAMiC,EAAO,mCAAmC7B,kBAA0B0B,IAC1ErO,QAAQ8G,IAAI,OAAOiG,EAAA,GAAQ/I,MAAMgJ,QAAQD,EAAA,GAAQE,UAAUuB,EAAMzB,EAAA,GAAQG,OAAOE,QACpF,CACJ,KAIJ,OAAQ,qBAAoB3I,UAExB,MAAMyD,EAAenJ,OAAO0P,OAAOrH,KAAKa,SAASC,cAAcpI,QAAO4O,GAAqB,yBAAhBA,EAAEvF,YAC7E,UAAWwF,KAAezG,EAC1B,CACI,MAAM0G,EAAsC,IAA5BxH,KAAKa,SAAS+C,UAAkB,SAAW,GACvDa,EAAazE,KAAKyH,OAAO9G,YAAY4G,EAAYxF,UAAW/B,KAAK0H,cAAc,uBAAyBF,IAK5G,GAJIxH,KAAKC,SAAS6E,0BACR9E,KAAKwG,wBAAwB/B,EAAYzE,KAAKa,SAASe,gBACvD5B,KAAKwG,wBAAwB,GAAG/B,QAAkBzE,KAAKa,SAASe,WAEtE2F,EAAYtF,cAAgBsF,EAAY5F,YAC5C,CACI,MAAMwD,EAAcoC,EAAYtF,aAAesF,EAAY5F,kBACrD3B,KAAK2H,gBAAgBJ,EAAYxF,UAAW0C,EAAYU,EAAanF,KAAKa,SAASe,SAC7F,CACJ,KAIJ,OAAQ,8BAA6BvE,MAAO8H,IAEpCnF,KAAKC,SAAS6E,0BAER9E,KAAKwG,wBAAwBxG,KAAK0H,cAAc,8BAA+B1H,KAAKa,SAASe,gBAC7F5B,KAAKwG,wBAAwBxG,KAAK0H,cAAc,kCAAmC1H,KAAKa,SAASe,gBACjG5B,KAAKwG,wBAAwBxG,KAAK0H,cAAc,oCAAqC1H,KAAKa,SAASe,gBACnG5B,KAAKwG,wBAAwBxG,KAAK0H,cAAc,qCAAsC1H,KAAKa,SAASe,gBACpG5B,KAAKwG,wBAAwBxG,KAAK0H,cAAc,8BAA+B1H,KAAKa,SAASe,gBAC7F5B,KAAKwG,wBAAwBxG,KAAK0H,cAAc,kCAAmC1H,KAAKa,SAASe,gBACjG5B,KAAKwG,wBAAwBxG,KAAK0H,cAAc,oCAAqC1H,KAAKa,SAASe,gBACnG5B,KAAKwG,wBAAwBxG,KAAK0H,cAAc,qCAAsC1H,KAAKa,SAASe,WAE1G5B,KAAKC,SAAS2H,qBAER5H,KAAK2H,gBAAgB,kBAAmB3H,KAAK0H,cAAc,8BAA+BvC,EAAanF,KAAKa,SAASe,gBACrH5B,KAAK2H,gBAAgB,kBAAmB3H,KAAK0H,cAAc,8BAA+BvC,EAAanF,KAAKa,SAASe,UACvH5B,KAAKC,SAAS4H,yBAER7H,KAAK2H,gBAAgB,uBAAwB3H,KAAK0H,cAAc,kCAAmCvC,EAAanF,KAAKa,SAASe,gBAC9H5B,KAAK2H,gBAAgB,uBAAwB3H,KAAK0H,cAAc,kCAAmCvC,EAAanF,KAAKa,SAASe,WAEpI5B,KAAKC,SAAS6H,iCAER9H,KAAK2H,gBAAgB,gCAAiC3H,KAAK0H,cAAc,oCAAqCvC,EAAanF,KAAKa,SAASe,gBACzI5B,KAAK2H,gBAAgB,gCAAiC3H,KAAK0H,cAAc,oCAAqCvC,EAAanF,KAAKa,SAASe,WAE/I5B,KAAKC,SAAS8H,4BAER/H,KAAK2H,gBAAgB,0BAA2B3H,KAAK0H,cAAc,qCAAsCvC,EAAanF,KAAKa,SAASe,gBACpI5B,KAAK2H,gBAAgB,0BAA2B3H,KAAK0H,cAAc,qCAAsCvC,EAAanF,KAAKa,SAASe,WAElJ,IAIJ,uBAAevE,UAEX,MACM8H,EADejE,KAAKC,MACSnB,KAAKgI,aAClCC,EAA8C,KAAnC,IAAK/G,MAAQgH,oBACxBC,EAAmB,IAAIjH,KAAKA,KAAKC,MAAQ8G,GAAWG,cAAcC,MAAM,GAAI,GAAG5N,QAAQ,IAAK,KAAKA,QAAQ,QAAS,KAaxH,GATIuF,KAAKsI,uBAAyBtI,KAAKuI,WAAYvI,KAAKuI,SAASC,GAAK7C,EAAA,GAAQ/I,MAAMkF,SAChF9B,KAAKyI,iBACL7P,QAAQ8G,IAAI,OAAOiG,EAAA,GAAQ/I,MAAMgJ,QAAQD,EAAA,GAAQE,UAAU,iCAAkC,KAAOG,SDxQxG/B,IAEAxK,QAAQiP,MAAMC,IAAI,WAAYzE,GAC9BD,EAAe2E,QACf3E,OAAiB,GCwQjBrL,QAAQ8G,IAAI,OAAOiG,EAAA,GAAQ/I,MAAMgJ,QAAQD,EAAA,GAAQE,UAAU,kBAAoBsC,EAAiBxC,EAAA,GAAQG,OAAOE,SAC/GpN,QAAQ8G,IAAI,OAAOiG,EAAA,GAAQ/I,MAAMgJ,QAAQD,EAAA,GAAQE,UAAU,iBAAmB7F,KAAK4G,kBAAkBzB,GAAcQ,EAAA,GAAQG,OAAOE,SAE/F,IAA/BhG,KAAKa,SAAS6C,cAAuB1D,KAAKsI,sBAQzC,CACD,MAAMO,EAAU7I,KAAKa,SAAS6C,aAAe,EACzB,cAAc1D,KAAKa,SAAS6C,0DAC5B,kEACpB9K,QAAQ8G,IAAI,OAAOiG,EAAA,GAAQ/I,MAAMgJ,QAAQD,EAAA,GAAQE,UAAUgD,EAASlD,EAAA,GAAQG,OAAOE,QACvF,MAXQhG,KAAKa,SAAS+C,UAAY,UACpB5D,KAAK2H,gBAAgB,GAAI3H,KAAK0H,cAAc,mBAAoBvC,EAAanF,KAAKa,SAASe,gBAC3F5B,KAAK8I,2BAA2B3D,UAEpCnF,KAAK+I,oBASfnQ,QAAQ8G,IAAI,OAAOiG,EAAA,GAAQ/I,MAAMgJ,QAAQD,EAAA,GAAQE,UAAU7F,KAAKuG,SAAUZ,EAAA,GAAQG,OAAOO,WAAW,IAIxG,OAAQ,4BAA2BhJ,MAAO+G,EAAae,EAAqB6D,EAAuBpH,WAEzF5B,KAAKC,SAAS0E,MAAMC,iBAAiBR,EAAKe,SAC1CnF,KAAKC,SAAS0E,MAAMC,iBAAiBR,EAAM,MAAO4E,SAClDhJ,KAAKC,SAAS0E,MAAMC,iBAAiBR,EAAM,WAAYxC,EAAS,IAI1E,oBAAY,CAACqH,EAAuBlN,EAA+BxD,KAE/D,IAAKyH,KAAKsI,sBACV,CACI,MAAMY,EAAUD,aAAgBlJ,MAGhC,GAFAC,KAAKyI,gBAAkC,kBAATQ,EAC9BjJ,KAAKsI,sBAAwB,CAAEvM,MAAOA,EAAO6E,MAAOrI,KAAMA,EAAMqI,MAAOyB,QAAS9J,EAAMqK,OACtD,UAA5B5C,KAAKC,SAASpE,UAClB,CACI,MAAM,QAAEsN,GAAY,EAAQ,KAC5BnJ,KAAKuI,SAAWY,EAChBA,EAAQX,GAAK7C,EAAA,GAAQE,UAAUF,EAAA,GAAQyD,QAAS,KAAOC,MAAS1D,EAAA,GAAQE,UAAU,aAAc,KAAOG,KAC3G,CACA,IAAIzN,EAIA,MAAM,IAAIwH,MAAM,iBAEpB,IALI,QAAU,wCAAwCxH,EAAKqK,MAAQ,+BAKb,IAAlD7G,GAAO8F,MAAMnJ,QAAO6J,GAAKA,EAAEC,aAAY7J,OAEvC,MADAc,QAAQR,IAAI6G,6BAAgCoJ,EAAUD,EAAKpJ,QAAU,GAC/D,IAAIE,MAAM,wBAA0BtG,QAAQR,IAAI6G,6BAM9D,KA5VAE,KAAKa,SAAW,CACZ+C,UAAW,EACXC,cAAe,EACfC,iBAAkB,EAClBlC,SAAU,EACV8B,aAAc,EACdC,gBAAiB,EACjB7C,aAAc,CAAC,GAGnBd,KAAKC,SAAW,CACZ6E,mBAAmB,EACnBD,eAAe,EACfE,iCAAiC,EACjClJ,UAAW,QACXkM,qBAAqB,EACrBF,kBAAkB,EAClBD,cAAc,EACd1C,sBAAsB,EACtB4C,0BAA0B,EAC1B3F,mBAAmB,EACnBX,oBAAoB,EACpBmD,MAAO,CAEHtH,0BAA0BiM,GAAe,EAEzCjM,cAAmB,SAAOiM,IAAuB,IAIzD3R,OAAOC,OAAOoI,KAAKC,SAAUxI,GAAW,CAAC,GAAG,EAAAyI,EAAA,MDtBzBsE,ECwBR,KAAQxE,KAAK2C,WAAU,EAAK,GDtBtCsB,GAAkBxK,QAAQiP,MAAMa,QAEjC5G,EAAY6B,EACZP,EAAiB,kBAAyB,CAAEuF,MAAO/P,QAAQiP,MAAOe,kBAAmB,KACrFhQ,QAAQiP,MAAMgB,YAAW,GACzB,qBAA4BjQ,QAAQiP,MAAOzE,GAC3CxK,QAAQiP,MAAMiB,GAAG,WAAYzF,ICkB7BlE,KAAKgI,aAAe9G,KAAKC,MACzBnB,KAAKyH,OAAS,IAAIpH,EAAmBL,KACzC,CAGI6C,0BAAwB,QAAS7C,KAAKsI,qBAAuB,CAE7D7Q,cAAiC,OAAOuI,KAAKC,QAAU,CAEvDxI,YAAQA,GAAyCuI,KAAKgI,aAAe9G,KAAKC,MAAOxJ,OAAOC,OAAOoI,KAAKC,SAAUxI,EAAU,CAExHsM,cAA0B,OAAO/D,KAAKa,QAAU,CAEhD+I,YAA8B,OAAO5J,KAAKyH,MAAQ,gDCnEnD,MAAMvH,EAAO,KAEhB,MAAM2J,EAAoC,CAAC,EAiB3C,OAhBApQ,QAAQyG,KAAKjG,SAAQ,CAAC6P,EAAKC,EAAKC,KAExBF,EAAIG,WAAW,WAEXD,EAAID,EAAM,KAAOC,EAAID,EAAM,GAAGE,WAAW,OAEzCJ,EAAKK,EAAgBJ,IAAQE,EAAID,EAAM,IACnC,QAAUF,EAAKC,MACfD,EAAKC,GAAOK,SAASH,EAAID,EAAM,GAAI,MAIvCF,EAAKC,IAAO,EAEpB,QACD,GACID,CAAI,EAITK,EAAmBjH,GAEdA,EACNxI,QAAQ,uBAAuB,CAAC2P,EAAQxH,IACpB,IAAVA,EAAcwH,EAAO7G,cAAgB6G,EAAOhH,gBAEtD3I,QAAQ,WAAY,uNCKlB,MAAMqL,EAAS,IAjBtB,oBAEI,cAAiB,CAAE,EAAG,KACtB,gBAAmB,CAAE,EAAG,KACxB,mBAAsB,CAAE,EAAG,KAC3B,iBAAoB,CAAE,EAAG,KACzB,eAAkB,CAAE,GAAI,KACxB,cAAiB,CAAE,GAAI,KACvB,eAAkB,CAAE,GAAI,KACxB,cAAiB,CAAE,GAAI,KACvB,cAAiB,CAAE,GAAI,KACvB,eAAkB,CAAE,GAAI,KACxB,iBAAoB,CAAE,GAAI,KAC1B,aAAgB,CAAE,GAAI,KACtB,gBAAmB,CAAE,GAAI,IAAG,GAKnBD,EAAY,CAACP,EAAa1I,IAAoB,KAAUA,EAAM,GAAK,IAAM0I,EAAM,KAAU1I,EAAM,GAAK,IAEpG+I,EAAU,CACnBG,SACAD,YACA/D,QAAS,IACT8D,KAAM,IACTyE,QAAS,IACTvM,MAAO,IACPsL,QAAS,IACTkB,MAAO,IACPC,IAAK,IACLC,OAAQ,IACRC,KAAM,IACNC,WAAY,IACZC,YAAa,IACbC,aAAc,IACdC,OAAQ,IACLC,GAAI,IACJlO,MACA,CACIkF,QAAS+D,EAAU,IAAKC,EAAOiF,OAC/BC,YAAanF,EAAU,IAAKC,EAAOuD,MACnCzD,KAAMC,EAAU,IAAKC,EAAOO,SAC5B4E,SAAUpF,EAAU,IAAKC,EAAOuD,MAChCgB,QAASxE,EAAU,IAAKC,EAAOoF,QAC/BC,aAActF,EAAU,IAAKC,EAAOuD,MACpCvL,MAAO+H,EAAU,IAAKC,EAAOK,KAC7BiF,WAAYvF,EAAU,IAAKC,EAAOuD,MAClCiB,MAAOzE,EAAU,IAAKC,EAAOiF,OAC7BR,IAAK1E,EAAU,IAAKC,EAAOiF,OAC3B3B,QAASvD,EAAU,IAAKC,EAAOE,MAC/B8E,GAAIjF,EAAU,IAAKC,EAAOiF,2FCpE3B,MAAMM,EAAa/D,IAAYgE,MAAMC,WAAWjE,KAAOkE,SAASlE,GAG1DmE,EAAY,CAAC9N,EAAW+N,IAA2C,IAAdA,EAAyB/N,EAAI,IAAYA,EAG9FX,EAAQK,MAAOJ,GAAe,IAAIC,SAAQ1C,GAAW2C,WAAW3C,EAASyC,KAGzE0O,EAAY,CAACrG,EAAcsG,EAAeC,EAAM,KACzDjT,QAAQ8G,IAAI,OAAOmM,IAAMD,GAAQ,KAAQhP,MAAMgJ,OAAON,EAAM,IAAM,KAAQO,UAAUP,EAAK,KAAQQ,OAAOE,MAAQ,MAGvG8F,EAAmB,KAG5BlT,QAAQ8G,IAAI,OAAO,KAAQ9C,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAC1H,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YACtH,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YACtH,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YACtH,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,WACrIlJ,QAAQ8G,IAAI,OAAO,KAAQ9C,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAChG,KAAQlF,MAAMkO,OAAO,KAAQjF,UAAU,8CAA+C,KAAQC,OAAOiF,WACrG,KAAQnO,MAAMkO,OAAO,KAAQlO,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,WAChIlJ,QAAQ8G,IAAI,OAAO,KAAQ9C,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAC1H,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YACtH,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YACtH,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YACtH,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,YAAY,KAAQlF,MAAMkF,UAAU,WCpCnJiK,EAAOC,QAAUxU,QAAQ,qCCAzBuU,EAAOC,QAAUxU,QAAQ,yBCAzBuU,EAAOC,QAAUxU,QAAQ,wCCAzBuU,EAAOC,QAAUxU,QAAQ,sBCAzBuU,EAAOC,QAAUxU,QAAQ,4BCAzBuU,EAAOC,QAAUxU,QAAQ,eCAzBuU,EAAOC,QAAUxU,QAAQ,SCCrByU,EAA2B,CAAC,EAGhC,SAASC,EAAoBC,GAE5B,IAAIC,EAAeH,EAAyBE,GAC5C,QAAqBE,IAAjBD,EACH,OAAOA,EAAaJ,QAGrB,IAAID,EAASE,EAAyBE,GAAY,CACjDG,GAAIH,EACJI,QAAQ,EACRP,QAAS,CAAC,GAUX,OANAQ,EAAoBL,GAAUJ,EAAQA,EAAOC,QAASE,GAGtDH,EAAOQ,QAAS,EAGTR,EAAOC,OACf,CAGAE,EAAoBO,EAAID,EAGxBN,EAAoBQ,EAAIT,EC9BxBC,EAAoBS,EAAKZ,IACxB,IAAIa,EAASb,GAAUA,EAAOc,WAC7B,IAAOd,EAAiB,QACxB,IAAM,EAEP,OADAG,EAAoBY,EAAEF,EAAQ,CAAE3Q,EAAG2Q,IAC5BA,CAAM,ECLdV,EAAoBY,EAAI,CAACd,EAASe,KACjC,IAAI,IAAI3I,KAAO2I,EACXb,EAAoBc,EAAED,EAAY3I,KAAS8H,EAAoBc,EAAEhB,EAAS5H,IAC5EzM,OAAOsV,eAAejB,EAAS5H,EAAK,CAAE8I,YAAY,EAAMC,IAAKJ,EAAW3I,IAE1E,ECND8H,EAAoBzP,EAAI,CAAC,EAGzByP,EAAoBtO,EAAKwP,GACjBlQ,QAAQ/C,IAAIxC,OAAOc,KAAKyT,EAAoBzP,GAAG4Q,QAAO,CAACC,EAAUlJ,KACvE8H,EAAoBzP,EAAE2H,GAAKgJ,EAASE,GAC7BA,IACL,KCNJpB,EAAoBqB,EAAKH,IAER,ECHjBlB,EAAoBc,EAAI,CAACQ,EAAKC,IAAU9V,OAAO+V,UAAUC,eAAeC,KAAKJ,EAAKC,GCClFvB,EAAoB2B,EAAK7B,IACH,oBAAX8B,QAA0BA,OAAOC,aAC1CpW,OAAOsV,eAAejB,EAAS8B,OAAOC,YAAa,CAAEC,MAAO,WAE7DrW,OAAOsV,eAAejB,EAAS,aAAc,CAAEgC,OAAO,GAAO,ECL9D9B,EAAoB+B,EAAI,CAACC,EAAQC,EAAU7Q,KAE1C,IAAI6O,EAAWgC,EACX7Q,IAAI6Q,EAAWD,EAAQ5Q,EAAK,IAAO4O,EAAoBA,EAAoBvO,EAAIwO,IACnFgC,EAASrU,IAAIoS,EAAoBtO,EAAGsO,GACpC,IAAI2B,EAAIvQ,IACR,YAAa+O,IAANwB,EAAkBK,EAASL,CAAC,EjCFhCvW,EAAkB,CACrB,IAAK,GAKFC,EAAgB6W,IACnB,IAAIC,EAAcD,EAAME,QAASH,EAAWC,EAAMG,IAAKC,EAAUJ,EAAMI,QACvE,IAAI,IAAIrC,KAAYkC,EAChBnC,EAAoBc,EAAEqB,EAAalC,KACrCD,EAAoBO,EAAEN,GAAYkC,EAAYlC,IAG7CqC,GAASA,EAAQtC,GACpB,IAAI,IAAIuC,EAAI,EAAGA,EAAIN,EAASxV,OAAQ8V,IACnCnX,EAAgB6W,EAASM,IAAM,CAAC,EAKlCvC,EAAoBzP,EAAEjF,QAAU,CAAC4V,EAASE,KAErChW,EAAgB8V,IAElB7V,EAAaC,QAAQ,KAAO0U,EAAoBqB,EAAEH,IAEpD,EAGDrB,OAAOC,QAAUE,EACjBA,EAAoBwC,EAAInX,EkC/BxB,IAAIoX,EAAsBzC,EAAoB","sources":["webpack/runtime/require_chunk_loading","external_commonjs_nyc","external_commonjs_resolve-from","external_node-commonjs_fs","external_node-commonjs_path","C:\\Projects\\@spmeesseman\\test-utils\\src\\runner\\nyc.ts","external_commonjs_glob","external_commonjs_mocha","C:\\Projects\\@spmeesseman\\test-utils\\src\\runner\\mocha.ts","C:\\Projects\\@spmeesseman\\test-utils\\src\\runner\\run.ts","C:\\Projects\\@spmeesseman\\test-utils\\src\\runner\\index.ts","C:\\Projects\\@spmeesseman\\test-utils\\src\\runner\\config.ts","C:\\Projects\\@spmeesseman\\test-utils\\src\\tracker\\utils.ts","external_node-commonjs_readline","C:\\Projects\\@spmeesseman\\test-utils\\src\\utils\\input.ts","C:\\Projects\\@spmeesseman\\test-utils\\src\\tracker\\index.ts","C:\\Projects\\@spmeesseman\\test-utils\\src\\utils\\argv.ts","C:\\Projects\\@spmeesseman\\test-utils\\src\\utils\\figures.ts","C:\\Projects\\@spmeesseman\\test-utils\\src\\utils\\utils.ts","external_commonjs_mocha/lib/reporters/base","external_commonjs_node-preload","external_commonjs_source-map-support/register","external_commonjs_spawn-wrap","external_commonjs_ts-node/register","external_node-commonjs_os","external_node-commonjs_tty","webpack/bootstrap","webpack/runtime/compat_get_default_export","webpack/runtime/define_property_getters","webpack/runtime/ensure_chunk","webpack/runtime/get_javascript_chunk_filename","webpack/runtime/hasOwnProperty_shorthand","webpack/runtime/make_namespace_object","webpack/runtime/startup_entrypoint","webpack/startup"],"sourcesContent":["// no baseURI\n\n// object to store loaded chunks\n// \"1\" means \"loaded\", otherwise not loaded yet\nvar installedChunks = {\n\t924: 1\n};\n\n// no on chunks loaded\n\nvar installChunk = (chunk) => {\n\tvar moreModules = chunk.modules, chunkIds = chunk.ids, runtime = chunk.runtime;\n\tfor(var moduleId in moreModules) {\n\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t}\n\t}\n\tif(runtime) runtime(__webpack_require__);\n\tfor(var i = 0; i < chunkIds.length; i++)\n\t\tinstalledChunks[chunkIds[i]] = 1;\n\n};\n\n// require() chunk loading for javascript\n__webpack_require__.f.require = (chunkId, promises) => {\n\t// \"1\" is the signal for \"already loaded\"\n\tif(!installedChunks[chunkId]) {\n\t\tif(true) { // all chunks have JS\n\t\t\tinstallChunk(require(\"./\" + __webpack_require__.u(chunkId)));\n\t\t} else installedChunks[chunkId] = 1;\n\t}\n};\n\nmodule.exports = __webpack_require__;\n__webpack_require__.C = installChunk;\n\n// no HMR\n\n// no HMR manifest","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"nyc\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"resolve-from\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"fs\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"path\");","/* eslint-disable import/no-extraneous-dependencies */\r\n/* eslint-disable @typescript-eslint/naming-convention */\r\n\r\n/**\r\n * @module testutils.runner.nyc\r\n */\r\n\r\nimport NYC from \"nyc\";\r\nimport resolveFrom from \"resolve-from\";\r\nimport { existsSync, readFileSync } from \"fs\";\r\nimport { join, relative, resolve } from \"path\";\r\nimport { ITestCoverageToolConfig, ITestRunOptions } from \"../interface/index.js\";\r\n\r\nconst modules: Record<string,string | null> = {};\r\n\r\n\r\nexport default async(options: ITestRunOptions) =>\r\n{\r\n    const nycConfig = Object.assign({}, defaultConfig(options), options.coverage.config);\r\n\t//\r\n\t// Instantiate an NYC instance and wrap the current running extension host process. This\r\n\t// differs a bit from the way nyc is normally used on the command line.  Iafb&Iwmbb:(\r\n\t//\r\n\tconst nyc = new NYC(nycConfig);\r\n\tnyc.wrap();\r\n\t//\r\n\t// Check the modules already loaded and warn in case of race condition\r\n\t// (ideally, at this point the require cache should only contain one file - this module (& helper imports)\r\n\t//\r\n\tconst myFilesRegex = new RegExp(`${options.moduleName}[\\\\/\\\\\\\\]${options.moduleBuildDir}[\\\\/\\\\\\\\]`),\r\n\t\t  filterFn = myFilesRegex.test.bind(myFilesRegex),\r\n\t\t  moduleCountShouldBe = 5;\r\n\tif (Object.keys(require.cache).filter(filterFn).length > moduleCountShouldBe)\r\n\t{\r\n\t\tconsole.warn(\"NYC initialized after modules were loaded\", Object.keys(require.cache).filter(filterFn));\r\n\t}\r\n\t//\r\n\t// Debug which files will be included/excluded\r\n\t// console.log('Glob verification', await nyc.exclude.glob(nyc.cwd));\r\n\t//\r\n\tif (!options.coverage.clean)\r\n\t{\r\n\t\tawait nyc.createTempDirectory();\r\n\t}\r\n\telse {\r\n\t\ttry {\r\n\t\t\tawait nyc.reset();\r\n\t\t}\r\n\t\tcatch {\r\n\t\t\tawait nyc.createTempDirectory();\r\n\t\t}\r\n\t}\r\n\t//\r\n\t// Prepare environment for spawned processes\r\n\t//\r\n\tconst env: any = {\r\n\t\tNYC_CONFIG: JSON.stringify(nycConfig),\r\n\t\tNYC_CWD: nycConfig.cwd\r\n\t};\r\n   \t//\r\n\t// Babel's cache interferes with some configurations, so is disabled by default, it\r\n\t// can be re-enabled with the configuration babelCache=`false`.  Iafb&Iwmbb:(\r\n\t//\r\n\tif (nycConfig.babelCache === false)\r\n\t{\r\n\t\tenv.BABEL_DISABLE_CACHE = process.env.BABEL_DISABLE_CACHE = \"1\";\r\n\t}\r\n\t//\r\n\t// Initialize nyc environment vars and process wrap if not using the spawn-wrap option\r\n\t//\r\n\tif (!nycConfig.useSpawnWrap)\r\n\t{\r\n\t\t// const nycLibPath = join(nyc.cwd, \"node_modules\", \"nyc\", \"lib\");\r\n\t\t// const nycLibPath = relative(__dirname, resolve(options.projectRoot, \"node_modules\", \"nyc\", \"lib\")).replace(/\\\\/g, \"/\");\r\n\t\t// const nycLibPath = join(options.projectRoot, \"node_modules\", \"nyc\", \"lib\");\r\n\t\tconst requireModules = [\r\n\t\t\t// join(nycLibPath, \"register-env.js\"),\r\n\t\t\t// require.resolve(`${nycLibPath}/register-env.js`)\r\n\t\t\t____require.resolve____(\"nyc/lib/register-env\"),\r\n\t\t\t...nyc.require.map((mod: string) => resolveFrom.silent(nyc.cwd, mod) || mod)\r\n\t\t];\r\n\t\t// eslint-disable-next-line import/no-extraneous-dependencies\r\n\t\tconst preloadList = require(\"node-preload\");\r\n\t\tpreloadList.push(\r\n\t\t\t...requireModules,\r\n\t\t\t// join(nycLibPath, \"wrap.js\")\r\n\t\t\t// require.resolve(`${nycLibPath}/wrap.js`)\r\n\t\t\t____require.resolve____(\"nyc/lib/wrap\")\r\n\t\t);\r\n\t\tObject.assign(process.env, env);\r\n\t\trequireModules.forEach(mod => { ____require____(mod); });\r\n\t}\r\n\t//\r\n\t// Call addAllFiles() AFTER importing register-env module (if (!nycConfig.useSpawnWrap))\r\n\t//\r\n\tif (nycConfig.all)\r\n\t{\r\n\t\tawait nyc.addAllFiles();\r\n\t}\r\n\t//\r\n\t// Initialize spawn-wrap module if required\r\n\t//\r\n\tif (nycConfig.useSpawnWrap)\r\n\t{   //\r\n\t\t// This is where we are failing now in our efforts to wrap the server spawn for coverage.\r\n\t\t// The vscode-languageclient module files to launch the server when these final lines are\r\n\t\t// enabled.  For now, we just use the nyc.wrap() like we always have, so that at least the\r\n\t\t// client process is wrapped when the bootstrap-fork starts it's thing in the VSCode engine.\r\n\t\t//\r\n\t\t// TODO - ^^^ Next try is to build a mocha command line instead of instantisting an instance\r\n\t\t//        programatically, and use foreground() in indext.ts to launch it.  THis would pretty\r\n\t\t//        much replicate how nyc/bin/nyc.js works.\r\n\t\t//\r\n\t\t// UPDATE 6/22/23 - Have language client and  server FINALLY covered by same test suites,\r\n\t\t//                  \"without\" using useSpawnWrap.  Key was to use a node runtime to directly\r\n\t\t//                  spawn the server, as opposed to the default fork.  Only took 3 years to\r\n\t\t//                  figure that out. Or 4 years?  Iafb&Iwmbb:(\r\n\t\t//                  > See: file:///c:/Projects/vscode-extjs/client/src/lib/language/client.ts\r\n\t\t//\r\n\t\tconst sw = require(\"spawn-wrap\"),\r\n\t\t\t  nycBinPath = relative(__dirname, resolve(nyc.cwd, \"node_modules\", \"nyc\", \"bin\")).replace(/\\\\/g, \"/\");\r\n\t\tsw.runMain();\r\n\t\tenv.SPAWN_WRAP_SHIM_ROOT = process.env.SPAWN_WRAP_SHIM_ROOT || process.env.XDG_CACHE_HOME || require(\"os\").homedir();\r\n\t\tsw([ ____require.resolve____(\"nyc/bin/wrap.js\") ], env);\r\n\t}\r\n\r\n\treturn nyc;\r\n};\r\n\r\n\r\n// const nycLibRequire = (moduleName: string) =>\r\n// {\r\n//     if (modules[moduleName] === undefined)\r\n// \t{;\r\n//         try {\r\n//             require(\"../../node_modules/nyc/lib/\" + moduleName);\r\n//         }\r\n// \t\tcatch { modules[moduleName] = null; }\r\n//     }\r\n//     return modules[moduleName];\r\n// }\r\n\r\n\r\nconst defaultConfig = (options: ITestRunOptions): Partial<ITestCoverageToolConfig> =>\r\n{\r\n\tlet cfgFile = join(options.projectRoot, \".nycrc.json\");\r\n\tif (existsSync(cfgFile)) {\r\n\t\ttry { return <ITestCoverageToolConfig>JSON.parse(readFileSync(cfgFile, \"utf8\")); } catch {}\r\n\t}\r\n\r\n\tcfgFile = join(options.projectRoot, \".nycrc\");\r\n\tif (existsSync(cfgFile)) {\r\n\t\ttry { return <ITestCoverageToolConfig>JSON.parse(readFileSync(cfgFile, \"utf8\")); } catch {}\r\n\t}\r\n\r\n\tcfgFile = join(options.projectRoot, \"nycrc.json\");\r\n\tif (existsSync(cfgFile)) {\r\n\t\ttry { return <ITestCoverageToolConfig>JSON.parse(readFileSync(cfgFile, \"utf8\")); } catch {}\r\n\t}\r\n\r\n\treturn {\r\n\t\textends: \"@istanbuljs/nyc-config-typescript\",\r\n\t\tcwd: options.projectRoot,\r\n\t\thookRequire: true,\r\n\t\thookRunInContext: true,\r\n\t\thookRunInThisContext: true,\r\n\t\tinstrument: true,\r\n\t\treportDir: \"./.coverage\",\r\n\t\tsilent: false,\r\n\t\treporter: [ \"text-summary\", \"html\" ],\r\n\t\tinclude: [ \"dist/**/*.js\" ],\r\n\t\texclude: [ \"dist/**/test/**\", \"node_modules/**\" ]\r\n\t};\r\n};\r\n\r\n","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"glob\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"mocha\");","/* eslint-disable import/no-extraneous-dependencies */\r\n\r\nimport * as glob from \"glob\";\r\nimport Mocha, { MochaOptions } from \"mocha\";\r\nimport { existsSync, readFileSync } from \"fs\";\r\nimport { basename, join, relative, resolve } from \"path\";\r\nimport { ITestRunOptions, ITestToolConfig } from \"../interface/index.js\";\r\n\r\n/**\r\n * @module testutils.runner.mocha\r\n */\r\n\r\nexport default (options: ITestRunOptions) =>\r\n{\r\n\tconst config: MochaOptions = Object.assign({}, defaultConfig(options), <Readonly<MochaOptions>>options.framework.config),\r\n\t\t  mocha = new Mocha(config),\r\n\t\t  suite = options.framework.suite;\r\n\r\n\tlet filesToTest = \"**/*.{spec,test}.js\";\r\n\tif (suite && suite.length > 0)\r\n\t{\r\n\t\tfilesToTest = (suite.length > 1 ? \"{\" : \"\");\r\n\t\tsuite.forEach((a: string) =>\r\n\t\t{\r\n\t\t\tif (filesToTest.length > 1) {\r\n\t\t\t\tfilesToTest += \",\";\r\n\t\t\t}\r\n\t\t\tfilesToTest += `**/${a}.{spec,test}.js`;\r\n\t\t});\r\n\t\tfilesToTest += (suite.length > 1 ? \"}\" : \"\");\r\n\t}\r\n\r\n\t//\r\n\t// Add all files to the test suite\r\n\t//\r\n\tconst root = <string>options.framework.root,\r\n\t\t  sortGroup = options.framework.sortGroup,\r\n\t\t  files = glob.sync(filesToTest, { cwd: options.framework.root });\r\n\tif (!sortGroup)\r\n\t{\r\n\t\tfiles.sort((a: string, b: string) => basename(a) < basename(b) ? -1 : 1);\r\n\t}\r\n\telse\r\n\t{\r\n\t\tfiles.sort((a: string, b: string) =>\r\n\t\t{\r\n\t\t\tconst pA = sortGroup.includes(relative(root, a)) ? relative(root, a) : basename(a),\r\n\t\t\t\t  pB = sortGroup.includes(relative(root, b)) ? relative(root, b) : basename(b);\r\n\t\t\treturn pA < pB ? -1 : 1;\r\n\t\t});\r\n\t}\r\n\tfiles.forEach(f => mocha.addFile(resolve(root, f)));\r\n\r\n\treturn mocha;\r\n};\r\n\r\n\r\nconst defaultConfig = (options: ITestRunOptions): Partial<ITestToolConfig> =>\r\n{\r\n\tlet cfgFile = join(options.projectRoot, \".mocharc.json\");\r\n\tif (existsSync(cfgFile)) {\r\n\t\ttry { return <ITestToolConfig>JSON.parse(readFileSync(cfgFile, \"utf8\")); } catch {}\r\n\t}\r\n\r\n\tcfgFile = join(options.projectRoot, \".mocharc\");\r\n\tif (existsSync(cfgFile)) {\r\n\t\ttry { return <ITestToolConfig>JSON.parse(readFileSync(cfgFile, \"utf8\")); } catch {}\r\n\t}\r\n\r\n\tcfgFile = join(options.projectRoot, \"mocharc.json\");\r\n\tif (existsSync(cfgFile)) {\r\n\t\ttry {return <ITestToolConfig>JSON.parse(readFileSync(cfgFile, \"utf8\")); } catch {}\r\n\t}\r\n\r\n\treturn {\r\n\t\tui: \"tdd\",      // the TDD UI\r\n\t\tcolor: true,    // colored output from test results,\r\n\t\ttimeout: 30000, // default timeout: 10 seconds\r\n\t\tretries: 0,\r\n\t\tslow: 250\r\n\t\t// require: [\r\n\t\t//     \"ts-node/register\",\r\n\t\t//     \"source-map-support/register\"\r\n\t\t// ]\r\n\t\t// reporter: \"mocha-multi-reporters\",\r\n\t\t// reporterOptions: {\r\n\t\t//     reporterEnabled: \"spec, mocha-junit-reporter\",\r\n\t\t//     mochaJunitReporterReporterOptions: {\r\n\t\t//         mochaFile: __dirname + \"/../../coverage/junit/extension_tests.xml\",\r\n\t\t//         suiteTitleSeparatedBy: \": \"\r\n\t\t//     }\r\n\t\t// }\r\n\t};\r\n};\r\n","\r\n/**\r\n * @module testutils.runner.run\r\n */\r\n\r\nimport runConfig from \"./config.js\";\r\nimport { pluralize } from \"../utils/utils.js\";\r\nimport { ITestRunOptions } from \"../interface/index.js\";\r\nimport { copyFileSync } from \"fs\";\r\nimport { join, resolve } from \"path\";\r\n\r\n\r\nexport const run = async (options: ITestRunOptions): Promise<void> =>\r\n{\r\n    const runCfg = await runConfig(options), // JSON.parse(process.env.testUtilOptions || \"{}\"));\r\n          htmlReportDark = options.coverage.htmlReportDark && options.coverage.tool === \"nyc\" && options.coverage.config?.reporter?.includes(\"html\");\r\n\r\n    preparePlatform();\r\n\r\n    if (htmlReportDark)\r\n    {\r\n        try {\r\n            const istanbulReportPath = resolve(options.projectRoot, \"node_modules\", \"istanbul-reports\", \"lib\"),\r\n                  istanbulHtmlReportPath = resolve(istanbulReportPath, \"html\", \"assets\"),\r\n                  istanbulHtmlReportCssFile = join(istanbulHtmlReportPath, \"base.css\");\r\n            copyFileSync(istanbulHtmlReportCssFile, join(istanbulHtmlReportPath, \"_base.css\"));\r\n            copyFileSync(resolve(__dirname, \"..\", \"..\", \"res\", \"runner\", \"istanbul\", \"html\", \"base.css\"), istanbulHtmlReportPath);\r\n        }\r\n        catch {}\r\n    }\r\n\r\n    let mochaError: Error | undefined,\r\n        failures = 0;\r\n    try {\r\n        // failures = await new Promise(async (resolve => foreground(childArgs, resolve));\r\n        failures = await new Promise(resolve => runCfg.mocha.run(resolve));\r\n    }\r\n    catch (e) { mochaError = e; }\r\n\r\n    if (runCfg.nyc)\r\n    {\r\n        try {\r\n            await sleep(runCfg.mocha.files.length * 5);\r\n            runCfg.nyc.writeCoverageFile();\r\n            await sleep(runCfg.mocha.files.length * 20);\r\n            await runCfg.nyc.writeProcessIndex();\r\n            runCfg.nyc.maybePurgeSourceMapCache();\r\n            console.log(await captureStdout(runCfg.nyc.report.bind(runCfg.nyc)));\r\n        }\r\n        catch (e) {\r\n            console.log(\"!!!\");\r\n            console.log(\"!!! Error writing coverage file:\");\r\n            console.log(\"!!!    \" + e);\r\n            console.log(\"!!!\");\r\n            try { await runCfg.nyc.showProcessTree(); } catch {}\r\n        }\r\n    }\r\n\r\n    if (htmlReportDark)\r\n    {\r\n        try {\r\n            const istanbulHtmlReportPath = resolve(options.projectRoot, \"node_modules\", \"istanbul-reports\", \"lib\", \"html\", \"assets\");\r\n            copyFileSync(join(istanbulHtmlReportPath, \"_base.css\"), join(istanbulHtmlReportPath, \"base.css\"));\r\n            copyFileSync(resolve(__dirname, \"..\", \"..\", \"res\", \"runner\", \"istanbul\", \"html\", \"base.css\"), istanbulHtmlReportPath);\r\n        }\r\n        catch {}\r\n    }\r\n\r\n    if (failures > 0 || mochaError)\r\n    {\r\n        let message = !mochaError ? `${failures} ${pluralize(\"test\", failures)} failed.` : mochaError.message;\r\n        if (process.env.TEST_UTILS_FAILURE_EXCEPTION) {\r\n            message = `${message}\\n${process.env.TEST_UTILS_FAILURE_EXCEPTION}`;\r\n        }\r\n        throw new Error(message);\r\n    }\r\n};\r\n\r\n\r\nconst sleep = (ms: number) => new Promise(resolve => setTimeout(resolve, ms));\r\n\r\n\r\nconst captureStdout = async (fn: any) =>\r\n{\r\n    // eslint-disable-next-line prefer-const\r\n    let w = process.stdout.write, buffer = \"\";\r\n    process.stdout.write = (s: string) => { buffer = buffer + s; return true; };\r\n    try {\r\n        await fn();\r\n    }\r\n    catch (e) {\r\n        suppressEPIPE(e);\r\n    }\r\n    finally {\r\n        process.stdout.write = w;\r\n    }\r\n    return buffer;\r\n};\r\n\r\n\r\nconst suppressEPIPE = async (error: any) =>\r\n{   //\r\n    // Prevent dumping error when `nyc npm t|head` causes stdout to be closed when reporting runs\r\n    //\r\n    if (error.code !== \"EPIPE\") { throw error; }\r\n};\r\n\r\n\r\nconst preparePlatform = async () =>\r\n{   //\r\n    // Linux: prevent a weird NPE when mocha on Linux requires the window size from the TTY\r\n    // Since we are not running in a tty environment, we just implement he method statically\r\n    //\r\n    if (process.platform === \"linux\")\r\n    {\r\n        const tty = require(\"tty\");\r\n        if (!tty.getWindowSize)\r\n        {\r\n            tty.getWindowSize = (): number[] => [ 80, 75 ];\r\n        }\r\n    }\r\n};\r\n","\r\n/**\r\n * @module testutils.runner.testrunner\r\n */\r\n\r\nimport { run } from \"./run.js\";\r\nimport { argv } from \"../utils/argv.js\";\r\nimport { ITestRunOptions } from \"../interface/index.js\";\r\n\r\n\r\nexport class TestRunner\r\n{\r\n    private readonly _options: ITestRunOptions;\r\n\r\n    run = () => run(Object.assign(this._options, argv()));\r\n\r\n    constructor(options: Partial<ITestRunOptions>)\r\n    {\r\n        this._options = {\r\n            coverage: {\r\n                clean: false,\r\n                config: {},\r\n                htmlReportDark: false,\r\n                tool: undefined\r\n            },\r\n            isTypescript: false,\r\n            moduleBuildDir: \"dist\",\r\n            moduleName: \"\",\r\n            projectRoot: \"\",\r\n            register: {\r\n                sourceMapSupport: true,\r\n                tsNode: false\r\n            },\r\n            framework: {\r\n                config: {},\r\n                root: \"\",\r\n                suite: undefined,\r\n                type: undefined\r\n            },\r\n            verbose: false\r\n        };\r\n\r\n        if (options) {\r\n            this._options = Object.assign(this._options, options);\r\n        }\r\n    }\r\n\r\n}\r\n","/* eslint-disable import/no-extraneous-dependencies */\r\n\r\n/**\r\n * @module testutils.runner.config\r\n */\r\n\r\nimport Nyc from \"./nyc.js\";\r\nimport Mocha from \"./mocha.js\";\r\nimport { existsSync } from \"fs\";\r\nimport { join, resolve } from \"path\";\r\nimport { ITestRunOptions } from \"../interface/index.js\";\r\n\r\nexport default async(options: ITestRunOptions) =>\r\n{\r\n    const xArgs = JSON.parse(process.env.xArgs || \"[]\"),\r\n          cover = !xArgs.includes(\"--no-coverage\");\r\n\r\n    if (cover)\r\n    {\r\n        if (options.isTypescript || options.register.tsNode)\r\n        {\r\n            require(\"ts-node/register\");\r\n        }\r\n        if (options.register.sourceMapSupport)\r\n        {\r\n            require(\"source-map-support/register\");\r\n        }\r\n    }\r\n\r\n    if (options.coverage.config)\r\n    {\r\n        options.coverage.config.cwd = options.coverage.config.cwd || __dirname;\r\n        if (!existsSync(join(options.projectRoot, \"package.json\")) || !existsSync(join(options.coverage.config.cwd, \"package.json\")))\r\n        {\r\n            let projectDir = __dirname;\r\n            while (projectDir.length > 3 && !existsSync(join(projectDir, \"package.json\"))) {\r\n                projectDir = resolve(projectDir, \"..\");\r\n            }\r\n            options.projectRoot = projectDir;\r\n            options.coverage.config.cwd = projectDir;\r\n        }\r\n    }\r\n\r\n    return {\r\n        nyc: cover ? await Nyc(options) : undefined,\r\n        mocha: Mocha(options)\r\n    };\r\n};\r\n","\r\n/**\r\n * @module testutils.tracker.utils\r\n */\r\n\r\nimport { writeInfo } from \"../utils/utils.js\";\r\nimport { TestTracker } from \"../tracker/index.js\";\r\nimport { ITestTrackerOptions, ITestResults } from \"../interface/index.js\";\r\n\r\n\r\nexport class TestUtilsUtilities\r\n{\r\n    private _testTimer = 0;\r\n    private readonly _inst: TestTracker;\r\n    private readonly _results: ITestResults;\r\n    private readonly _options: ITestTrackerOptions;\r\n\r\n\r\n    constructor(bestTimesInst: TestTracker)\r\n    {\r\n        this._inst = bestTimesInst;\r\n        this._options = bestTimesInst.options;\r\n        this._results = bestTimesInst.results;\r\n    }\r\n\r\n\r\n    get writeConsole() { return writeInfo; }\r\n\r\n\r\n    getSuccessCount = (instance: Mocha.Context) =>\r\n    {\r\n        const mTest = instance.test || instance.currentTest as Mocha.Runnable,\r\n              suite = mTest.parent as Mocha.Suite,\r\n              suiteKey = this.getSuiteKey(suite.title),\r\n              suiteResults = this._results.suiteResults[suiteKey];\r\n        return suiteResults.successCount;\r\n    };\r\n\r\n\r\n    endRollingCount = (instance: Mocha.Context, isSetup?: boolean) =>\r\n    {\r\n\r\n        const mTest = (!isSetup ? instance.test : instance.currentTest) as Mocha.Runnable,\r\n            suite = mTest.parent as Mocha.Suite,\r\n            suiteKey = this.getSuiteKey(suite.title),\r\n            suiteResults = this._results.suiteResults[suiteKey];\r\n        ++suiteResults.successCount;\r\n        suiteResults.runTime = Date.now() - this._testTimer;\r\n        suiteResults.runTimeFmt = `${Math.floor(suiteResults.runTime / 1000)} s, ${suiteResults.runTime % 1000} ms`;\r\n        if (this._options.printSuiteRuntimes && this._testTimer > 0) {\r\n            writeInfo(`suite runtime  : ${suiteResults.runTimeFmt}`);\r\n        }\r\n        this._testTimer = 0;\r\n    };\r\n\r\n\r\n    exitRollingCount = (instance: Mocha.Context, isSetup?: boolean, isTeardown?: boolean) =>\r\n    {\r\n        const mTest = (!isSetup && !isTeardown ? instance.test : instance.currentTest) as Mocha.Runnable,\r\n              suite = mTest.parent as Mocha.Suite,\r\n              suiteKey = this.getSuiteKey(suite.title);\r\n\r\n        if (!this._results.suiteResults[suiteKey])\r\n        {\r\n            this._results.suiteResults[suiteKey] = {\r\n                timeStarted: Date.now(),\r\n                numTests: suite.tests.length,\r\n                success: false,\r\n                successCount: -1,\r\n                suiteName: this.getSuiteFriendlyName(suite.title),\r\n                timeFinished: 0,\r\n                numTestsFailed: 0\r\n            };\r\n            if (suite.parent) {\r\n                this._options.isSingleSuiteTest = suite.parent.suites.length <= 2;\r\n            }\r\n        }\r\n\r\n        const suiteResults = this._results.suiteResults[suiteKey],\r\n              testIdx = !isSetup && !isTeardown ?\r\n                        suite.tests.findIndex(t => t.title === mTest.title && !t.isFailed() && !t.isPassed()) :\r\n                        (isSetup ? -1 : suite.tests.length);\r\n        try\r\n        {   if (suiteResults.successCount !== testIdx) {\r\n                throw new Error(`Expected success count to be ${suiteResults.successCount}, got ${testIdx}`);\r\n            }\r\n        }\r\n        catch (e) {\r\n            this._inst.setFailed(e, suite, Object.assign({ index: testIdx }, mTest));\r\n        }\r\n\r\n        this._testTimer = Date.now();\r\n        return this._inst.isRollingCountError;\r\n    };\r\n\r\n\r\n    getSuiteKey = (suiteName: string, preKey = \"\") =>\r\n    {\r\n        if (preKey) {\r\n            return preKey + this.properCase(suiteName.replace(\" Tests\", \"\")).replace(/[ \\W]/g, \"\");\r\n        }\r\n        return this.lowerCaseFirstChar(this.properCase(suiteName.replace(\" Tests\", \"\")), true).replace(/\\W/g, \"\");\r\n    };\r\n\r\n\r\n    getSuiteFriendlyName = (suiteName: string) => suiteName.replace(\" Tests\", \"\");\r\n\r\n\r\n    private properCase = (name: string | undefined, removeSpaces?: boolean) =>\r\n    {\r\n        if (!name) {\r\n            return \"\";\r\n        }\r\n        return name.replace(/(?:^\\w|[A-Z]|\\b\\w)/g, (ltr) => ltr.toUpperCase())\r\n                   .replace(/[ ]+/g, !removeSpaces ? \" \" : \"\");\r\n    };\r\n\r\n\r\n    private lowerCaseFirstChar = (s: string, removeSpaces: boolean) =>\r\n    {\r\n        let fs = \"\";\r\n        if (s)\r\n        {\r\n            fs = s[0].toString().toLowerCase();\r\n            if (s.length > 1) {\r\n                fs += s.substring(1);\r\n            }\r\n            if (removeSpaces) {\r\n                fs = fs.replace(/ /g, \"\");\r\n            }\r\n        }\r\n        return fs;\r\n    };\r\n\r\n\r\n    sleep = async (ms: number) => new Promise(resolve => setTimeout(resolve, ms));\r\n\r\n\r\n    suiteFinished = (instance: Mocha.Context) =>\r\n    {\r\n        const suite = instance.currentTest?.parent;\r\n        if (suite)\r\n        {\r\n            const numTestsFailedThisSuite = suite.tests.filter(t => t.isFailed()).length,\r\n                  suiteKey = this.getSuiteKey(suite.title),\r\n                  suiteResults = this._results.suiteResults[suiteKey];\r\n            this._results.numTestsFail += numTestsFailedThisSuite;\r\n            this._results.numTestsSuccess += suite.tests.filter(t => t.isPassed()).length;\r\n            this._results.numSuites++;\r\n            this._results.numTests += suite.tests.length;\r\n            if (numTestsFailedThisSuite > 0) {\r\n                this._results.numSuitesFail++;\r\n            }\r\n            else {\r\n                this._results.numSuitesSuccess++;\r\n            }\r\n            this._results.suiteResults[suiteKey] = Object.assign(suiteResults,\r\n            {\r\n                success: numTestsFailedThisSuite === 0,\r\n                timeFinished: Date.now(),\r\n                numTestsFailed: numTestsFailedThisSuite\r\n            });\r\n        }\r\n    };\r\n\r\n}\r\n","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"readline\");","\r\n/**\r\n * @module testutils.utils.input\r\n */\r\n\r\nimport * as readline from \"readline\";\r\n\r\nlet stdinInterface: readline.Interface | undefined;\r\nlet setFailed: () => void;\r\n\r\n\r\nexport const ctrlC = async(code: number|undefined) => onKey(\"\", { name: \"c\", ctrl: true, code });\r\n\r\n\r\nconst onKey = async(str: string, key: any) =>\r\n{\r\n    if (key.meta) // alt\r\n    {\r\n        const k = key.name;\r\n        if (k === \"0\" || k === \"1\" || k === \"2\" || k === \"3\" || k === \"4\" || k === \"5\")\r\n        {\r\n            // const lvl = parseInt(k, 10);\r\n            // log.setLogLevel(lvl);\r\n            // log.info(`Logging level set to level '${k}'`);\r\n        }\r\n    }\r\n    else if (key.ctrl)\r\n    {\r\n        if (key.name === \"c\")\r\n        {\r\n            setFailed();\r\n        }\r\n    }\r\n};\r\n\r\n\r\nexport const startInput = (setFailedFn: () => void) =>\r\n{\r\n    if (!stdinInterface && process.stdin.isTTY)\r\n    {\r\n        setFailed = setFailedFn;\r\n        stdinInterface = readline.createInterface({ input: process.stdin, escapeCodeTimeout: 50 });\r\n        process.stdin.setRawMode(true);\r\n        readline.emitKeypressEvents(process.stdin, stdinInterface);\r\n        process.stdin.on(\"keypress\", onKey);\r\n    }\r\n};\r\n\r\n\r\nexport const stopInput = () =>\r\n{\r\n    if (stdinInterface)\r\n    {\r\n        process.stdin.off(\"keypress\", onKey);\r\n        stdinInterface.close();\r\n        stdinInterface = undefined;\r\n    }\r\n};\r\n","\r\n/**\r\n * @module testutils.tracker.testtracker\r\n */\r\n\r\nimport { argv } from \"../utils/argv.js\";\r\nimport { writeInfo } from \"../utils/utils.js\";\r\nimport { TestUtilsUtilities } from \"./utils.js\";\r\nimport { figures, colors } from \"../utils/figures.js\";\r\nimport { startInput, stopInput } from \"../utils/input.js\";\r\nimport { ITestTrackerOptions, ITestResults, ITestSuiteResults, ITestToolRuntimeSuite, ITestToolRuntimeTest } from \"../interface/index.js\";\r\n\r\n\r\nexport class TestTracker\r\n{\r\n    private _symbols: any;\r\n    private _timeStarted = 0;\r\n    private _caughtControlC = false;\r\n    private _hasRollingCountError: Record<string, string | number> | undefined;\r\n\r\n    private readonly _results: ITestResults;\r\n    private readonly _utils: TestUtilsUtilities;\r\n    private readonly _options: ITestTrackerOptions;\r\n    private readonly _timeSep = \"----------------------------------------------------------------------------------------------------\";\r\n\r\n\r\n    constructor(options?: Partial<ITestTrackerOptions>)\r\n    {\r\n        this._results = {\r\n            numSuites: 0,\r\n            numSuitesFail: 0,\r\n            numSuitesSuccess: 0,\r\n            numTests: 0,\r\n            numTestsFail: 0,\r\n            numTestsSuccess: 0,\r\n            suiteResults: {}\r\n        };\r\n\r\n        this._options = {\r\n            clearAllBestTimes: false,\r\n            clearBestTime: false,\r\n            clearBestTimesOnTestCountChange: false,\r\n            framework: \"mocha\",\r\n            isConsoleLogEnabled: false,\r\n            isFileLogEnabled: false,\r\n            isLogEnabled: false,\r\n            isMultiRootWorkspace: false,\r\n            isOutputWindowLogEnabled: false,\r\n            isSingleSuiteTest: false,\r\n            printSuiteRuntimes: false,\r\n            store: {\r\n                // eslint-disable-next-line prefer-arrow/prefer-arrow-functions\r\n                async updateStoreValue(..._args: any[]) {},\r\n                // eslint-disable-next-line prefer-arrow/prefer-arrow-functions\r\n                async getStoreValue<T>(..._args: any[]) { return 0 as T; }\r\n            }\r\n        };\r\n\r\n        Object.assign(this._options, options || {}, argv());\r\n\r\n        startInput(() => { this.setFailed(true); }); // Catch CTRL+C\r\n\r\n        this._timeStarted = Date.now();\r\n        this._utils = new TestUtilsUtilities(this);\r\n    }\r\n\r\n\r\n    get isRollingCountError() { return !!this._hasRollingCountError; }\r\n\r\n    get options(): ITestTrackerOptions { return this._options; }\r\n\r\n    set options(options: Partial<ITestTrackerOptions>) { this._timeStarted = Date.now(); Object.assign(this._options, options); }\r\n\r\n    get results(): ITestResults { return this._results; }\r\n\r\n    get utils(): TestUtilsUtilities { return this._utils; }\r\n\r\n\r\n    suiteResults = (suiteName: string): ITestSuiteResults => this._results.suiteResults[suiteName];\r\n\r\n\r\n    private clearProcessTimeStorage = async (storageKey: string, numTests: number) =>\r\n    {\r\n        const _clr = async () => {\r\n            await this._options.store.updateStoreValue(storageKey, undefined);\r\n            await this._options.store.updateStoreValue(storageKey + \"Fmt\", undefined);\r\n            await this._options.store.updateStoreValue(storageKey + \"NumTests\", undefined);\r\n            await this._options.store.updateStoreValue(storageKey + \"Slow\", undefined);\r\n            await this._options.store.updateStoreValue(storageKey + \"SlowFmt\", undefined);\r\n            await this._options.store.updateStoreValue(storageKey + \"SlowNumTests\", undefined);\r\n        };\r\n        if (this._options.clearBestTime || this._options.clearAllBestTimes)\r\n        {\r\n            await _clr();\r\n        }\r\n        else if (this._options.clearBestTimesOnTestCountChange)\r\n        {\r\n            const prevNumTests = await this._options.store.getStoreValue<number>(storageKey + \"NumTests\", 0);\r\n            if (prevNumTests < numTests) {\r\n                await _clr();\r\n            }\r\n        }\r\n    };\r\n\r\n\r\n    private getStorageKey = (baseKey: string) => baseKey + (this._options.isMultiRootWorkspace ? \"MWS\" : \"\");\r\n\r\n\r\n    private getTimeElapsedFmt = (timeElapsed: number) =>\r\n    {\r\n        const m = Math.floor(timeElapsed / 1000 / 60),\r\n            s = Math.floor(timeElapsed / 1000 % 60),\r\n            ms = Math.round(timeElapsed % 1000);\r\n        return `${m} minutes, ${s} seconds, ${ms} milliseconds`;\r\n    };\r\n\r\n\r\n    private logBestTime = async (title: string, storageKey: string, timeElapsedFmt: string) =>\r\n    {\r\n        let msg: string;\r\n        let wsTypeMsg = this._options.isMultiRootWorkspace ? \"multi-root\" : \"single-root\";\r\n        const prevBestTimeElapsedFmt = await this._options.store.getStoreValue<string>(storageKey + \"Fmt\", \"\"),\r\n            slowestTImeFmt = await this._options.store.getStoreValue<string>(storageKey + \"SlowFmt\", \"\"),\r\n            prevMsg = ` The previous fastest time recorded for a ${wsTypeMsg} workspace was ${prevBestTimeElapsedFmt}`,\r\n            slowMsg = ` The slowest time recorded for a ${wsTypeMsg} workspace was ${slowestTImeFmt}`,\r\n            preMsg = `    ${figures.color.info} ${figures.withColor(\"!!!\", figures.colors.cyan)}`;\r\n        wsTypeMsg = this._options.isMultiRootWorkspace ? \"Multi-Root\" : \"Single-Root\";\r\n        if (title)\r\n        {\r\n            if (title.includes(\"Logging\")) {\r\n                msg = ` New Fastest Time with ${title} (${wsTypeMsg} workspace) ${figures.withColor(timeElapsedFmt, figures.colors.cyan)}`;\r\n            }\r\n            else {\r\n                if (this._results.numSuites > 1) {\r\n                    msg = ` New Fastest Time for Suite '${title}' (${wsTypeMsg} workspace) ${figures.withColor(timeElapsedFmt, figures.colors.cyan)}`;\r\n                }\r\n                else {\r\n                    msg = ` New Fastest Time for Suite '${title}' (Single Test)(${wsTypeMsg} workspace) ${figures.withColor(timeElapsedFmt, figures.colors.cyan)}`;\r\n                }\r\n            }\r\n        }\r\n        else {\r\n            msg = ` New Fastest Time for 'All Tests' (${wsTypeMsg} workspace) ${figures.withColor(timeElapsedFmt, figures.colors.cyan)}`;\r\n        }\r\n        // console.log(preMsg);\r\n        console.log(preMsg + figures.withColor(msg, figures.colors.grey));\r\n        console.log(preMsg + figures.withColor(prevMsg, figures.colors.grey));\r\n        console.log(preMsg + figures.withColor(slowMsg, figures.colors.grey));\r\n        // console.log(preMsg);\r\n    };\r\n\r\n\r\n    private logSlowestTime = async (title: string, storageKey: string, timeElapsedFmt: string) =>\r\n    {\r\n        let msg: string;\r\n        let wsTypeMsg = this._options.isMultiRootWorkspace ? \"multi-root\" : \"single-root\";\r\n        const prevBestTimeElapsedFmt = await this._options.store.getStoreValue<string>(storageKey + \"Fmt\", \"\"),\r\n            slowestTimeFmt = await this._options.store.getStoreValue<string>(storageKey + \"SlowFmt\", \"\"),\r\n            prevMsg = ` The previous slowest time recorded for a ${wsTypeMsg} workspace was ${slowestTimeFmt}`,\r\n            fastMsg = ` The fastest time recorded for a ${wsTypeMsg} workspace was ${prevBestTimeElapsedFmt}`,\r\n            preMsg = `    ${figures.color.info} ${figures.withColor(\"!!!\", figures.colors.red)}`;\r\n        wsTypeMsg = this._options.isMultiRootWorkspace ? \"Multi-Root\" : \"Single-Root\";\r\n        if (title)\r\n        {\r\n            if (title.includes(\"Logging\")) {\r\n                msg = ` New Slowest Time with ${title} (${wsTypeMsg} workspace) ${figures.withColor(timeElapsedFmt, figures.colors.red)}`;\r\n            }\r\n            else {\r\n                if (this._results.numSuites > 1) {\r\n                    msg = ` New Slowest Time for Suite '${title}' (${wsTypeMsg} workspace) ${figures.withColor(timeElapsedFmt, figures.colors.red)}`;\r\n                }\r\n                else {\r\n                    msg = ` New Slowest Time for Suite '${title}' (Single Test)(${wsTypeMsg} workspace) ${figures.withColor(timeElapsedFmt, figures.colors.red)}`;\r\n                }\r\n            }\r\n        }\r\n        else {\r\n            msg = ` New Slowest Time for 'All Tests' (${wsTypeMsg} workspace) ${figures.withColor(timeElapsedFmt, figures.colors.cyan)}`;\r\n        }\r\n        // console.log(preMsg);\r\n        console.log(preMsg + figures.withColor(msg, figures.colors.grey));\r\n        console.log(preMsg + figures.withColor(prevMsg, figures.colors.grey));\r\n        console.log(preMsg + figures.withColor(fastMsg, figures.colors.grey));\r\n        // console.log(preMsg);\r\n    };\r\n\r\n\r\n    private processBestTime = async (logTitle: string, storageKey: string, timeElapsed: number, numTests: number) =>\r\n    {\r\n        const title = !logTitle || logTitle.includes(\"Logging\") ? \"All Tests \" + logTitle : logTitle,\r\n            msg = (figures.withColor(\"-- \", figures.colors.magenta) +\r\n                    figures.withColor(title.toUpperCase(), figures.colors.white) +\r\n                    figures.withColor(` ${this._timeSep.substring(0, this._timeSep.length - title.length - 4)}`, figures.colors.magenta));\r\n        console.log(`    ${figures.color.info} ${msg}`);\r\n\r\n        await this.clearProcessTimeStorage(storageKey, numTests);\r\n\r\n        let bestTimeElapsed = await this._options.store.getStoreValue<number>(storageKey, 0);\r\n        if (bestTimeElapsed === 0) {\r\n            bestTimeElapsed = timeElapsed + 1;\r\n        }\r\n        const worstTimeElapsedStored = await this._options.store.getStoreValue<number>(`${storageKey}Slow`, 0);\r\n        let worstTimeElapsed = worstTimeElapsedStored;\r\n        if (worstTimeElapsed === 0) {\r\n            worstTimeElapsed = timeElapsed + 1;\r\n        }\r\n\r\n        const timeElapsedFmt = this.getTimeElapsedFmt(timeElapsed);\r\n        if (timeElapsed > 0 && timeElapsed < bestTimeElapsed)\r\n        {\r\n            await this.logBestTime(logTitle, storageKey, timeElapsedFmt);\r\n            await this.saveProcessTimeToStorage(storageKey, timeElapsed, timeElapsedFmt, numTests);\r\n            if (worstTimeElapsedStored === 0) {\r\n                await this.saveProcessTimeToStorage(`${storageKey}Slow`, timeElapsed, timeElapsedFmt, numTests);\r\n            }\r\n        }\r\n        else if (timeElapsed > 0 && (timeElapsed > worstTimeElapsed || worstTimeElapsedStored === 0))\r\n        {\r\n            await this.logSlowestTime(logTitle, storageKey, timeElapsedFmt);\r\n            await this.saveProcessTimeToStorage(`${storageKey}Slow`, timeElapsed, timeElapsedFmt, numTests);\r\n        }\r\n        else\r\n        {\r\n            let bestTimeElapsedFmt = await this._options.store.getStoreValue<string>(storageKey + \"Fmt\", \"\"),\r\n                worstTimeElapsedFmt = await this._options.store.getStoreValue<string>(storageKey + \"SlowFmt\", \"\");\r\n            const wsTypeMsg = this._options.isMultiRootWorkspace ? \"multi-root\" : \"single-root\",\r\n                msg1 = `The time elapsed was ${timeElapsedFmt}`,\r\n                msg2 = timeElapsed > 0 ? `The fastest time recorded for a ${wsTypeMsg} workspace is ${bestTimeElapsedFmt}` :\r\n                                        \"Fastest time tracking not available for tests running at 0 ms\";\r\n            if (!bestTimeElapsedFmt) {\r\n                await this.saveProcessTimeToStorage(storageKey, timeElapsed, timeElapsedFmt, numTests);\r\n                bestTimeElapsedFmt = timeElapsedFmt;\r\n            }\r\n            if (!worstTimeElapsedFmt) {\r\n                await this.saveProcessTimeToStorage(`${storageKey}Slow`, timeElapsed, timeElapsedFmt, numTests);\r\n                worstTimeElapsedFmt = timeElapsedFmt;\r\n            }\r\n            console.log(`    ${figures.color.info} ${figures.withColor(msg1, figures.colors.grey)}`);\r\n            console.log(`    ${figures.color.info} ${figures.withColor(msg2, figures.colors.grey)}`);\r\n            if (timeElapsed > 0)\r\n            {\r\n                const msg3 = `The slowest time recorded for a ${wsTypeMsg} workspace is ${worstTimeElapsedFmt}`;\r\n                console.log(`    ${figures.color.info} ${figures.withColor(msg3, figures.colors.grey)}`);\r\n            }\r\n        }\r\n    };\r\n\r\n\r\n    private processSuiteTimes = async () =>\r\n    {\r\n        const suiteResults = Object.values(this._results.suiteResults).filter(v => v.suiteName !== \"Deactivate Extension\");\r\n        for (const suiteResult of suiteResults)\r\n        {\r\n            const typeKey = this._results.numSuites === 1 ? \"Single\" : \"\",\r\n                storageKey = this._utils.getSuiteKey(suiteResult.suiteName, this.getStorageKey(\"bestTimeElapsedSuite\" + typeKey));\r\n            if (this._options.clearAllBestTimes) {\r\n                await this.clearProcessTimeStorage(storageKey, this._results.numTests);\r\n                await this.clearProcessTimeStorage(`${storageKey}Slow`, this._results.numTests);\r\n            }\r\n            if (suiteResult.timeFinished && suiteResult.timeStarted)\r\n            {\r\n                const timeElapsed = suiteResult.timeFinished - suiteResult.timeStarted;\r\n                await this.processBestTime(suiteResult.suiteName, storageKey, timeElapsed, this._results.numTests);\r\n            }\r\n        }\r\n    };\r\n\r\n\r\n    private processTimesWithLogEnabled = async (timeElapsed: number) =>\r\n    {\r\n        if (this._options.clearAllBestTimes)\r\n        {\r\n            await this.clearProcessTimeStorage(this.getStorageKey(\"bestTimeElapsedWithLogging\"), this._results.numTests);\r\n            await this.clearProcessTimeStorage(this.getStorageKey(\"bestTimeElapsedWithLoggingFile\"), this._results.numTests);\r\n            await this.clearProcessTimeStorage(this.getStorageKey(\"bestTimeElapsedWithLoggingOutput\"), this._results.numTests);\r\n            await this.clearProcessTimeStorage(this.getStorageKey(\"bestTimeElapsedWithLoggingConsole\"), this._results.numTests);\r\n            await this.clearProcessTimeStorage(this.getStorageKey(\"slowTimeElapsedWithLogging\"), this._results.numTests);\r\n            await this.clearProcessTimeStorage(this.getStorageKey(\"slowTimeElapsedWithLoggingFile\"), this._results.numTests);\r\n            await this.clearProcessTimeStorage(this.getStorageKey(\"slowTimeElapsedWithLoggingOutput\"), this._results.numTests);\r\n            await this.clearProcessTimeStorage(this.getStorageKey(\"slowTimeElapsedWithLoggingConsole\"), this._results.numTests);\r\n        }\r\n        if (this._options.isLogEnabled)\r\n        {\r\n            await this.processBestTime(\"Logging Enabled\", this.getStorageKey(\"bestTimeElapsedWithLogging\"), timeElapsed, this._results.numTests);\r\n            await this.processBestTime(\"Logging Enabled\", this.getStorageKey(\"slowTimeElapsedWithLogging\"), timeElapsed, this._results.numTests);\r\n            if (this._options.isFileLogEnabled)\r\n            {\r\n                await this.processBestTime(\"File Logging Enabled\", this.getStorageKey(\"bestTimeElapsedWithLoggingFile\"), timeElapsed, this._results.numTests);\r\n                await this.processBestTime(\"File Logging Enabled\", this.getStorageKey(\"slowTimeElapsedWithLoggingFile\"), timeElapsed, this._results.numTests);\r\n            }\r\n            if (this._options.isOutputWindowLogEnabled)\r\n            {\r\n                await this.processBestTime(\"Output Window Logging Enabled\", this.getStorageKey(\"bestTimeElapsedWithLoggingOutput\"), timeElapsed, this._results.numTests);\r\n                await this.processBestTime(\"Output Window Logging Enabled\", this.getStorageKey(\"slowTimeElapsedWithLoggingOutput\"), timeElapsed, this._results.numTests);\r\n            }\r\n            if (this._options.isConsoleLogEnabled)\r\n            {\r\n                await this.processBestTime(\"Console Logging Enabled\", this.getStorageKey(\"bestTimeElapsedWithLoggingConsole\"), timeElapsed, this._results.numTests);\r\n                await this.processBestTime(\"Console Logging Enabled\", this.getStorageKey(\"slowTimeElapsedWithLoggingConsole\"), timeElapsed, this._results.numTests);\r\n            }\r\n        }\r\n    };\r\n\r\n\r\n    processTimes = async () =>\r\n    {\r\n        const timeFinished = Date.now(),\r\n              timeElapsed = timeFinished - this._timeStarted,\r\n              tzOffset = (new Date()).getTimezoneOffset() * 60000,\r\n              timeFinishedFmt = (new Date(Date.now() - tzOffset)).toISOString().slice(0, -1).replace(\"T\", \" \").replace(/[\\-]/g, \"/\");\r\n        //\r\n        // If ctrl+c or rolling count error is set, reset the mocha success icon for \"cleanup\" final test/step\r\n        //\r\n        if (this._hasRollingCountError && this._symbols) { this._symbols.ok = figures.color.success; }\r\n        if (this._caughtControlC) {\r\n            console.log(`    ${figures.color.info} ${figures.withColor(\"User cancelled (caught CTRL+C)\", colors.grey)}`);\r\n        }\r\n        stopInput();\r\n\r\n        console.log(`    ${figures.color.info} ${figures.withColor(\"Time Finished: \" + timeFinishedFmt, figures.colors.grey)}`);\r\n        console.log(`    ${figures.color.info} ${figures.withColor(\"Time Elapsed: \" + this.getTimeElapsedFmt(timeElapsed), figures.colors.grey)}`);\r\n\r\n        if (this._results.numTestsFail === 0 && !this._hasRollingCountError)\r\n        {\r\n            if (this._results.numSuites > 3)  { // > 3, sometimes i string the single test together with a few others temp\r\n                await this.processBestTime(\"\", this.getStorageKey(\"bestTimeElapsed\"), timeElapsed, this._results.numTests);\r\n                await this.processTimesWithLogEnabled(timeElapsed);\r\n            }\r\n            await this.processSuiteTimes();\r\n        }\r\n        else {\r\n            const skipMsg = this._results.numTestsFail > 0 ?\r\n                                `There were ${this._results.numTestsFail} failed tests, best time processing skipped` :\r\n                                \"There was a rolling count failure, best time processing skipped\";\r\n            console.log(`    ${figures.color.info} ${figures.withColor(skipMsg, figures.colors.grey)}`);\r\n        }\r\n\r\n        console.log(`    ${figures.color.info} ${figures.withColor(this._timeSep, figures.colors.magenta)}`);\r\n    };\r\n\r\n\r\n    private saveProcessTimeToStorage = async (key: string, timeElapsed: number, timeElapseFmt: string, numTests: number) =>\r\n    {\r\n        await this._options.store.updateStoreValue(key, timeElapsed);\r\n        await this._options.store.updateStoreValue(key + \"Fmt\", timeElapseFmt);\r\n        await this._options.store.updateStoreValue(key + \"NumTests\", numTests);\r\n    };\r\n\r\n\r\n    setFailed = (eObj: boolean | Error, suite?: ITestToolRuntimeSuite, test?: ITestToolRuntimeTest) =>\r\n    {\r\n        if (!this._hasRollingCountError)\r\n        {\r\n            const isError = eObj instanceof Error;\r\n            this._caughtControlC = typeof eObj === \"boolean\";\r\n            this._hasRollingCountError = { suite: suite!.title, test: test!.title, testIdx: test!.index };\r\n            if (this._options.framework === \"mocha\")\r\n            {\r\n                const { symbols } = require(\"mocha/lib/reporters/base\");\r\n                this._symbols = symbols;\r\n                symbols.ok = figures.withColor(figures.pointer, colors.blue) +  figures.withColor(\" [Skipped]\", colors.grey);\r\n            }\r\n            if (test) {\r\n                writeInfo(`rolling success count failure @ test ${test.index + 1}, skipping remaining tests`);\r\n            }\r\n            else {\r\n                throw new Error(\"Caught CTRL-C\");\r\n            }\r\n            if (suite?.tests.filter(t => t.isFailed()).length === 0) {\r\n                process.env.TEST_UTILS_FAILURE_EXCEPTION = (isError ? eObj.message : \"\");\r\n                throw new Error(\"Rolling count error: \" + process.env.TEST_UTILS_FAILURE_EXCEPTION);\r\n            }\r\n            // else if (isError) {\r\n            //     TODO - hmmm, how to get mocha runtime exception\r\n            //     process.env.TEST_UTILS_FAILURE_EXCEPTION = `${eObj.message}\\n${eObj.stack}`;\r\n            // }\r\n        }\r\n    };\r\n\r\n}\r\n","/**\r\n * @module testutils.utils.argv\r\n */\r\n\r\nimport { isNumeric } from \"./utils.js\";\r\nimport { ITestRunArguments } from \"../interface/argv.js\";\r\n\r\n\r\nexport const argv = (): Partial<ITestRunArguments> =>\r\n{\r\n    const args : Partial<ITestRunArguments> = {};\r\n    process.argv.forEach((arg, idx, arr) =>\r\n    {\r\n        if (arg.startsWith(\"--tu-\"))\r\n        {\r\n            if (arr[idx + 1] && !arr[idx + 1].startsWith(\"--\"))\r\n            {\r\n                args[toCamelProperty(arg)] = arr[idx + 1];\r\n                if (isNumeric(args[arg])) {\r\n                    args[arg] = parseInt(arr[idx + 1], 10);\r\n                }\r\n            }\r\n            else {\r\n                args[arg] = true;\r\n            }\r\n        }\r\n    }, this);\r\n    return args;\r\n};\r\n\r\n\r\nconst toCamelProperty = (name: string): string =>\r\n{\r\n    return name\r\n    .replace(/(?:^\\w|[A-Z]|\\b\\w)/g, (letter, index) => {\r\n        return index !== 0 ? letter.toLowerCase() : letter.toUpperCase();\r\n    })\r\n    .replace(/[\\s\\-]+/g, \"\");\r\n};\r\n","\r\n/**\r\n * @module testutils.utils.figures\r\n */\r\n\r\nexport type LogColor = [ number, number ];\r\nexport type LogStyle = [ number, number ];\r\n\r\ninterface ILogColors\r\n{\r\n    bold: LogColor;\r\n    italic: LogColor;\r\n    underline: LogColor;\r\n    inverse: LogColor;\r\n    white: LogColor;\r\n    grey: LogColor;\r\n    black: LogColor;\r\n    blue: LogColor;\r\n    cyan: LogColor;\r\n    green: LogColor;\r\n    magenta: LogColor;\r\n    red: LogColor;\r\n    yellow: LogColor;\r\n};\r\n\r\nclass LogColors implements ILogColors\r\n{\r\n    bold: LogStyle = [ 1, 22 ];\r\n    italic: LogStyle = [ 3, 23 ];\r\n    underline: LogStyle = [ 4, 24 ];\r\n    inverse: LogStyle = [ 7, 27 ];\r\n    white: LogColor = [ 37, 39 ];\r\n    grey: LogColor = [ 90, 39 ];\r\n    black: LogColor = [ 30, 39 ];\r\n    blue: LogColor = [ 34, 39 ];\r\n    cyan: LogColor = [ 36, 39 ];\r\n    green: LogColor = [ 32, 39 ];\r\n    magenta: LogColor = [ 35, 39 ];\r\n    red: LogColor = [ 31, 39 ];\r\n    yellow: LogColor = [ 33, 39 ];\r\n};\r\n\r\nexport const colors = new LogColors();\r\n\r\nexport const withColor = (msg: string, color: LogColor) => \"\\x1B[\" + color[0] + \"m\" + msg + \"\\x1B[\" + color[1] + \"m\";\r\n\r\nexport const figures = {\r\n    colors,\r\n    withColor,\r\n    success: \"✔\",\r\n    info: \"ℹ\",\r\n\twarning: \"⚠\",\r\n\terror: \"✘\",\r\n\tpointer: \"❯\",\r\n\tstart: \"▶\",\r\n\tend: \"◀\",\r\n\tnodejs: \"⬢\",\r\n\tstar: \"★\",\r\n\tcheckboxOn: \"☒\",\r\n\tcheckboxOff: \"☐\",\r\n\tpointerSmall: \"›\",\r\n\tbullet: \"●\",\r\n    up: \"△\",\r\n    color:\r\n    {\r\n        success: withColor(\"✔\", colors.green),\r\n        successBlue: withColor(\"✔\", colors.blue),\r\n        info: withColor(\"ℹ\", colors.magenta),\r\n        infoTask: withColor(\"ℹ\", colors.blue),\r\n        warning: withColor(\"⚠\", colors.yellow),\r\n        warningTests: withColor(\"⚠\", colors.blue),\r\n        error: withColor(\"✘\", colors.red),\r\n        errorTests: withColor(\"✘\", colors.blue),\r\n        start: withColor(\"▶\", colors.green),\r\n        end: withColor(\"◀\", colors.green),\r\n        pointer: withColor(\"❯\", colors.grey),\r\n        up: withColor(\"△\", colors.green),\r\n    }\r\n\r\n};\r\n","\r\n/**\r\n * @module testutils.utils.utils\r\n */\r\n\r\nimport { figures } from \"./figures.js\";\r\n\r\n\r\nexport const isNumeric = (v: any) => !isNaN(parseFloat(v)) && isFinite(v);\r\n\r\n\r\nexport const pluralize = (s: string, itemLength: number) => { if (itemLength!== 1 ) return s + \"s\"; return s; }\r\n\r\n\r\nexport const sleep = async (ms: number) => new Promise(resolve => setTimeout(resolve, ms));\r\n\r\n\r\nexport const writeInfo = (msg?: string, icon?: string, pad = \"\") =>\r\n    console.log(`    ${pad}${icon || figures.color.info}${msg ? \" \" + figures.withColor(msg, figures.colors.grey) : \"\"}`);\r\n\r\n\r\nexport const writeErrorsAreOk = () =>\r\n{\r\n\r\n    console.log(`    ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ` +\r\n                `${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ` +\r\n                `${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ` +\r\n                `${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ` +\r\n                `${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}`);\r\n    console.log(`    ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ` +\r\n                `${figures.color.up}  ${figures.withColor(\"  THESE ERRORS WERE SUPPOSED TO HAPPEN!!!  \", figures.colors.green)}  ` +\r\n                `${figures.color.up}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}`);\r\n    console.log(`    ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ` +\r\n                `${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ` +\r\n                `${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ` +\r\n                `${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ` +\r\n                `${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}  ${figures.color.success}`);\r\n\r\n};\r\n","module.exports = require(\"mocha/lib/reporters/base\");","module.exports = require(\"node-preload\");","module.exports = require(\"source-map-support/register\");","module.exports = require(\"spawn-wrap\");","module.exports = require(\"ts-node/register\");","module.exports = require(\"os\");","module.exports = require(\"tty\");","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n// expose the module cache\n__webpack_require__.c = __webpack_module_cache__;\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = (chunkId) => {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks and sibling chunks for the entrypoint\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn undefined;\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.X = (result, chunkIds, fn) => {\n\t// arguments: chunkIds, moduleId are deprecated\n\tvar moduleId = chunkIds;\n\tif(!fn) chunkIds = result, fn = () => (__webpack_require__(__webpack_require__.s = moduleId));\n\tchunkIds.map(__webpack_require__.e, __webpack_require__)\n\tvar r = fn();\n\treturn r === undefined ? result : r;\n}","// module cache are used so entry inlining is disabled\n// startup\n// Load entry module and return exports\nvar __webpack_exports__ = __webpack_require__(55);\n"],"names":["installedChunks","installChunk","require","options","nycConfig","Object","assign","defaultConfig","coverage","config","nyc","wrap","myFilesRegex","RegExp","moduleName","moduleBuildDir","filterFn","test","bind","keys","filter","length","console","warn","clean","reset","createTempDirectory","env","NYC_CONFIG","JSON","stringify","NYC_CWD","cwd","babelCache","BABEL_DISABLE_CACHE","process","useSpawnWrap","requireModules","____require","resolve____","map","mod","push","forEach","____require____","all","addAllFiles","sw","relative","__dirname","resolve","replace","runMain","SPAWN_WRAP_SHIM_ROOT","XDG_CACHE_HOME","cfgFile","join","projectRoot","existsSync","parse","readFileSync","extends","hookRequire","hookRunInContext","hookRunInThisContext","instrument","reportDir","silent","reporter","include","exclude","framework","mocha","suite","filesToTest","a","root","sortGroup","files","sort","b","includes","basename","f","addFile","ui","color","timeout","retries","slow","sleep","ms","Promise","setTimeout","captureStdout","async","fn","w","stdout","write","buffer","s","e","suppressEPIPE","error","code","preparePlatform","platform","tty","getWindowSize","TestRunner","constructor","runCfg","cover","xArgs","isTypescript","register","tsNode","sourceMapSupport","projectDir","htmlReportDark","tool","istanbulReportPath","istanbulHtmlReportPath","istanbulHtmlReportCssFile","copyFileSync","mochaError","failures","run","writeCoverageFile","writeProcessIndex","maybePurgeSourceMapCache","log","report","showProcessTree","message","TEST_UTILS_FAILURE_EXCEPTION","Error","this","_options","argv","type","verbose","TestUtilsUtilities","bestTimesInst","instance","currentTest","parent","suiteKey","getSuiteKey","title","_results","suiteResults","successCount","isSetup","runTime","Date","now","_testTimer","runTimeFmt","Math","floor","printSuiteRuntimes","isTeardown","mTest","timeStarted","numTests","tests","success","suiteName","getSuiteFriendlyName","timeFinished","numTestsFailed","isSingleSuiteTest","suites","testIdx","findIndex","t","isFailed","isPassed","_inst","setFailed","index","isRollingCountError","preKey","properCase","lowerCaseFirstChar","name","removeSpaces","ltr","toUpperCase","fs","toString","toLowerCase","substring","numTestsFailedThisSuite","numTestsFail","numTestsSuccess","numSuites","numSuitesFail","numSuitesSuccess","results","writeConsole","stdinInterface","onKey","str","key","meta","ctrl","TestTracker","setFailedFn","storageKey","_clr","store","updateStoreValue","clearBestTime","clearAllBestTimes","clearBestTimesOnTestCountChange","getStoreValue","baseKey","isMultiRootWorkspace","timeElapsed","round","timeElapsedFmt","msg","wsTypeMsg","prevMsg","slowMsg","preMsg","figures","info","withColor","colors","cyan","grey","prevBestTimeElapsedFmt","fastMsg","red","logTitle","magenta","white","_timeSep","clearProcessTimeStorage","bestTimeElapsed","worstTimeElapsedStored","worstTimeElapsed","getTimeElapsedFmt","logBestTime","saveProcessTimeToStorage","logSlowestTime","bestTimeElapsedFmt","worstTimeElapsedFmt","msg1","msg2","msg3","values","v","suiteResult","typeKey","_utils","getStorageKey","processBestTime","isLogEnabled","isFileLogEnabled","isOutputWindowLogEnabled","isConsoleLogEnabled","_timeStarted","tzOffset","getTimezoneOffset","timeFinishedFmt","toISOString","slice","_hasRollingCountError","_symbols","ok","_caughtControlC","stdin","off","close","skipMsg","processTimesWithLogEnabled","processSuiteTimes","timeElapseFmt","eObj","isError","symbols","pointer","blue","_args","isTTY","input","escapeCodeTimeout","setRawMode","on","utils","args","arg","idx","arr","startsWith","toCamelProperty","parseInt","letter","warning","start","end","nodejs","star","checkboxOn","checkboxOff","pointerSmall","bullet","up","green","successBlue","infoTask","yellow","warningTests","errorTests","isNumeric","isNaN","parseFloat","isFinite","pluralize","itemLength","writeInfo","icon","pad","writeErrorsAreOk","module","exports","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","id","loaded","__webpack_modules__","m","c","n","getter","__esModule","d","definition","o","defineProperty","enumerable","get","chunkId","reduce","promises","u","obj","prop","prototype","hasOwnProperty","call","r","Symbol","toStringTag","value","X","result","chunkIds","chunk","moreModules","modules","ids","runtime","i","C","__webpack_exports__"],"sourceRoot":""}