Commit 8735335b authored by Dan Davison's avatar Dan Davison

Merge branch 'ml-update-transient-bug-mwps-test' into 'master'

Refactor and update MWPS e2e test after CR

See merge request gitlab-org/gitlab!59440
parents 1fd3674a 8eb2c4b0
...@@ -3,97 +3,97 @@ ...@@ -3,97 +3,97 @@
module QA module QA
RSpec.describe 'Create', :runner do RSpec.describe 'Create', :runner do
describe 'Merge requests' do describe 'Merge requests' do
let(:project) do shared_examples 'merge when pipeline succeeds' do |repeat: 1|
Resource::Project.fabricate_via_api! do |project| let(:project) do
project.name = 'merge-when-pipeline-succeeds' Resource::Project.fabricate_via_api! do |project|
project.initialize_with_readme = true project.name = 'merge-when-pipeline-succeeds'
end project.initialize_with_readme = true
end end
let!(:runner) do
Resource::Runner.fabricate! do |runner|
runner.project = project
runner.name = "runner-for-#{project.name}"
runner.tags = ["runner-for-#{project.name}"]
end end
end
before do let!(:runner) do
Resource::Repository::Commit.fabricate_via_api! do |commit| Resource::Runner.fabricate! do |runner|
commit.project = project runner.project = project
commit.commit_message = 'Add .gitlab-ci.yml' runner.name = "runner-for-#{project.name}"
commit.add_files( runner.tags = ["runner-for-#{project.name}"]
[ end
{
file_path: '.gitlab-ci.yml',
content: <<~EOF
test:
tags: ["runner-for-#{project.name}"]
script: sleep 10
only:
- merge_requests
EOF
}
]
)
end end
Flow::Login.sign_in before do
end Resource::Repository::Commit.fabricate_via_api! do |commit|
commit.project = project
after do commit.commit_message = 'Add .gitlab-ci.yml'
runner&.remove_via_api! commit.add_files(
project&.remove_via_api! [
end {
file_path: '.gitlab-ci.yml',
content: <<~EOF
test:
tags: ["runner-for-#{project.name}"]
script: sleep 10
only:
- merge_requests
EOF
}
]
)
end
it 'merges when pipeline succeeds', testcase: 'https://gitlab.com/gitlab-org/quality/testcases/-/issues/1684' do Flow::Login.sign_in
verify_merge_when_pipeline_succeeds end
end
it 'reliably merges when pipeline succeeds', :transient, testcase: 'https://gitlab.com/gitlab-org/quality/testcases/-/issues/1684' do after do
verify_merge_when_pipeline_succeeds(repeat: Runtime::Env.transient_trials) do |i| runner&.remove_via_api!
QA::Runtime::Logger.info("Transient bug test - Trial #{i}") project&.remove_via_api!
end end
end
def verify_merge_when_pipeline_succeeds(repeat: 1) it 'merges after pipeline succeeds' do
repeat.times do |i| repeat.times do |i|
yield i if block_given? QA::Runtime::Logger.info("Transient bug test - Trial #{i}") if repeat > 1
branch_name = "merge-request-test-#{SecureRandom.hex(8)}" branch_name = "mr-test-#{SecureRandom.hex(6)}-#{i}"
# Create a branch that will be merged into the default branch # Create a branch that will be merged into the default branch
Resource::Repository::ProjectPush.fabricate! do |project_push| Resource::Repository::ProjectPush.fabricate! do |project_push|
project_push.project = project project_push.project = project
project_push.new_branch = true project_push.new_branch = true
project_push.branch_name = branch_name project_push.branch_name = branch_name
project_push.file_name = "file-#{SecureRandom.hex(8)}.txt" project_push.file_name = "#{branch_name}.txt"
end end
# Create a merge request to merge the branch we just created # Create a merge request to merge the branch we just created
merge_request = Resource::MergeRequest.fabricate_via_api! do |merge_request| merge_request = Resource::MergeRequest.fabricate_via_api! do |merge_request|
merge_request.project = project merge_request.project = project
merge_request.source_branch = branch_name merge_request.source_branch = branch_name
merge_request.no_preparation = true merge_request.no_preparation = true
end end
merge_request.visit! merge_request.visit!
Page::MergeRequest::Show.perform do |mr| Page::MergeRequest::Show.perform do |mr|
mr.merge_when_pipeline_succeeds! mr.merge_when_pipeline_succeeds!
Support::Waiter.wait_until(sleep_interval: 5) do Support::Waiter.wait_until(sleep_interval: 5) do
merge_request = merge_request.reload! merge_request = merge_request.reload!
merge_request.state == 'merged' merge_request.state == 'merged'
end end
aggregate_failures do aggregate_failures do
expect(merge_request.merge_when_pipeline_succeeds).to be_truthy expect(merge_request.merge_when_pipeline_succeeds).to be_truthy
expect(mr.merged?).to be_truthy, "Expected content 'The changes were merged' but it did not appear." expect(mr.merged?).to be_truthy, "Expected content 'The changes were merged' but it did not appear."
end
end end
end end
end end
end end
context 'when merging once', testcase: 'https://gitlab.com/gitlab-org/quality/testcases/-/issues/1684' do
it_behaves_like 'merge when pipeline succeeds'
end
context 'when merging several times', :transient, testcase: 'https://gitlab.com/gitlab-org/quality/testcases/-/issues/1684' do
it_behaves_like 'merge when pipeline succeeds', repeat: Runtime::Env.transient_trials
end
end end
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