2015-04-26 12:48:37 +05:30
|
|
|
class Spinach::Features::ProjectForkedMergeRequests < Spinach::FeatureSteps
|
2014-09-02 18:07:02 +05:30
|
|
|
include SharedAuthentication
|
|
|
|
include SharedProject
|
|
|
|
include SharedNote
|
|
|
|
include SharedPaths
|
|
|
|
include Select2Helper
|
|
|
|
|
|
|
|
step 'I am a member of project "Shop"' do
|
|
|
|
@project = Project.find_by(name: "Shop")
|
|
|
|
@project ||= create(:project, name: "Shop")
|
|
|
|
@project.team << [@user, :reporter]
|
|
|
|
end
|
|
|
|
|
|
|
|
step 'I have a project forked off of "Shop" called "Forked Shop"' do
|
|
|
|
@forked_project = Projects::ForkService.new(@project, @user).execute
|
|
|
|
end
|
|
|
|
|
|
|
|
step 'I click link "New Merge Request"' do
|
|
|
|
click_link "New Merge Request"
|
|
|
|
end
|
|
|
|
|
|
|
|
step 'I should see merge request "Merge Request On Forked Project"' do
|
2015-09-11 14:41:01 +05:30
|
|
|
expect(@project.merge_requests.size).to be >= 1
|
2014-09-02 18:07:02 +05:30
|
|
|
@merge_request = @project.merge_requests.last
|
2015-09-11 14:41:01 +05:30
|
|
|
expect(current_path).to eq namespace_project_merge_request_path(@project.namespace, @project, @merge_request)
|
|
|
|
expect(@merge_request.title).to eq "Merge Request On Forked Project"
|
|
|
|
expect(@merge_request.source_project).to eq @forked_project
|
|
|
|
expect(@merge_request.source_branch).to eq "fix"
|
|
|
|
expect(@merge_request.target_branch).to eq "master"
|
|
|
|
expect(page).to have_content @forked_project.path_with_namespace
|
|
|
|
expect(page).to have_content @project.path_with_namespace
|
|
|
|
expect(page).to have_content @merge_request.source_branch
|
|
|
|
expect(page).to have_content @merge_request.target_branch
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
step 'I fill out a "Merge Request On Forked Project" merge request' do
|
2016-09-13 17:45:13 +05:30
|
|
|
expect(page).to have_content('Source branch')
|
|
|
|
expect(page).to have_content('Target branch')
|
|
|
|
|
2016-06-02 11:05:42 +05:30
|
|
|
first('.js-source-project').click
|
|
|
|
first('.dropdown-source-project a', text: @forked_project.path_with_namespace)
|
|
|
|
|
|
|
|
first('.js-target-project').click
|
|
|
|
first('.dropdown-target-project a', text: @project.path_with_namespace)
|
|
|
|
|
|
|
|
first('.js-source-branch').click
|
|
|
|
first('.dropdown-source-branch .dropdown-content a', text: 'fix').click
|
2014-09-02 18:07:02 +05:30
|
|
|
|
2015-12-23 02:04:40 +05:30
|
|
|
click_button "Compare branches and continue"
|
|
|
|
|
|
|
|
expect(page).to have_css("h3.page-title", text: "New Merge Request")
|
2014-09-02 18:07:02 +05:30
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
page.within 'form#new_merge_request' do
|
|
|
|
fill_in "merge_request_title", with: "Merge Request On Forked Project"
|
|
|
|
end
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
step 'I submit the merge request' do
|
2015-12-23 02:04:40 +05:30
|
|
|
click_button "Submit merge request"
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
step 'I follow the target commit link' do
|
|
|
|
commit = @project.repository.commit
|
|
|
|
click_link commit.short_id(8)
|
|
|
|
end
|
|
|
|
|
|
|
|
step 'I should see the commit under the forked from project' do
|
|
|
|
commit = @project.repository.commit
|
2015-09-11 14:41:01 +05:30
|
|
|
expect(page).to have_content(commit.message)
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
step 'I click "Create Merge Request on fork" link' do
|
|
|
|
click_link "Create Merge Request on fork"
|
|
|
|
end
|
|
|
|
|
|
|
|
step 'I see prefilled new Merge Request page for the forked project' do
|
2015-09-11 14:41:01 +05:30
|
|
|
expect(current_path).to eq new_namespace_project_merge_request_path(@forked_project.namespace, @forked_project)
|
|
|
|
expect(find("#merge_request_source_project_id").value).to eq @forked_project.id.to_s
|
|
|
|
expect(find("#merge_request_target_project_id").value).to eq @project.id.to_s
|
|
|
|
expect(find("#merge_request_source_branch").value).to have_content "new_design"
|
|
|
|
expect(find("#merge_request_target_branch").value).to have_content "master"
|
|
|
|
expect(find("#merge_request_title").value).to eq "New Design"
|
2015-04-26 12:48:37 +05:30
|
|
|
verify_commit_link(".mr_target_commit", @project)
|
|
|
|
verify_commit_link(".mr_source_commit", @forked_project)
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
step 'I update the merge request title' do
|
|
|
|
fill_in "merge_request_title", with: "An Edited Forked Merge Request"
|
|
|
|
end
|
|
|
|
|
|
|
|
step 'I save the merge request' do
|
|
|
|
click_button "Save changes"
|
|
|
|
end
|
|
|
|
|
|
|
|
step 'I should see the edited merge request' do
|
2015-09-11 14:41:01 +05:30
|
|
|
expect(page).to have_content "An Edited Forked Merge Request"
|
|
|
|
expect(@project.merge_requests.size).to be >= 1
|
2014-09-02 18:07:02 +05:30
|
|
|
@merge_request = @project.merge_requests.last
|
2015-09-11 14:41:01 +05:30
|
|
|
expect(current_path).to eq namespace_project_merge_request_path(@project.namespace, @project, @merge_request)
|
|
|
|
expect(@merge_request.source_project).to eq @forked_project
|
|
|
|
expect(@merge_request.source_branch).to eq "fix"
|
|
|
|
expect(@merge_request.target_branch).to eq "master"
|
|
|
|
expect(page).to have_content @forked_project.path_with_namespace
|
|
|
|
expect(page).to have_content @project.path_with_namespace
|
|
|
|
expect(page).to have_content @merge_request.source_branch
|
|
|
|
expect(page).to have_content @merge_request.target_branch
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
step 'I should see last push widget' do
|
2015-09-11 14:41:01 +05:30
|
|
|
expect(page).to have_content "You pushed to new_design"
|
|
|
|
expect(page).to have_link "Create Merge Request"
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
step 'I click link edit "Merge Request On Forked Project"' do
|
|
|
|
find("#edit_merge_request").click
|
|
|
|
end
|
|
|
|
|
|
|
|
step 'I see the edit page prefilled for "Merge Request On Forked Project"' do
|
2015-09-11 14:41:01 +05:30
|
|
|
expect(current_path).to eq edit_namespace_project_merge_request_path(@project.namespace, @project, @merge_request)
|
2016-06-02 11:05:42 +05:30
|
|
|
expect(page).to have_content "Edit merge request #{@merge_request.to_reference}"
|
2015-09-11 14:41:01 +05:30
|
|
|
expect(find("#merge_request_title").value).to eq "Merge Request On Forked Project"
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
step 'I fill out an invalid "Merge Request On Forked Project" merge request' do
|
2016-06-02 11:05:42 +05:30
|
|
|
expect(find_by_id("merge_request_source_project_id", visible: false).value).to eq @forked_project.id.to_s
|
|
|
|
expect(find_by_id("merge_request_target_project_id", visible: false).value).to eq @project.id.to_s
|
|
|
|
expect(find_by_id("merge_request_source_branch", visible: false).value).to eq nil
|
|
|
|
expect(find_by_id("merge_request_target_branch", visible: false).value).to eq "master"
|
2014-09-02 18:07:02 +05:30
|
|
|
click_button "Compare branches"
|
|
|
|
end
|
|
|
|
|
|
|
|
step 'I should see validation errors' do
|
2015-09-11 14:41:01 +05:30
|
|
|
expect(page).to have_content "You must select source and target branch"
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
step 'the target repository should be the original repository' do
|
2016-06-02 11:05:42 +05:30
|
|
|
expect(find_by_id("merge_request_target_project_id").value).to eq "#{@project.id}"
|
2015-09-11 14:41:01 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
step 'I click "Assign to" dropdown"' do
|
|
|
|
first('.ajax-users-select').click
|
|
|
|
end
|
|
|
|
|
|
|
|
step 'I should see the target project ID in the input selector' do
|
|
|
|
expect(page).to have_selector("input[data-project-id=\"#{@project.id}\"]")
|
|
|
|
end
|
|
|
|
|
|
|
|
step 'I should see the users from the target project ID' do
|
|
|
|
expect(page).to have_selector('.user-result', visible: true, count: 3)
|
|
|
|
users = page.all('.user-name')
|
|
|
|
expect(users[0].text).to eq 'Unassigned'
|
|
|
|
expect(users[1].text).to eq current_user.name
|
|
|
|
expect(users[2].text).to eq @project.users.first.name
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
# Verify a link is generated against the correct project
|
|
|
|
def verify_commit_link(container_div, container_project)
|
|
|
|
# This should force a wait for the javascript to execute
|
2016-08-24 12:49:21 +05:30
|
|
|
expect(find(:div, container_div).find(".commit_short_id")['href']).to have_content "#{container_project.path_with_namespace}/commit"
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
end
|