Commit 5287cf67 authored by Igor Drozdov's avatar Igor Drozdov

Create project-feature in project factory

It'll avoid an update after the factory created
parent ba6c21a0
...@@ -40,7 +40,7 @@ FactoryBot.define do ...@@ -40,7 +40,7 @@ FactoryBot.define do
forward_deployment_enabled { nil } forward_deployment_enabled { nil }
end end
after(:create) do |project, evaluator| before(:create) do |project, evaluator|
# Builds and MRs can't have higher visibility level than repository access level. # Builds and MRs can't have higher visibility level than repository access level.
builds_access_level = [evaluator.builds_access_level, evaluator.repository_access_level].min builds_access_level = [evaluator.builds_access_level, evaluator.repository_access_level].min
merge_requests_access_level = [evaluator.merge_requests_access_level, evaluator.repository_access_level].min merge_requests_access_level = [evaluator.merge_requests_access_level, evaluator.repository_access_level].min
...@@ -56,8 +56,10 @@ FactoryBot.define do ...@@ -56,8 +56,10 @@ FactoryBot.define do
pages_access_level: evaluator.pages_access_level pages_access_level: evaluator.pages_access_level
} }
project.project_feature.update!(hash) project.build_project_feature(hash)
end
after(:create) do |project, evaluator|
# Normally the class Projects::CreateService is used for creating # Normally the class Projects::CreateService is used for creating
# projects, and this class takes care of making sure the owner and current # projects, and this class takes care of making sure the owner and current
# user have access to the project. Our specs don't use said service class, # user have access to the project. Our specs don't use said service class,
......
...@@ -38,16 +38,17 @@ RSpec.describe 'Projects::MetricsDashboardController' do ...@@ -38,16 +38,17 @@ RSpec.describe 'Projects::MetricsDashboardController' do
context 'with anonymous user and public dashboard visibility' do context 'with anonymous user and public dashboard visibility' do
let(:anonymous_user) { create(:user) } let(:anonymous_user) { create(:user) }
let(:project) do let(:project) { create(:project, :public) }
create(:project, :public, metrics_dashboard_access_level: 'enabled')
end
before do before do
project.update!(metrics_dashboard_access_level: 'enabled')
login_as(anonymous_user) login_as(anonymous_user)
end end
it 'returns 200' do it 'returns 200' do
send_request send_request
expect(response).to have_gitlab_http_status(:ok) expect(response).to have_gitlab_http_status(:ok)
end end
end end
......
...@@ -16,6 +16,8 @@ RSpec.describe Projects::OverwriteProjectService do ...@@ -16,6 +16,8 @@ RSpec.describe Projects::OverwriteProjectService do
subject { described_class.new(project_to, user) } subject { described_class.new(project_to, user) }
before do before do
project_to.project_feature.reload
allow(project_to).to receive(:import_data).and_return(double(data: { 'original_path' => project_from.path })) allow(project_to).to receive(:import_data).and_return(double(data: { 'original_path' => project_from.path }))
end end
......
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