From ce59760962ec71de903ad2ba93e37804fddc7251 Mon Sep 17 00:00:00 2001 From: KristianFJones Date: Sun, 31 May 2020 17:28:23 +0000 Subject: [PATCH] fix: Fix parsing --- src/Modules/Worker/WorkerController.ts | 36 ++++++++++++-------------- 1 file changed, 16 insertions(+), 20 deletions(-) diff --git a/src/Modules/Worker/WorkerController.ts b/src/Modules/Worker/WorkerController.ts index 7cac4ec..66134a7 100644 --- a/src/Modules/Worker/WorkerController.ts +++ b/src/Modules/Worker/WorkerController.ts @@ -25,7 +25,7 @@ interface WorkerThread { } const controllerDefaultOptions: TestControllerOptions = { - testFileRegex: /.*(test|spec)\.ts/gm, + testFileRegex: /.*(test|spec)\.((ts|js)x?)$/gm, }; interface WorkerControllerEventMap { @@ -97,45 +97,41 @@ export class WorkerController extends BaseEventEmitter< */ public async findTestFiles(rootDir: string): Promise { const controllerOptions = this.options; + const testFiles = this.testFiles; - async function processDirectory( - directoryPath: string, - ): Promise { + async function processDirectory(directoryPath: string): Promise { const directoryContents = await fs.readdir(directoryPath, { withFileTypes: true, encoding: 'utf-8', }); - const testFiles = await Promise.all( + await Promise.all( directoryContents.map(async (dirContent) => { const contentName = dirContent.name; const contentPath = resolvePath(directoryPath, contentName); + if (controllerOptions.testFileRegex.test(contentName)) { + testFiles.push( + new TestFile({ + path: contentPath, + }), + ); + + return; + } + if (contentName === 'node_modules') { - return []; + return; } if (dirContent.isDirectory()) { return processDirectory(contentPath); } - - if (controllerOptions.testFileRegex.test(dirContent.name)) { - return [ - new TestFile({ - path: contentPath, - }), - ]; - } - - return []; }), ); - - return testFiles.filter(Boolean).flat(); } - const testFiles = await processDirectory(rootDir); - this.testFiles.push(...testFiles); + await processDirectory(rootDir); } /**