Commit 9eac3fdb authored by Robert Speicher's avatar Robert Speicher

Merge branch 'fix-for-tree-restorer-spec' into 'master'

Fix tree_restorer spec

Closes #213793

See merge request gitlab-org/gitlab!29141
parents 910f0f5a 58f24bc1
...@@ -11,7 +11,7 @@ describe Gitlab::ImportExport::Project::TreeRestorer do ...@@ -11,7 +11,7 @@ describe Gitlab::ImportExport::Project::TreeRestorer do
let(:shared) { project.import_export_shared } let(:shared) { project.import_export_shared }
RSpec.shared_examples 'project tree restorer work properly' do |reader| RSpec.shared_examples 'project tree restorer work properly' do |reader, ndjson_enabled|
describe 'restore project tree' do describe 'restore project tree' do
before_all do before_all do
# Using an admin for import, so we can check assignment of existing members # Using an admin for import, so we can check assignment of existing members
...@@ -25,6 +25,9 @@ describe Gitlab::ImportExport::Project::TreeRestorer do ...@@ -25,6 +25,9 @@ describe Gitlab::ImportExport::Project::TreeRestorer do
@project = create(:project, :builds_enabled, :issues_disabled, name: 'project', path: 'project') @project = create(:project, :builds_enabled, :issues_disabled, name: 'project', path: 'project')
@shared = @project.import_export_shared @shared = @project.import_export_shared
allow(Feature).to receive(:enabled?).and_call_original
stub_feature_flags(project_import_ndjson: ndjson_enabled)
setup_import_export_config('complex') setup_import_export_config('complex')
setup_reader(reader) setup_reader(reader)
...@@ -999,23 +1002,12 @@ describe Gitlab::ImportExport::Project::TreeRestorer do ...@@ -999,23 +1002,12 @@ describe Gitlab::ImportExport::Project::TreeRestorer do
end end
context 'enable ndjson import' do context 'enable ndjson import' do
before_all do it_behaves_like 'project tree restorer work properly', :legacy_reader, true
# Test suite `restore project tree` run `project_tree_restorer.restore` in `before_all`.
# `Enable all features by default for testing` happens in `before(:each)`
# So it requires manually enable feature flag to allow ndjson_reader
Feature.enable(:project_import_ndjson)
end
it_behaves_like 'project tree restorer work properly', :legacy_reader
it_behaves_like 'project tree restorer work properly', :ndjson_reader it_behaves_like 'project tree restorer work properly', :ndjson_reader, true
end end
context 'disable ndjson import' do context 'disable ndjson import' do
before do it_behaves_like 'project tree restorer work properly', :legacy_reader, false
stub_feature_flags(project_import_ndjson: false)
end
it_behaves_like 'project tree restorer work properly', :legacy_reader
end end
end end
...@@ -16,7 +16,6 @@ describe Gitlab::ImportExport::Project::TreeSaver do ...@@ -16,7 +16,6 @@ describe Gitlab::ImportExport::Project::TreeSaver do
let_it_be(:group) { create(:group) } let_it_be(:group) { create(:group) }
let_it_be(:project) { setup_project } let_it_be(:project) { setup_project }
let_it_be(:shared) { project.import_export_shared } let_it_be(:shared) { project.import_export_shared }
let_it_be(:project_tree_saver ) { described_class.new(project: project, current_user: user, shared: shared) }
let(:relation_name) { :projects } let(:relation_name) { :projects }
...@@ -29,10 +28,18 @@ describe Gitlab::ImportExport::Project::TreeSaver do ...@@ -29,10 +28,18 @@ describe Gitlab::ImportExport::Project::TreeSaver do
end end
before_all do before_all do
Feature.enable(:project_export_as_ndjson) if ndjson_enabled RSpec::Mocks.with_temporary_scope do
allow(Feature).to receive(:enabled?).and_call_original
stub_feature_flags(project_export_as_ndjson: ndjson_enabled)
project.add_maintainer(user) project.add_maintainer(user)
stub_feature_flags(project_export_as_ndjson: ndjson_enabled)
project_tree_saver = described_class.new(project: project, current_user: user, shared: shared)
project_tree_saver.save project_tree_saver.save
end end
end
after :all do after :all do
FileUtils.rm_rf(export_path) FileUtils.rm_rf(export_path)
......
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