Commit 833a65e5 authored by Sanad Liaquat's avatar Sanad Liaquat

Merge branch 'replace-e2e-test-by-api-test' into 'master'

Replace an end-to-end test by an API test

See merge request gitlab-org/gitlab!25013
parents b9940c46 01439da3
...@@ -2,35 +2,34 @@ ...@@ -2,35 +2,34 @@
module QA module QA
context 'Plan' do context 'Plan' do
describe 'Close issue' do include Support::Api
describe 'Issue' do
let(:issue) do let(:issue) do
Resource::Issue.fabricate_via_api! Resource::Issue.fabricate_via_api!
end end
let(:issue_id) { issue.api_response[:iid] } let(:issue_id) { issue.api_response[:iid] }
before do let(:api_client) { Runtime::API::Client.new(:gitlab) }
Flow::Login.sign_in
before do
# Initial commit should be pushed because # Initial commit should be pushed because
# the very first commit to the project doesn't close the issue # the very first commit to the project doesn't close the issue
# https://gitlab.com/gitlab-org/gitlab-foss/issues/38965 # https://gitlab.com/gitlab-org/gitlab-foss/issues/38965
push_commit('Initial commit') push_commit('Initial commit')
end end
it 'closes an issue by pushing a commit' do it 'closes via pushing a commit' do
push_commit("Closes ##{issue_id}", false) push_commit("Closes ##{issue_id}", false)
issue.visit! Support::Retrier.retry_until(max_duration: 10, sleep_interval: 1) do
issue_closed?
Page::Project::Issue::Show.perform do |show|
reopen_issue_button_visible = show.wait_until(reload: true) do
show.has_element?(:reopen_issue_button, wait: 1.0)
end
expect(reopen_issue_button_visible).to be_truthy
end end
end end
private
def push_commit(commit_message, new_branch = true) def push_commit(commit_message, new_branch = true)
Resource::Repository::ProjectPush.fabricate! do |push| Resource::Repository::ProjectPush.fabricate! do |push|
push.commit_message = commit_message push.commit_message = commit_message
...@@ -39,6 +38,11 @@ module QA ...@@ -39,6 +38,11 @@ module QA
push.project = issue.project push.project = issue.project
end end
end end
def issue_closed?
response = get Runtime::API::Request.new(api_client, "/projects/#{issue.project.id}/issues/#{issue_id}").url
parse_body(response)[:state] == 'closed'
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