From 0c3fb7e32819d59ce63baed7e125d46e4d958170 Mon Sep 17 00:00:00 2001 From: Dan Arnfield Date: Fri, 29 Dec 2023 01:32:46 -0600 Subject: [PATCH] fix: `hmr: false` doesn't disable Hot Module Replacement (#392) * webpacker-dev-server >= 4 enables HMR by default, so explicitly disable when `hmr: false` --- CHANGELOG.md | 1 + lib/shakapacker/dev_server_runner.rb | 5 +++-- .../dev_server_runner_spec.rb | 20 +++++++++---------- .../webpacker_test_app/config/webpacker.yml | 2 +- .../config/webpacker_other_location.yml | 2 +- spec/shakapacker/dev_server_runner_spec.rb | 20 +++++++++---------- .../test_app/config/shakapacker.yml | 2 +- .../config/shakapacker_other_location.yml | 2 +- 8 files changed, 28 insertions(+), 26 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 0dab3273a..c15fbd52e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -18,6 +18,7 @@ _Please add entries here for your pull requests that are not yet released._ - Recommend `server` option instead of deprecated `https` option when `--https` is provided [PR 380](https://github.com/shakacode/shakapacker/pull/380) by [G-Rath](https://github.com/g-rath) - Recompile assets on asset host change [PR 364](https://github.com/shakacode/shakapacker/pull/364) by [ahangarha](https://github.com/ahangarha). - Add deprecation warning for `https` option in `shakapacker.yml` (use `server: 'https'` instead) [PR 382](https://github.com/shakacode/shakapacker/pull/382) by [G-Rath](https://github.com/g-rath). +- Disable Hot Module Replacement in `webpack-dev-server` when `hmr: false` [PR 392](https://github.com/shakacode/shakapacker/pull/392) by [thedanbob](https://github.com/thedanbob). ### Deprecated - The usage of relative_url_root is deprecated in Shakapacker and will be removed in v8. [PR 376](https://github.com/shakacode/shakapacker/pull/376) by [ahangarha](https://github.com/ahangarha). diff --git a/lib/shakapacker/dev_server_runner.rb b/lib/shakapacker/dev_server_runner.rb index dc0d55806..c479a2ecc 100644 --- a/lib/shakapacker/dev_server_runner.rb +++ b/lib/shakapacker/dev_server_runner.rb @@ -86,8 +86,9 @@ def execute_cmd cmd += ["--config", @webpack_config] cmd += ["--progress", "--color"] if @pretty - cmd += ["--hot"] if @hot - cmd += ["only"] if @hot == "only" + # Default behavior of webpack-dev-server is @hot = true + cmd += ["--hot", "only"] if @hot == "only" + cmd += ["--no-hot"] if !@hot cmd += @argv diff --git a/spec/backward_compatibility_specs/dev_server_runner_spec.rb b/spec/backward_compatibility_specs/dev_server_runner_spec.rb index e31a674b4..3fe853ff4 100644 --- a/spec/backward_compatibility_specs/dev_server_runner_spec.rb +++ b/spec/backward_compatibility_specs/dev_server_runner_spec.rb @@ -54,7 +54,7 @@ port: "3035", pretty?: false, protocol: "https", - hmr?: false + hmr?: true ) ) @@ -70,15 +70,15 @@ port: "3035", pretty?: false, protocol: "https", - hmr?: false + hmr?: true ) ) verify_command(cmd, argv: ["--https"]) end - it "supports hot module reloading" do - cmd = package_json.manager.native_exec_command("webpack", ["serve", "--config", "#{test_app_path}/config/webpack/webpack.config.js", "--hot"]) + it "supports disabling hot module reloading" do + cmd = package_json.manager.native_exec_command("webpack", ["serve", "--config", "#{test_app_path}/config/webpack/webpack.config.js", "--no-hot"]) allow(Shakapacker::DevServer).to receive(:new).and_return( double( @@ -86,7 +86,7 @@ port: "3035", pretty?: false, protocol: "http", - hmr?: true + hmr?: false ) ) @@ -136,7 +136,7 @@ port: "3035", pretty?: false, protocol: "https", - hmr?: false + hmr?: true ) ) @@ -152,15 +152,15 @@ port: "3035", pretty?: false, protocol: "https", - hmr?: false + hmr?: true ) ) verify_command(cmd, argv: ["--https"]) end - it "supports hot module reloading" do - cmd = ["#{test_app_path}/node_modules/.bin/webpack", "serve", "--config", "#{test_app_path}/config/webpack/webpack.config.js", "--hot"] + it "supports disabling hot module reloading" do + cmd = ["#{test_app_path}/node_modules/.bin/webpack", "serve", "--config", "#{test_app_path}/config/webpack/webpack.config.js", "--no-hot"] allow(Shakapacker::DevServer).to receive(:new).and_return( double( @@ -168,7 +168,7 @@ port: "3035", pretty?: false, protocol: "http", - hmr?: true + hmr?: false ) ) diff --git a/spec/backward_compatibility_specs/webpacker_test_app/config/webpacker.yml b/spec/backward_compatibility_specs/webpacker_test_app/config/webpacker.yml index a51f2dba2..367758736 100644 --- a/spec/backward_compatibility_specs/webpacker_test_app/config/webpacker.yml +++ b/spec/backward_compatibility_specs/webpacker_test_app/config/webpacker.yml @@ -48,7 +48,7 @@ development: host: localhost port: 3035 public: localhost:3035 - hmr: false + hmr: true overlay: true disable_host_check: true use_local_ip: false diff --git a/spec/backward_compatibility_specs/webpacker_test_app/config/webpacker_other_location.yml b/spec/backward_compatibility_specs/webpacker_test_app/config/webpacker_other_location.yml index 9e4360087..9bf33999f 100644 --- a/spec/backward_compatibility_specs/webpacker_test_app/config/webpacker_other_location.yml +++ b/spec/backward_compatibility_specs/webpacker_test_app/config/webpacker_other_location.yml @@ -42,7 +42,7 @@ development: host: localhost port: 3035 public: localhost:3035 - hmr: false + hmr: true # If HMR is on, CSS will by inlined by delivering it as part of the script payload via style-loader. Be sure # that you add style-loader to your project dependencies. # diff --git a/spec/shakapacker/dev_server_runner_spec.rb b/spec/shakapacker/dev_server_runner_spec.rb index 0fe3095a6..5df059f91 100644 --- a/spec/shakapacker/dev_server_runner_spec.rb +++ b/spec/shakapacker/dev_server_runner_spec.rb @@ -53,7 +53,7 @@ port: "3035", pretty?: false, protocol: "https", - hmr?: false + hmr?: true ) ) @@ -69,15 +69,15 @@ port: "3035", pretty?: false, protocol: "https", - hmr?: false + hmr?: true ) ) verify_command(cmd, argv: ["--https"]) end - it "supports hot module reloading" do - cmd = package_json.manager.native_exec_command("webpack", ["serve", "--config", "#{test_app_path}/config/webpack/webpack.config.js", "--hot"]) + it "supports disabling hot module reloading" do + cmd = package_json.manager.native_exec_command("webpack", ["serve", "--config", "#{test_app_path}/config/webpack/webpack.config.js", "--no-hot"]) allow(Shakapacker::DevServer).to receive(:new).and_return( double( @@ -85,7 +85,7 @@ port: "3035", pretty?: false, protocol: "http", - hmr?: true + hmr?: false ) ) @@ -134,7 +134,7 @@ port: "3035", pretty?: false, protocol: "https", - hmr?: false + hmr?: true ) ) @@ -150,15 +150,15 @@ port: "3035", pretty?: false, protocol: "https", - hmr?: false + hmr?: true ) ) verify_command(cmd, argv: ["--https"]) end - it "supports hot module reloading" do - cmd = ["#{test_app_path}/node_modules/.bin/webpack", "serve", "--config", "#{test_app_path}/config/webpack/webpack.config.js", "--hot"] + it "supports disabling hot module reloading" do + cmd = ["#{test_app_path}/node_modules/.bin/webpack", "serve", "--config", "#{test_app_path}/config/webpack/webpack.config.js", "--no-hot"] allow(Shakapacker::DevServer).to receive(:new).and_return( double( @@ -166,7 +166,7 @@ port: "3035", pretty?: false, protocol: "http", - hmr?: true + hmr?: false ) ) diff --git a/spec/shakapacker/test_app/config/shakapacker.yml b/spec/shakapacker/test_app/config/shakapacker.yml index 8dc9de404..57a3cc7e5 100644 --- a/spec/shakapacker/test_app/config/shakapacker.yml +++ b/spec/shakapacker/test_app/config/shakapacker.yml @@ -47,7 +47,7 @@ development: host: localhost port: 3035 public: localhost:3035 - hmr: false + hmr: true overlay: true disable_host_check: true use_local_ip: false diff --git a/spec/shakapacker/test_app/config/shakapacker_other_location.yml b/spec/shakapacker/test_app/config/shakapacker_other_location.yml index 8ea4cfdc4..5d972ea8b 100644 --- a/spec/shakapacker/test_app/config/shakapacker_other_location.yml +++ b/spec/shakapacker/test_app/config/shakapacker_other_location.yml @@ -42,7 +42,7 @@ development: host: localhost port: 3035 public: localhost:3035 - hmr: false + hmr: true # If HMR is on, CSS will by inlined by delivering it as part of the script payload via style-loader. Be sure # that you add style-loader to your project dependencies. #