Commit bacd3048 authored by Mayra Cabrera's avatar Mayra Cabrera

Merge branch 'sh-webpack-clear-memoization' into 'master'

Clear memoized manifest to solve intermittent spec errors

Closes #255176

See merge request gitlab-org/gitlab!43229
parents 0e74f73d f7b5be1a
......@@ -24,6 +24,8 @@ module Gitlab
AssetMissingError = Class.new(StandardError)
class << self
include Gitlab::Utils::StrongMemoize
def entrypoint_paths(source)
raise WebpackError, manifest["errors"] unless manifest_bundled?
......@@ -55,6 +57,10 @@ module Gitlab
end
end
def clear_manifest!
clear_memoization(:manifest)
end
private
def manifest_bundled?
......@@ -67,7 +73,7 @@ module Gitlab
load_manifest
else
# ... otherwise cache at class level, as JSON loading/parsing can be expensive
@manifest ||= load_manifest
strong_memoize(:manifest) { load_manifest }
end
end
......
......@@ -16,6 +16,14 @@ RSpec.describe Gitlab::Webpack::Manifest do
EOF
end
around do |example|
Gitlab::Webpack::Manifest.clear_manifest!
example.run
Gitlab::Webpack::Manifest.clear_manifest!
end
shared_examples_for "a valid manifest" do
it "returns single entry asset paths from the manifest" do
expect(Gitlab::Webpack::Manifest.asset_paths("entry2")).to eq(["/public_path/entry2.js"])
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment