Skip to content

Commit

Permalink
fix(web): return port from http-server process
Browse files Browse the repository at this point in the history
  • Loading branch information
barbados-clemens committed May 19, 2023
1 parent 3472897 commit 4acd68b
Showing 1 changed file with 33 additions and 5 deletions.
38 changes: 33 additions & 5 deletions packages/web/src/executors/file-server/file-server.impl.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import { watch } from 'chokidar';
import { platform } from 'os';
import { join, resolve } from 'path';
import { readModulePackageJson } from 'nx/src/utils/package-json';
import * as detectPort from 'detect-port';

// platform specific command name
const pmCmd = platform() === 'win32' ? `npx.cmd` : 'npx';
Expand All @@ -24,10 +25,6 @@ function getHttpServerArgs(options: Schema) {
if (options.cors) {
args.push(`--cors`);
}

if (options.port) {
args.push(`-p=${options.port}`);
}
if (options.host) {
args.push(`-a=${options.host}`);
}
Expand Down Expand Up @@ -182,6 +179,10 @@ export default async function* fileServerExecutor(
pathToHttpServerBin
);

// detect port as close to when used to prevent port being used by another process
// when running in parallel
const port = await detectPort(options.port || 8080);
args.push(`-p=${port}`);
const serve = fork(pathToHttpServer, [outputPath, ...args], {
stdio: 'pipe',
cwd: context.root,
Expand All @@ -203,7 +204,34 @@ export default async function* fileServerExecutor(
};
process.on('exit', processExitListener);
process.on('SIGTERM', processExitListener);

// TODO(caleb): should this be in devkit?
function stripConsoleColors(log: string): string {
return log?.replace(
/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g,
''
);
}

serve.stdout.on('data', (chunk) => {
// const str = chunk.toString();
// // need to strip colors other wise the port includes color codes
// // which cause cypress to throw reading the url;
// const lines = stripConsoleColors(str).split('\n');
// // Available on:
// // http://localhost:8081
// // Hit CTRL-C to stop the server
// const line = lines?.find((l) => l.includes(options.host))?.trim();
// if (line) {
// const u = new URL(line);

// if (u.port) {
// res(u.port);
// } else {
// rej('Could not find port');
// }
// }

if (chunk.toString().indexOf('GET') === -1) {
process.stdout.write(chunk);
}
Expand All @@ -215,7 +243,7 @@ export default async function* fileServerExecutor(
yield {
success: true,
baseUrl: `${options.ssl ? 'https' : 'http'}://${options.host}:${
options.port
port || options.port
}`,
};

Expand Down

0 comments on commit 4acd68b

Please sign in to comment.