Skip to content

Commit

Permalink
feat(dev): use the same port for dev ready messages and websocket
Browse files Browse the repository at this point in the history
  • Loading branch information
pcattori committed May 24, 2023
1 parent 43adafb commit c22c934
Show file tree
Hide file tree
Showing 8 changed files with 39 additions and 67 deletions.
10 changes: 2 additions & 8 deletions integration/hmr-log-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,11 +9,7 @@ import { createFixtureProject, css, js, json } from "./helpers/create-fixture";

test.setTimeout(120_000);

let fixture = (options: {
appServerPort: number;
httpPort: number;
webSocketPort: number;
}) => ({
let fixture = (options: { appServerPort: number; httpPort: number }) => ({
files: {
"remix.config.js": js`
module.exports = {
Expand All @@ -22,7 +18,6 @@ let fixture = (options: {
future: {
unstable_dev: {
httpPort: ${options.httpPort},
webSocketPort: ${options.webSocketPort},
},
v2_routeConvention: true,
v2_errorBoundary: true,
Expand Down Expand Up @@ -252,9 +247,8 @@ test("HMR", async ({ page }) => {
let portRange = makeRange(4080, 4099);
let appServerPort = await getPort({ port: portRange });
let httpPort = await getPort({ port: portRange });
let webSocketPort = await getPort({ port: portRange });
let projectDir = await createFixtureProject(
fixture({ appServerPort, httpPort, webSocketPort })
fixture({ appServerPort, httpPort })
);

// spin up dev server
Expand Down
10 changes: 2 additions & 8 deletions integration/hmr-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,11 +9,7 @@ import { createFixtureProject, css, js, json } from "./helpers/create-fixture";

test.setTimeout(120_000);

let fixture = (options: {
appServerPort: number;
httpPort: number;
webSocketPort: number;
}) => ({
let fixture = (options: { appServerPort: number; httpPort: number }) => ({
files: {
"remix.config.js": js`
module.exports = {
Expand All @@ -22,7 +18,6 @@ let fixture = (options: {
future: {
unstable_dev: {
httpPort: ${options.httpPort},
webSocketPort: ${options.webSocketPort},
},
v2_routeConvention: true,
v2_errorBoundary: true,
Expand Down Expand Up @@ -250,9 +245,8 @@ test("HMR", async ({ page }) => {
let portRange = makeRange(3080, 3099);
let appServerPort = await getPort({ port: portRange });
let httpPort = await getPort({ port: portRange });
let webSocketPort = await getPort({ port: portRange });
let projectDir = await createFixtureProject(
fixture({ appServerPort, httpPort, webSocketPort })
fixture({ appServerPort, httpPort })
);

// spin up dev server
Expand Down
1 change: 0 additions & 1 deletion packages/remix-dev/__tests__/cli-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,6 @@ describe("remix CLI", () => {
--http-host HTTP(S) host for the dev server. Default: localhost
--http-port HTTP(S) port for the dev server. Default: any open port
--no-restart Do not restart the app server when rebuilds occur.
--websocket-port WebSocket port for the dev server. Default: any open port
\`init\` Options:
--no-delete Skip deleting the \`remix.init\` script
\`routes\` Options:
Expand Down
16 changes: 2 additions & 14 deletions packages/remix-dev/cli/commands.ts
Original file line number Diff line number Diff line change
Expand Up @@ -183,7 +183,7 @@ export async function build(
host: dev.httpHost,
port: dev.httpPort,
};
options.devWebSocketPort = dev.webSocketPort;
options.devWebSocketPort = dev.httpPort;
}

fse.emptyDirSync(config.assetsBuildDirectory);
Expand Down Expand Up @@ -224,7 +224,6 @@ export async function dev(
httpHost?: string;
httpPort?: number;
restart?: boolean;
websocketPort?: number;
} = {}
) {
if (process.env.NODE_ENV && process.env.NODE_ENV !== "development") {
Expand Down Expand Up @@ -477,7 +476,6 @@ type DevBuildFlags = {
httpScheme: string;
httpHost: string;
httpPort: number;
webSocketPort: number;
};
let resolveDevBuild = async (
config: RemixConfig,
Expand All @@ -501,17 +499,11 @@ let resolveDevBuild = async (
flags.httpPort ??
(dev === true ? undefined : dev.httpPort) ??
(await findPort());
// prettier-ignore
let webSocketPort =
flags.webSocketPort ??
(dev === true ? undefined : dev.webSocketPort) ??
(await findPort());

return {
httpScheme,
httpHost,
httpPort,
webSocketPort,
};
};

Expand All @@ -526,10 +518,7 @@ let resolveDevServe = async (
let dev = config.future.unstable_dev;
if (dev === false) throw Error("Cannot resolve dev options");

let { httpScheme, httpHost, httpPort, webSocketPort } = await resolveDevBuild(
config,
flags
);
let { httpScheme, httpHost, httpPort } = await resolveDevBuild(config, flags);

// prettier-ignore
let command =
Expand Down Expand Up @@ -563,7 +552,6 @@ let resolveDevServe = async (
httpScheme,
httpHost,
httpPort,
webSocketPort,
restart,
};
};
6 changes: 0 additions & 6 deletions packages/remix-dev/cli/run.ts
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,6 @@ ${colors.logoBlue("R")} ${colors.logoGreen("E")} ${colors.logoYellow(
--http-host HTTP(S) host for the dev server. Default: localhost
--http-port HTTP(S) port for the dev server. Default: any open port
--no-restart Do not restart the app server when rebuilds occur.
--websocket-port WebSocket port for the dev server. Default: any open port
\`init\` Options:
--no-delete Skip deleting the \`remix.init\` script
\`routes\` Options:
Expand Down Expand Up @@ -188,7 +187,6 @@ export async function run(argv: string[] = process.argv.slice(2)) {
"--http-host": String,
"--http-port": Number,
"--no-restart": Boolean,
"--websocket-port": Number,
},
{
argv,
Expand Down Expand Up @@ -225,10 +223,6 @@ export async function run(argv: string[] = process.argv.slice(2)) {
flags.httpPort = flags["http-port"];
delete flags["http-port"];
}
if (flags["websocket-port"]) {
flags.webSocketPort = flags["websocket-port"];
delete flags["websocket-port"];
}

if (args["--no-delete"]) {
flags.delete = false;
Expand Down
1 change: 0 additions & 1 deletion packages/remix-dev/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,6 @@ type Dev = {
httpScheme?: string;
httpHost?: string;
httpPort?: number;
webSocketPort?: number;
restart?: boolean;
publicDirectory?: string;
};
Expand Down
57 changes: 30 additions & 27 deletions packages/remix-dev/devServer_unstable/index.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import * as path from "node:path";
import * as stream from "node:stream";
import * as http from "node:http";
import fs from "fs-extra";
import prettyMs from "pretty-ms";
import execa from "execa";
Expand Down Expand Up @@ -44,18 +45,10 @@ export let serve = async (
httpScheme: string;
httpHost: string;
httpPort: number;
webSocketPort: number;
restart: boolean;
}
) => {
await loadEnv(initialConfig.rootDirectory);
let websocket = Socket.serve({ port: options.webSocketPort });
let httpOrigin: Origin = {
scheme: options.httpScheme,
host: options.httpHost,
port: options.httpPort,
};

let state: {
appServer?: execa.ExecaChildProcess;
manifest?: Manifest;
Expand All @@ -65,6 +58,30 @@ export let serve = async (
prevLoaderHashes?: Record<string, string>;
} = {};

let app = express()
// handle `broadcastDevReady` messages
.use(express.json())
.post("/ping", (req, res) => {
let { buildHash } = req.body;
if (typeof buildHash !== "string") {
console.warn(`Unrecognized payload: ${req.body}`);
res.sendStatus(400);
}
if (buildHash === state.manifest?.version) {
state.appReady?.ok();
}
res.sendStatus(200);
});

let server = http.createServer(app);
let websocket = Socket.serve(server);

let httpOrigin: Origin = {
scheme: options.httpScheme,
host: options.httpHost,
port: options.httpPort,
};

let bin = await detectBin();
let startAppServer = (command: string) => {
console.log(`> ${command}`);
Expand Down Expand Up @@ -119,7 +136,7 @@ export let serve = async (
sourcemap: true,
onWarning: warnOnce,
devHttpOrigin: httpOrigin,
devWebSocketPort: options.webSocketPort,
devWebSocketPort: options.httpPort,
},
},
{
Expand Down Expand Up @@ -198,28 +215,14 @@ export let serve = async (
}
);

let httpServer = express()
// handle `broadcastDevReady` messages
.use(express.json())
.post("/ping", (req, res) => {
let { buildHash } = req.body;
if (typeof buildHash !== "string") {
console.warn(`Unrecognized payload: ${req.body}`);
res.sendStatus(400);
}
if (buildHash === state.manifest?.version) {
state.appReady?.ok();
}
res.sendStatus(200);
})
.listen(httpOrigin.port, () => {
console.log("Remix dev server ready");
});
server.listen(httpOrigin.port, () => {
console.log("Remix dev server ready");
});

return new Promise(() => {}).finally(async () => {
await kill(state.appServer);
websocket.close();
httpServer.close();
server.close();
await dispose();
});
};
Expand Down
5 changes: 3 additions & 2 deletions packages/remix-dev/devServer_unstable/socket.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import WebSocket from "ws";
import type { Server as HTTPServer } from "http";

import { type Manifest } from "../manifest";
import type * as HMR from "./hmr";
Expand All @@ -14,8 +15,8 @@ type Message =

type Broadcast = (message: Message) => void;

export let serve = (options: { port: number }) => {
let wss = new WebSocket.Server({ port: options.port });
export let serve = (server: HTTPServer) => {
let wss = new WebSocket.Server({ server });

let broadcast: Broadcast = (message) => {
wss.clients.forEach((client) => {
Expand Down

0 comments on commit c22c934

Please sign in to comment.