Commit c27b91da authored by Adam Hegyi's avatar Adam Hegyi

Merge branch '341783-tidy-specs-for-cross-modification' into 'master'

Refactor specs prevent_cross_database_modification_spec

See merge request gitlab-org/gitlab!73451
parents 71488731 3b382796
...@@ -6,7 +6,7 @@ RSpec.describe 'Database::PreventCrossDatabaseModification' do ...@@ -6,7 +6,7 @@ RSpec.describe 'Database::PreventCrossDatabaseModification' do
let_it_be(:pipeline, refind: true) { create(:ci_pipeline) } let_it_be(:pipeline, refind: true) { create(:ci_pipeline) }
let_it_be(:project, refind: true) { create(:project) } let_it_be(:project, refind: true) { create(:project) }
shared_examples 'succeessful examples' do shared_examples 'successful examples' do
context 'outside transaction' do context 'outside transaction' do
it { expect { run_queries }.not_to raise_error } it { expect { run_queries }.not_to raise_error }
end end
...@@ -36,7 +36,7 @@ RSpec.describe 'Database::PreventCrossDatabaseModification' do ...@@ -36,7 +36,7 @@ RSpec.describe 'Database::PreventCrossDatabaseModification' do
project.reload project.reload
end end
include_examples 'succeessful examples' include_examples 'successful examples'
end end
context 'when only CI data is modified' do context 'when only CI data is modified' do
...@@ -45,7 +45,7 @@ RSpec.describe 'Database::PreventCrossDatabaseModification' do ...@@ -45,7 +45,7 @@ RSpec.describe 'Database::PreventCrossDatabaseModification' do
project.reload project.reload
end end
include_examples 'succeessful examples' include_examples 'successful examples'
end end
context 'when other data is modified' do context 'when other data is modified' do
...@@ -54,38 +54,42 @@ RSpec.describe 'Database::PreventCrossDatabaseModification' do ...@@ -54,38 +54,42 @@ RSpec.describe 'Database::PreventCrossDatabaseModification' do
project.touch project.touch
end end
include_examples 'succeessful examples' include_examples 'successful examples'
end end
describe 'with_cross_database_modification_prevented block' do context 'when both CI and other data is modified' do
it 'raises error when CI and other data is modified' do def run_queries
expect do project.touch
with_cross_database_modification_prevented do pipeline.touch
Project.transaction do
project.touch
pipeline.touch
end
end
end.to raise_error /Cross-database data modification/
end end
it 'raises an error when an undefined gitlab_schema table is modified with another table' do context 'outside transaction' do
expect do it { expect { run_queries }.not_to raise_error }
with_cross_database_modification_prevented do end
Project.transaction do
context 'when data modification happens in a transaction' do
it 'raises error' do
Project.transaction do
expect { run_queries }.to raise_error /Cross-database data modification/
end
end
context 'when data modification happens in nested transactions' do
it 'raises error' do
Project.transaction(requires_new: true) do
project.touch project.touch
project.connection.execute('UPDATE foo_bars_undefined_table SET a=1 WHERE id = -1') Project.transaction(requires_new: true) do
expect { pipeline.touch }.to raise_error /Cross-database data modification/
end
end end
end end
end.to raise_error /Cross-database data modification.*The gitlab_schema was undefined/ end
end end
end
context 'when running tests with prevent_cross_database_modification', :prevent_cross_database_modification do context 'when executing a SELECT FOR UPDATE query' do
context 'when both CI and other data is modified' do
def run_queries def run_queries
project.touch project.touch
pipeline.touch pipeline.lock!
end end
context 'outside transaction' do context 'outside transaction' do
...@@ -99,41 +103,11 @@ RSpec.describe 'Database::PreventCrossDatabaseModification' do ...@@ -99,41 +103,11 @@ RSpec.describe 'Database::PreventCrossDatabaseModification' do
end end
end end
context 'when data modification happens in nested transactions' do context 'when the modification is inside a factory save! call' do
it 'raises error' do let(:runner) { create(:ci_runner, :project, projects: [build(:project)]) }
Project.transaction(requires_new: true) do
project.touch
Project.transaction(requires_new: true) do
expect { pipeline.touch }.to raise_error /Cross-database data modification/
end
end
end
end
end
context 'when executing a SELECT FOR UPDATE query' do it 'does not raise an error' do
def run_queries runner
project.touch
pipeline.lock!
end
context 'outside transaction' do
it { expect { run_queries }.not_to raise_error }
end
context 'when data modification happens in a transaction' do
it 'raises error' do
Project.transaction do
expect { run_queries }.to raise_error /Cross-database data modification/
end
end
context 'when the modification is inside a factory save! call' do
let(:runner) { create(:ci_runner, :project, projects: [build(:project)]) }
it 'does not raise an error' do
runner
end
end end
end end
end end
...@@ -145,7 +119,7 @@ RSpec.describe 'Database::PreventCrossDatabaseModification' do ...@@ -145,7 +119,7 @@ RSpec.describe 'Database::PreventCrossDatabaseModification' do
project.save! project.save!
end end
include_examples 'succeessful examples' include_examples 'successful examples'
end end
describe '#allow_cross_database_modification_within_transaction' do describe '#allow_cross_database_modification_within_transaction' do
...@@ -171,4 +145,15 @@ RSpec.describe 'Database::PreventCrossDatabaseModification' do ...@@ -171,4 +145,15 @@ RSpec.describe 'Database::PreventCrossDatabaseModification' do
end end
end end
end end
context 'when some table with a defined schema and another table with undefined gitlab_schema is modified' do
it 'raises an error including including message about undefined schema' do
expect do
Project.transaction do
project.touch
project.connection.execute('UPDATE foo_bars_undefined_table SET a=1 WHERE id = -1')
end
end.to raise_error /Cross-database data modification.*The gitlab_schema was undefined/
end
end
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