Commit a5d10d4c authored by Igor Drozdov's avatar Igor Drozdov

Reset state correctly for tests failed in Rails 6.1

Objects created via let_it_be are shared between tests.
Sometimes we reload them in order to reset the state.
Sometimes it's not enough.
For example, some tests fail because @_destroyed instance
variable preserved. So the objects removed in a previous
test, marked as removed in the subsequent ones.

Let's use refind to fix those cases
parent 06dd3bcf
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe 'User manages merge trains option', :js do RSpec.describe 'User manages merge trains option', :js do
let_it_be(:project) { create(:project) } let_it_be(:project, refind: true) { create(:project) }
let_it_be(:user) { create(:user) } let_it_be(:user) { create(:user) }
before do before do
......
...@@ -119,7 +119,7 @@ RSpec.describe Gitlab::SeatLinkData do ...@@ -119,7 +119,7 @@ RSpec.describe Gitlab::SeatLinkData do
end end
describe '#should_sync_seats?' do describe '#should_sync_seats?' do
let_it_be(:historical_data) { create(:historical_data, recorded_at: timestamp) } let_it_be(:historical_data, refind: true) { create(:historical_data, recorded_at: timestamp) }
let(:license) { build(:license, :cloud) } let(:license) { build(:license, :cloud) }
......
...@@ -8,7 +8,7 @@ RSpec.describe Mutations::Boards::EpicBoards::Destroy do ...@@ -8,7 +8,7 @@ RSpec.describe Mutations::Boards::EpicBoards::Destroy do
let_it_be_with_reload(:current_user) { create(:user) } let_it_be_with_reload(:current_user) { create(:user) }
let_it_be_with_reload(:group) { create(:group) } let_it_be_with_reload(:group) { create(:group) }
let_it_be(:board) { create(:epic_board, group: group) } let_it_be(:board) { create(:epic_board, group: group) }
let_it_be(:other_board) { create(:epic_board, group: group) } let_it_be(:other_board, refind: true) { create(:epic_board, group: group) }
let(:mutation) do let(:mutation) do
variables = { variables = {
......
...@@ -5,10 +5,10 @@ require 'spec_helper' ...@@ -5,10 +5,10 @@ require 'spec_helper'
RSpec.describe 'Destroy an epic board list' do RSpec.describe 'Destroy an epic board list' do
include GraphqlHelpers include GraphqlHelpers
let_it_be(:current_user, reload: true) { create(:user) } let_it_be(:current_user, refind: true) { create(:user) }
let_it_be(:group) { create(:group, :private) } let_it_be(:group) { create(:group, :private) }
let_it_be(:board) { create(:epic_board, group: group) } let_it_be(:board) { create(:epic_board, group: group) }
let_it_be(:list) { create(:epic_list, epic_board: board) } let_it_be(:list, refind: true) { create(:epic_list, epic_board: board) }
let(:variables) do let(:variables) do
{ {
......
...@@ -8,7 +8,8 @@ RSpec.describe 'Update of an existing issue' do ...@@ -8,7 +8,8 @@ RSpec.describe 'Update of an existing issue' do
let_it_be(:group) { create(:group) } let_it_be(:group) { create(:group) }
let_it_be(:current_user) { create(:user) } let_it_be(:current_user) { create(:user) }
let_it_be(:project) { create(:project, :public, group: group) } let_it_be(:project) { create(:project, :public, group: group) }
let_it_be(:issue) { create(:issue, project: project) } let_it_be(:issue, refind: true) { create(:issue, project: project) }
let(:input) do let(:input) do
{ {
'iid' => issue.iid.to_s, 'iid' => issue.iid.to_s,
......
...@@ -7,7 +7,7 @@ RSpec.describe AppSec::Dast::Profiles::DestroyService do ...@@ -7,7 +7,7 @@ RSpec.describe AppSec::Dast::Profiles::DestroyService do
let_it_be(:user) { create(:user) } let_it_be(:user) { create(:user) }
let_it_be(:project) { create(:project) } let_it_be(:project) { create(:project) }
let_it_be(:dast_profile, reload: true) { create(:dast_profile, project: project) } let_it_be(:dast_profile, refind: true) { create(:dast_profile, project: project) }
subject do subject do
described_class.new( described_class.new(
......
...@@ -8,7 +8,7 @@ RSpec.describe Dast::SiteProfileSecretVariables::DestroyService do ...@@ -8,7 +8,7 @@ RSpec.describe Dast::SiteProfileSecretVariables::DestroyService do
let_it_be(:user) { create(:user) } let_it_be(:user) { create(:user) }
let_it_be(:project) { create(:project) } let_it_be(:project) { create(:project) }
let_it_be(:dast_site_profile) { create(:dast_site_profile, project: project) } let_it_be(:dast_site_profile) { create(:dast_site_profile, project: project) }
let_it_be(:dast_site_profile_secret_variable, reload: true) { create(:dast_site_profile_secret_variable, dast_site_profile: dast_site_profile) } let_it_be(:dast_site_profile_secret_variable, refind: true) { create(:dast_site_profile_secret_variable, dast_site_profile: dast_site_profile) }
subject do subject do
described_class.new( described_class.new(
......
...@@ -7,7 +7,7 @@ RSpec.describe Geo::RepositoriesCleanUpWorker, :geo do ...@@ -7,7 +7,7 @@ RSpec.describe Geo::RepositoriesCleanUpWorker, :geo do
include ExclusiveLeaseHelpers include ExclusiveLeaseHelpers
describe '#perform' do describe '#perform' do
let_it_be(:secondary) { create(:geo_node) } let_it_be(:secondary, refind: true) { create(:geo_node) }
let_it_be(:synced_group) { create(:group) } let_it_be(:synced_group) { create(:group) }
let_it_be(:synced_subgroup) { create(:group, parent: synced_group) } let_it_be(:synced_subgroup) { create(:group, parent: synced_group) }
let_it_be(:unsynced_group) { create(:group) } let_it_be(:unsynced_group) { create(:group) }
......
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe Gitlab::Ci::Config::Entry::Default do RSpec.describe Gitlab::Ci::Config::Entry::Default do
let(:config) { {} }
let(:entry) { described_class.new(config) } let(:entry) { described_class.new(config) }
it_behaves_like 'with inheritable CI config' do it_behaves_like 'with inheritable CI config' do
......
...@@ -20,6 +20,7 @@ RSpec.describe Gitlab::Ci::Config::Entry::Hidden do ...@@ -20,6 +20,7 @@ RSpec.describe Gitlab::Ci::Config::Entry::Hidden do
end end
describe '.new' do describe '.new' do
let(:config) { {} }
let(:entry) { described_class.new(config) } let(:entry) { described_class.new(config) }
describe 'validations' do describe 'validations' do
...@@ -41,8 +42,6 @@ RSpec.describe Gitlab::Ci::Config::Entry::Hidden do ...@@ -41,8 +42,6 @@ RSpec.describe Gitlab::Ci::Config::Entry::Hidden do
context 'when entry value is not correct' do context 'when entry value is not correct' do
context 'when config is empty' do context 'when config is empty' do
let(:config) { {} }
describe '#valid' do describe '#valid' do
it 'is invalid' do it 'is invalid' do
expect(entry).not_to be_valid expect(entry).not_to be_valid
......
...@@ -3,6 +3,8 @@ ...@@ -3,6 +3,8 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe Gitlab::Ci::Config::Entry::Kubernetes do RSpec.describe Gitlab::Ci::Config::Entry::Kubernetes do
let(:config) { Hash(namespace: 'namespace') }
subject { described_class.new(config) } subject { described_class.new(config) }
describe 'attributes' do describe 'attributes' do
......
...@@ -2815,11 +2815,11 @@ RSpec.describe Project, factory_default: :keep do ...@@ -2815,11 +2815,11 @@ RSpec.describe Project, factory_default: :keep do
end end
describe '#remove_import_data' do describe '#remove_import_data' do
let_it_be(:import_data) { ProjectImportData.new(data: { 'test' => 'some data' }) } let(:import_data) { ProjectImportData.new(data: { 'test' => 'some data' }) }
context 'when jira import' do context 'when jira import' do
let_it_be(:project, reload: true) { create(:project, import_type: 'jira', import_data: import_data) } let!(:project) { create(:project, import_type: 'jira', import_data: import_data) }
let_it_be(:jira_import) { create(:jira_import_state, project: project) } let!(:jira_import) { create(:jira_import_state, project: project) }
it 'does remove import data' do it 'does remove import data' do
expect(project.mirror?).to be false expect(project.mirror?).to be false
...@@ -2829,8 +2829,7 @@ RSpec.describe Project, factory_default: :keep do ...@@ -2829,8 +2829,7 @@ RSpec.describe Project, factory_default: :keep do
end end
context 'when neither a mirror nor a jira import' do context 'when neither a mirror nor a jira import' do
let_it_be(:user) { create(:user) } let!(:project) { create(:project, import_type: 'github', import_data: import_data) }
let_it_be(:project) { create(:project, import_type: 'github', import_data: import_data) }
it 'removes import data' do it 'removes import data' do
expect(project.mirror?).to be false expect(project.mirror?).to be false
......
...@@ -8,7 +8,8 @@ RSpec.describe Mutations::Boards::Destroy do ...@@ -8,7 +8,8 @@ RSpec.describe Mutations::Boards::Destroy do
let_it_be(:current_user, reload: true) { create(:user) } let_it_be(:current_user, reload: true) { create(:user) }
let_it_be(:project, reload: true) { create(:project) } let_it_be(:project, reload: true) { create(:project) }
let_it_be(:board) { create(:board, project: project) } let_it_be(:board) { create(:board, project: project) }
let_it_be(:other_board) { create(:board, project: project) } let_it_be(:other_board, refind: true) { create(:board, project: project) }
let(:mutation) do let(:mutation) do
variables = { variables = {
id: GitlabSchema.id_from_object(board).to_s id: GitlabSchema.id_from_object(board).to_s
......
...@@ -10,7 +10,8 @@ RSpec.describe Mutations::Boards::Lists::Destroy do ...@@ -10,7 +10,8 @@ RSpec.describe Mutations::Boards::Lists::Destroy do
it_behaves_like 'board lists destroy request' do it_behaves_like 'board lists destroy request' do
let_it_be(:group, reload: true) { create(:group) } let_it_be(:group, reload: true) { create(:group) }
let_it_be(:board) { create(:board, group: group) } let_it_be(:board) { create(:board, group: group) }
let_it_be(:list) { create(:list, board: board) } let_it_be(:list, refind: true) { create(:list, board: board) }
let(:variables) do let(:variables) do
{ {
list_id: GitlabSchema.id_from_object(list).to_s list_id: GitlabSchema.id_from_object(list).to_s
......
...@@ -1335,6 +1335,7 @@ RSpec.describe API::Projects do ...@@ -1335,6 +1335,7 @@ RSpec.describe API::Projects do
describe 'GET /users/:user_id/starred_projects/' do describe 'GET /users/:user_id/starred_projects/' do
before do before do
user3.update!(starred_projects: [project, project2, project3]) user3.update!(starred_projects: [project, project2, project3])
user3.reload
end end
it 'returns error when user not found' do it 'returns error when user not found' do
......
...@@ -5,7 +5,7 @@ require 'spec_helper' ...@@ -5,7 +5,7 @@ require 'spec_helper'
RSpec.describe Ci::CreateDownstreamPipelineService, '#execute' do RSpec.describe Ci::CreateDownstreamPipelineService, '#execute' do
let_it_be(:user) { create(:user) } let_it_be(:user) { create(:user) }
let(:upstream_project) { create(:project, :repository) } let(:upstream_project) { create(:project, :repository) }
let_it_be(:downstream_project) { create(:project, :repository) } let_it_be(:downstream_project, refind: true) { create(:project, :repository) }
let!(:upstream_pipeline) do let!(:upstream_pipeline) do
create(:ci_pipeline, :running, project: upstream_project) create(:ci_pipeline, :running, project: upstream_project)
......
...@@ -161,6 +161,7 @@ RSpec.describe Deployments::UpdateEnvironmentService do ...@@ -161,6 +161,7 @@ RSpec.describe Deployments::UpdateEnvironmentService do
context 'when deployment was created by an external CD system' do context 'when deployment was created by an external CD system' do
before do before do
deployment.update_column(:deployable_id, nil) deployment.update_column(:deployable_id, nil)
deployment.reload
end end
it 'guesses the deployment tier' do it 'guesses the deployment tier' do
......
...@@ -7,7 +7,7 @@ RSpec.describe Projects::Prometheus::Alerts::NotifyService do ...@@ -7,7 +7,7 @@ RSpec.describe Projects::Prometheus::Alerts::NotifyService do
using RSpec::Parameterized::TableSyntax using RSpec::Parameterized::TableSyntax
let_it_be_with_reload(:project) { create(:project) } let_it_be_with_reload(:project) { create(:project) }
let_it_be_with_reload(:setting) do let_it_be_with_refind(:setting) do
create(:project_incident_management_setting, project: project, send_email: true, create_issue: true) create(:project_incident_management_setting, project: project, send_email: true, create_issue: true)
end end
......
...@@ -41,15 +41,15 @@ RSpec.describe WebHooks::DestroyService do ...@@ -41,15 +41,15 @@ RSpec.describe WebHooks::DestroyService do
end end
context 'with system hook' do context 'with system hook' do
let_it_be(:hook) { create(:system_hook, url: "http://example.com") } let!(:hook) { create(:system_hook, url: "http://example.com") }
let_it_be(:log) { create_list(:web_hook_log, 3, web_hook: hook) } let!(:log) { create_list(:web_hook_log, 3, web_hook: hook) }
it_behaves_like 'batched destroys' it_behaves_like 'batched destroys'
end end
context 'with project hook' do context 'with project hook' do
let_it_be(:hook) { create(:project_hook) } let!(:hook) { create(:project_hook) }
let_it_be(:log) { create_list(:web_hook_log, 3, web_hook: hook) } let!(:log) { create_list(:web_hook_log, 3, web_hook: hook) }
it_behaves_like 'batched destroys' it_behaves_like 'batched destroys'
end end
......
...@@ -5,7 +5,7 @@ require 'spec_helper' ...@@ -5,7 +5,7 @@ require 'spec_helper'
RSpec.describe ContainerExpirationPolicies::CleanupContainerRepositoryWorker do RSpec.describe ContainerExpirationPolicies::CleanupContainerRepositoryWorker do
using RSpec::Parameterized::TableSyntax using RSpec::Parameterized::TableSyntax
let_it_be(:repository, reload: true) { create(:container_repository, :cleanup_scheduled) } let_it_be(:repository, refind: true) { create(:container_repository, :cleanup_scheduled) }
let_it_be(:project) { repository.project } let_it_be(:project) { repository.project }
let_it_be(:policy) { project.container_expiration_policy } let_it_be(:policy) { project.container_expiration_policy }
let_it_be(:other_repository) { create(:container_repository) } let_it_be(:other_repository) { create(:container_repository) }
......
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