diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2021-03-23 06:09:04 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2021-03-23 06:09:04 +0300 |
commit | 4f31109a95c149fc92ec1899fb18110160e02789 (patch) | |
tree | ea0aae5e1392159ae942e5171381b29f157ad0e2 /spec/requests/api | |
parent | 5df6990daccf98d24f3ac45865d0386c3a4c3eb5 (diff) |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/requests/api')
-rw-r--r-- | spec/requests/api/graphql/custom_emoji_query_spec.rb | 10 | ||||
-rw-r--r-- | spec/requests/api/graphql/group/timelogs_spec.rb | 122 | ||||
-rw-r--r-- | spec/requests/api/graphql/group_query_spec.rb | 10 |
3 files changed, 140 insertions, 2 deletions
diff --git a/spec/requests/api/graphql/custom_emoji_query_spec.rb b/spec/requests/api/graphql/custom_emoji_query_spec.rb index d5a423d0eba..874357d9eef 100644 --- a/spec/requests/api/graphql/custom_emoji_query_spec.rb +++ b/spec/requests/api/graphql/custom_emoji_query_spec.rb @@ -16,7 +16,15 @@ RSpec.describe 'getting custom emoji within namespace' do describe "Query CustomEmoji on Group" do def custom_emoji_query(group) - graphql_query_for('group', 'fullPath' => group.full_path) + fields = all_graphql_fields_for('Group') + # TODO: Set required timelogs args elsewhere https://gitlab.com/gitlab-org/gitlab/-/issues/325499 + fields.selection['timelogs(startDate: "2021-03-01" endDate: "2021-03-30")'] = fields.selection.delete('timelogs') + + graphql_query_for( + 'group', + { fullPath: group.full_path }, + fields + ) end it 'returns emojis when authorised' do diff --git a/spec/requests/api/graphql/group/timelogs_spec.rb b/spec/requests/api/graphql/group/timelogs_spec.rb new file mode 100644 index 00000000000..ca015a82148 --- /dev/null +++ b/spec/requests/api/graphql/group/timelogs_spec.rb @@ -0,0 +1,122 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe 'Timelogs through GroupQuery' do + include GraphqlHelpers + + describe 'Get list of timelogs from a group issues' do + let_it_be(:user) { create(:user) } + let_it_be(:group) { create(:group) } + let_it_be(:project) { create(:project, :public, group: group) } + let_it_be(:milestone) { create(:milestone, group: group) } + let_it_be(:issue) { create(:issue, project: project, milestone: milestone) } + let_it_be(:timelog1) { create(:timelog, issue: issue, user: user, spent_at: '2019-08-13 14:00:00') } + let_it_be(:timelog2) { create(:timelog, issue: issue, user: user, spent_at: '2019-08-10 08:00:00') } + let_it_be(:params) { { startTime: '2019-08-10 12:00:00', endTime: '2019-08-21 12:00:00' } } + let(:timelogs_data) { graphql_data['group']['timelogs']['nodes'] } + + before do + group.add_developer(user) + end + + context 'when the request is correct' do + before do + post_graphql(query, current_user: user) + end + + it_behaves_like 'a working graphql query' + + it 'returns timelogs successfully' do + expect(response).to have_gitlab_http_status(:ok) + expect(graphql_errors).to be_nil + expect(timelog_array.size).to eq 1 + end + + it 'contains correct data', :aggregate_failures do + username = timelog_array.map {|data| data['user']['username'] } + spent_at = timelog_array.map { |data| data['spentAt'].to_time } + time_spent = timelog_array.map { |data| data['timeSpent'] } + issue_title = timelog_array.map {|data| data['issue']['title'] } + milestone_title = timelog_array.map {|data| data['issue']['milestone']['title'] } + + expect(username).to eq([user.username]) + expect(spent_at.first).to be_like_time(timelog1.spent_at) + expect(time_spent).to eq([timelog1.time_spent]) + expect(issue_title).to eq([issue.title]) + expect(milestone_title).to eq([milestone.title]) + end + + context 'when arguments with no time are present' do + let!(:timelog3) { create(:timelog, issue: issue, user: user, spent_at: '2019-08-10 15:00:00') } + let!(:timelog4) { create(:timelog, issue: issue, user: user, spent_at: '2019-08-21 15:00:00') } + let(:params) { { startDate: '2019-08-10', endDate: '2019-08-21' }} + + it 'sets times as start of day and end of day' do + expect(response).to have_gitlab_http_status(:ok) + expect(timelog_array.size).to eq 2 + end + end + end + + context 'when requests has errors' do + context 'when there are no timelogs present' do + before do + Timelog.delete_all + end + + it 'returns empty result' do + post_graphql(query, current_user: user) + + expect(response).to have_gitlab_http_status(:success) + expect(graphql_errors).to be_nil + expect(timelogs_data).to be_empty + end + end + + context 'when user has no permission to read group timelogs' do + it 'returns empty result' do + guest = create(:user) + group.add_guest(guest) + post_graphql(query, current_user: guest) + + expect(response).to have_gitlab_http_status(:success) + expect(graphql_errors).to be_nil + expect(timelogs_data).to be_empty + end + end + end + end + + def timelog_array(extract_attribute = nil) + timelogs_data.map do |item| + extract_attribute ? item[extract_attribute] : item + end + end + + def query(timelog_params = params) + timelog_nodes = <<~NODE + nodes { + spentAt + timeSpent + user { + username + } + issue { + title + milestone { + title + } + } + } + NODE + + graphql_query_for("group", { "fullPath" => group.full_path }, + [query_graphql_field( + "timelogs", + timelog_params, + timelog_nodes + )] + ) + end +end diff --git a/spec/requests/api/graphql/group_query_spec.rb b/spec/requests/api/graphql/group_query_spec.rb index 391bae4cfcf..8e4f808f794 100644 --- a/spec/requests/api/graphql/group_query_spec.rb +++ b/spec/requests/api/graphql/group_query_spec.rb @@ -17,7 +17,15 @@ RSpec.describe 'getting group information' do # similar to the API "GET /groups/:id" describe "Query group(fullPath)" do def group_query(group) - graphql_query_for('group', 'fullPath' => group.full_path) + fields = all_graphql_fields_for('Group') + # TODO: Set required timelogs args elsewhere https://gitlab.com/gitlab-org/gitlab/-/issues/325499 + fields.selection['timelogs(startDate: "2021-03-01" endDate: "2021-03-30")'] = fields.selection.delete('timelogs') + + graphql_query_for( + 'group', + { fullPath: group.full_path }, + fields + ) end it_behaves_like 'a working graphql query' do |