debian-mirror-gitlab/spec/requests/api/graphql/group/merge_requests_spec.rb
2023-03-05 14:24:40 +05:30

143 lines
4.3 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
# Based on ee/spec/requests/api/epics_spec.rb
# Should follow closely in order to ensure all situations are covered
RSpec.describe 'Query.group.mergeRequests', feature_category: :code_review do
include GraphqlHelpers
let_it_be(:group) { create(:group) }
let_it_be(:sub_group) { create(:group, parent: group) }
let_it_be(:project_a) { create(:project, :repository, group: group) }
let_it_be(:project_b) { create(:project, :repository, group: group) }
let_it_be(:project_c) { create(:project, :repository, group: sub_group) }
let_it_be(:project_x) { create(:project, :repository) }
let_it_be(:user) { create(:user, developer_projects: [project_x]) }
let_it_be(:archived_project) { create(:project, :archived, :repository, group: group) }
let_it_be(:archived_mr) { create(:merge_request, source_project: archived_project) }
let_it_be(:mr_attrs) do
{ target_branch: 'master' }
end
let_it_be(:mr_traits) do
[:unique_branches, :unique_author]
end
let_it_be(:mrs_a, reload: true) { create_list(:merge_request, 2, *mr_traits, **mr_attrs, source_project: project_a) }
let_it_be(:mrs_b, reload: true) { create_list(:merge_request, 2, *mr_traits, **mr_attrs, source_project: project_b) }
let_it_be(:mrs_c, reload: true) { create_list(:merge_request, 2, *mr_traits, **mr_attrs, source_project: project_c) }
let_it_be(:other_mr) { create(:merge_request, source_project: project_x) }
let(:mrs_data) { graphql_data_at(:group, :merge_requests, :nodes) }
before do
group.add_developer(user)
end
def expected_mrs(mrs)
mrs.map { |mr| a_graphql_entity_for(mr) }
end
describe 'not passing any arguments' do
let(:query) do
<<~GQL
query($path: ID!) {
group(fullPath: $path) {
mergeRequests { nodes { id } }
}
}
GQL
end
it 'can find all merge requests in the group, excluding sub-groups' do
post_graphql(query, current_user: user, variables: { path: group.full_path })
expect(mrs_data).to match_array(expected_mrs(mrs_a + mrs_b))
end
end
describe 'restricting by author' do
let(:query) do
<<~GQL
query($path: ID!, $user: String) {
group(fullPath: $path) {
mergeRequests(authorUsername: $user) { nodes { id author { username } } }
}
}
GQL
end
let(:author) { mrs_b.first.author }
it 'can find all merge requests with user as author' do
post_graphql(query, current_user: user, variables: { user: author.username, path: group.full_path })
expect(mrs_data).to match_array(expected_mrs([mrs_b.first]))
end
end
describe 'restricting by assignee' do
let(:query) do
<<~GQL
query($path: ID!, $user: String) {
group(fullPath: $path) {
mergeRequests(assigneeUsername: $user) { nodes { id } }
}
}
GQL
end
let_it_be(:assignee) { create(:user) }
before_all do
mrs_b.second.assignees << assignee
mrs_a.first.assignees << assignee
end
it 'can find all merge requests assigned to user' do
post_graphql(query, current_user: user, variables: { user: assignee.username, path: group.full_path })
expect(mrs_data).to match_array(expected_mrs([mrs_a.first, mrs_b.second]))
end
end
describe 'passing include_subgroups: true' do
let(:query) do
<<~GQL
query($path: ID!) {
group(fullPath: $path) {
mergeRequests(includeSubgroups: true) { nodes { id } }
}
}
GQL
end
it 'can find all merge requests in the group, including sub-groups' do
post_graphql(query, current_user: user, variables: { path: group.full_path })
expect(mrs_data).to match_array(expected_mrs(mrs_a + mrs_b + mrs_c))
end
end
describe 'passing include_archived: true' do
let(:query) do
<<~GQL
query($path: ID!) {
group(fullPath: $path) {
mergeRequests(includeArchived: true) { nodes { id } }
}
}
GQL
end
it 'can find all merge requests in the group, including from archived projects' do
post_graphql(query, current_user: user, variables: { path: group.full_path })
expect(mrs_data).to match_array(expected_mrs(mrs_a + mrs_b + [archived_mr]))
end
end
end