Upgrade Webpacker to version 3.0.1 (#5122)
This commit is contained in:
		
				
					committed by
					
						
						Eugen Rochko
					
				
			
			
				
	
			
			
			
						parent
						
							3caf0ba923
						
					
				
				
					commit
					901fc48aae
				
			
							
								
								
									
										2
									
								
								Gemfile
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								Gemfile
									
									
									
									
									
								
							@@ -67,7 +67,7 @@ gem 'sprockets-rails', '~> 3.2', require: 'sprockets/railtie'
 | 
				
			|||||||
gem 'statsd-instrument', '~> 2.1'
 | 
					gem 'statsd-instrument', '~> 2.1'
 | 
				
			||||||
gem 'twitter-text', '~> 1.14'
 | 
					gem 'twitter-text', '~> 1.14'
 | 
				
			||||||
gem 'tzinfo-data', '~> 1.2017'
 | 
					gem 'tzinfo-data', '~> 1.2017'
 | 
				
			||||||
gem 'webpacker', '~> 2.0'
 | 
					gem 'webpacker', '~> 3.0'
 | 
				
			||||||
gem 'webpush'
 | 
					gem 'webpush'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
gem 'json-ld-preloaded', '~> 2.2.1'
 | 
					gem 'json-ld-preloaded', '~> 2.2.1'
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -335,6 +335,8 @@ GEM
 | 
				
			|||||||
    rack-cors (0.4.1)
 | 
					    rack-cors (0.4.1)
 | 
				
			||||||
    rack-protection (2.0.0)
 | 
					    rack-protection (2.0.0)
 | 
				
			||||||
      rack
 | 
					      rack
 | 
				
			||||||
 | 
					    rack-proxy (0.6.2)
 | 
				
			||||||
 | 
					      rack
 | 
				
			||||||
    rack-test (0.7.0)
 | 
					    rack-test (0.7.0)
 | 
				
			||||||
      rack (>= 1.0, < 3)
 | 
					      rack (>= 1.0, < 3)
 | 
				
			||||||
    rack-timeout (0.4.2)
 | 
					    rack-timeout (0.4.2)
 | 
				
			||||||
@@ -510,9 +512,9 @@ GEM
 | 
				
			|||||||
      addressable (>= 2.3.6)
 | 
					      addressable (>= 2.3.6)
 | 
				
			||||||
      crack (>= 0.3.2)
 | 
					      crack (>= 0.3.2)
 | 
				
			||||||
      hashdiff
 | 
					      hashdiff
 | 
				
			||||||
    webpacker (2.0)
 | 
					    webpacker (3.0.1)
 | 
				
			||||||
      activesupport (>= 4.2)
 | 
					      activesupport (>= 4.2)
 | 
				
			||||||
      multi_json (~> 1.2)
 | 
					      rack-proxy (>= 0.6.1)
 | 
				
			||||||
      railties (>= 4.2)
 | 
					      railties (>= 4.2)
 | 
				
			||||||
    webpush (0.3.2)
 | 
					    webpush (0.3.2)
 | 
				
			||||||
      hkdf (~> 0.2)
 | 
					      hkdf (~> 0.2)
 | 
				
			||||||
@@ -621,7 +623,7 @@ DEPENDENCIES
 | 
				
			|||||||
  tzinfo-data (~> 1.2017)
 | 
					  tzinfo-data (~> 1.2017)
 | 
				
			||||||
  uglifier (~> 3.2)
 | 
					  uglifier (~> 3.2)
 | 
				
			||||||
  webmock (~> 3.0)
 | 
					  webmock (~> 3.0)
 | 
				
			||||||
  webpacker (~> 2.0)
 | 
					  webpacker (~> 3.0)
 | 
				
			||||||
  webpush
 | 
					  webpush
 | 
				
			||||||
 | 
					
 | 
				
			||||||
RUBY VERSION
 | 
					RUBY VERSION
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,4 @@
 | 
				
			|||||||
web: PORT=3000 bundle exec puma -C config/puma.rb
 | 
					web: PORT=3000 bundle exec puma -C config/puma.rb
 | 
				
			||||||
sidekiq: PORT=3000 bundle exec sidekiq
 | 
					sidekiq: PORT=3000 bundle exec sidekiq
 | 
				
			||||||
stream: PORT=4000 yarn run start
 | 
					stream: PORT=4000 yarn run start
 | 
				
			||||||
webpack: ./bin/webpack-dev-server --host 0.0.0.0
 | 
					webpack: ./bin/webpack-dev-server --listen-host 0.0.0.0
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -2,7 +2,6 @@
 | 
				
			|||||||
$stdout.sync = true
 | 
					$stdout.sync = true
 | 
				
			||||||
 | 
					
 | 
				
			||||||
require "shellwords"
 | 
					require "shellwords"
 | 
				
			||||||
require "yaml"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
ENV["RAILS_ENV"] ||= "development"
 | 
					ENV["RAILS_ENV"] ||= "development"
 | 
				
			||||||
RAILS_ENV = ENV["RAILS_ENV"]
 | 
					RAILS_ENV = ENV["RAILS_ENV"]
 | 
				
			||||||
@@ -20,9 +19,9 @@ unless File.exist?(WEBPACK_CONFIG)
 | 
				
			|||||||
  exit!
 | 
					  exit!
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
newenv  = { "NODE_PATH" => NODE_MODULES_PATH.shellescape }
 | 
					env = { "NODE_PATH" => NODE_MODULES_PATH.shellescape }
 | 
				
			||||||
cmdline = ["yarn", "run", "webpack", "--", "--config", WEBPACK_CONFIG] + ARGV
 | 
					cmd = [ "#{NODE_MODULES_PATH}/.bin/webpack", "--config", WEBPACK_CONFIG ] + ARGV
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Dir.chdir(APP_PATH) do
 | 
					Dir.chdir(APP_PATH) do
 | 
				
			||||||
  exec newenv, *cmdline
 | 
					  exec env, *cmd
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,6 +3,7 @@ $stdout.sync = true
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
require "shellwords"
 | 
					require "shellwords"
 | 
				
			||||||
require "yaml"
 | 
					require "yaml"
 | 
				
			||||||
 | 
					require "socket"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ENV["RAILS_ENV"] ||= "development"
 | 
					ENV["RAILS_ENV"] ||= "development"
 | 
				
			||||||
RAILS_ENV = ENV["RAILS_ENV"]
 | 
					RAILS_ENV = ENV["RAILS_ENV"]
 | 
				
			||||||
@@ -13,7 +14,9 @@ NODE_ENV = ENV["NODE_ENV"]
 | 
				
			|||||||
APP_PATH          = File.expand_path("../", __dir__)
 | 
					APP_PATH          = File.expand_path("../", __dir__)
 | 
				
			||||||
CONFIG_FILE       = File.join(APP_PATH, "config/webpacker.yml")
 | 
					CONFIG_FILE       = File.join(APP_PATH, "config/webpacker.yml")
 | 
				
			||||||
NODE_MODULES_PATH = File.join(APP_PATH, "node_modules")
 | 
					NODE_MODULES_PATH = File.join(APP_PATH, "node_modules")
 | 
				
			||||||
WEBPACK_CONFIG    = File.join(APP_PATH, "config/webpack/development.js")
 | 
					WEBPACK_CONFIG    = File.join(APP_PATH, "config/webpack/#{NODE_ENV}.js")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					DEFAULT_LISTEN_HOST_ADDR = NODE_ENV == 'development' ? 'localhost' : '0.0.0.0'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
def args(key)
 | 
					def args(key)
 | 
				
			||||||
  index = ARGV.index(key)
 | 
					  index = ARGV.index(key)
 | 
				
			||||||
@@ -21,23 +24,45 @@ def args(key)
 | 
				
			|||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
begin
 | 
					begin
 | 
				
			||||||
  dev_server = YAML.load_file(CONFIG_FILE)["development"]["dev_server"]
 | 
					  dev_server = YAML.load_file(CONFIG_FILE)[RAILS_ENV]["dev_server"]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  DEV_SERVER_HOST = "http#{"s" if args('--https') || dev_server["https"]}://#{dev_server["host"]}:#{args('--port') || dev_server["port"]}"
 | 
					  HOSTNAME          = args('--host') || dev_server["host"]
 | 
				
			||||||
 | 
					  PORT              = args('--port') || dev_server["port"]
 | 
				
			||||||
 | 
					  HTTPS             = ARGV.include?('--https') || dev_server["https"]
 | 
				
			||||||
 | 
					  DEV_SERVER_ADDR   = "http#{"s" if HTTPS}://#{HOSTNAME}:#{PORT}"
 | 
				
			||||||
 | 
					  LISTEN_HOST_ADDR  = args('--listen-host') || DEFAULT_LISTEN_HOST_ADDR
 | 
				
			||||||
 | 
					
 | 
				
			||||||
rescue Errno::ENOENT, NoMethodError
 | 
					rescue Errno::ENOENT, NoMethodError
 | 
				
			||||||
  puts "Webpack dev_server configuration not found in #{CONFIG_FILE}."
 | 
					  $stdout.puts "Webpack dev_server configuration not found in #{CONFIG_FILE}."
 | 
				
			||||||
  puts "Please run bundle exec rails webpacker:install to install webpacker"
 | 
					  $stdout.puts "Please run bundle exec rails webpacker:install to install webpacker"
 | 
				
			||||||
  exit!
 | 
					  exit!
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
newenv = {
 | 
					begin
 | 
				
			||||||
  "NODE_PATH" => NODE_MODULES_PATH.shellescape,
 | 
					  server = TCPServer.new(LISTEN_HOST_ADDR, PORT)
 | 
				
			||||||
  "ASSET_HOST" => DEV_SERVER_HOST.shellescape
 | 
					  server.close
 | 
				
			||||||
}.freeze
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
cmdline = ["yarn", "run", "webpack-dev-server", "--", "--progress", "--color", "--config", WEBPACK_CONFIG] + ARGV
 | 
					rescue Errno::EADDRINUSE
 | 
				
			||||||
 | 
					  $stdout.puts "Another program is running on port #{PORT}. Set a new port in #{CONFIG_FILE} for dev_server"
 | 
				
			||||||
 | 
					  exit!
 | 
				
			||||||
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Delete supplied host, port and listen-host CLI arguments
 | 
				
			||||||
 | 
					["--host", "--port", "--listen-host"].each do |arg|
 | 
				
			||||||
 | 
					  ARGV.delete(args(arg))
 | 
				
			||||||
 | 
					  ARGV.delete(arg)
 | 
				
			||||||
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					env = { "NODE_PATH" => NODE_MODULES_PATH.shellescape }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					cmd = [
 | 
				
			||||||
 | 
					  "#{NODE_MODULES_PATH}/.bin/webpack-dev-server", "--progress", "--color",
 | 
				
			||||||
 | 
					  "--config", WEBPACK_CONFIG,
 | 
				
			||||||
 | 
					  "--host", LISTEN_HOST_ADDR,
 | 
				
			||||||
 | 
					  "--public", "#{HOSTNAME}:#{PORT}",
 | 
				
			||||||
 | 
					  "--port", PORT.to_s
 | 
				
			||||||
 | 
					] + ARGV
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Dir.chdir(APP_PATH) do
 | 
					Dir.chdir(APP_PATH) do
 | 
				
			||||||
  exec newenv, *cmdline
 | 
					  exec env, *cmd
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -4,6 +4,15 @@ default: &default
 | 
				
			|||||||
  source_path: app/javascript
 | 
					  source_path: app/javascript
 | 
				
			||||||
  source_entry_path: packs
 | 
					  source_entry_path: packs
 | 
				
			||||||
  public_output_path: packs
 | 
					  public_output_path: packs
 | 
				
			||||||
 | 
					  cache_path: tmp/cache/webpacker
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  # Additional paths webpack should lookup modules
 | 
				
			||||||
 | 
					  # ['app/assets', 'engine/foo/app/assets']
 | 
				
			||||||
 | 
					  resolved_paths: []
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  # Reload manifest.json on all requests so we reload latest compiled packs
 | 
				
			||||||
 | 
					  cache_manifest: false
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  extensions:
 | 
					  extensions:
 | 
				
			||||||
    - .js
 | 
					    - .js
 | 
				
			||||||
    - .sass
 | 
					    - .sass
 | 
				
			||||||
@@ -17,16 +26,25 @@ default: &default
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
development:
 | 
					development:
 | 
				
			||||||
  <<: *default
 | 
					  <<: *default
 | 
				
			||||||
 | 
					  compile: true
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  dev_server:
 | 
					  dev_server:
 | 
				
			||||||
    host: 127.0.0.1
 | 
					    host: localhost
 | 
				
			||||||
    port: 8080
 | 
					    port: 3035
 | 
				
			||||||
 | 
					    hmr: false
 | 
				
			||||||
    https: false
 | 
					    https: false
 | 
				
			||||||
 | 
					
 | 
				
			||||||
test:
 | 
					test:
 | 
				
			||||||
  <<: *default
 | 
					  <<: *default
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  # Compile test packs to a separate directory
 | 
				
			||||||
  public_output_path: packs-test
 | 
					  public_output_path: packs-test
 | 
				
			||||||
 | 
					
 | 
				
			||||||
production:
 | 
					production:
 | 
				
			||||||
  <<: *default
 | 
					  <<: *default
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  # Production depends on precompilation of packs prior to booting for performance.
 | 
				
			||||||
 | 
					  compile: false
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  # Cache manifest.json for performance
 | 
				
			||||||
 | 
					  cache_manifest: true
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -16,7 +16,7 @@ end
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
if Rake::Task.task_defined?('assets:precompile')
 | 
					if Rake::Task.task_defined?('assets:precompile')
 | 
				
			||||||
  Rake::Task['assets:precompile'].enhance do
 | 
					  Rake::Task['assets:precompile'].enhance do
 | 
				
			||||||
    Webpacker::Manifest.load
 | 
					    Webpacker.manifest.refresh
 | 
				
			||||||
    Rake::Task['assets:generate_static_pages'].invoke
 | 
					    Rake::Task['assets:generate_static_pages'].invoke
 | 
				
			||||||
  end
 | 
					  end
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user