Commit 88856729 authored by Lee Tickett's avatar Lee Tickett Committed by Michael Kozono

Move graphql timelogs to ce

parent 761a8b63
...@@ -1663,6 +1663,7 @@ Gitlab/NamespacedClass: ...@@ -1663,6 +1663,7 @@ Gitlab/NamespacedClass:
- 'app/policies/service_policy.rb' - 'app/policies/service_policy.rb'
- 'app/policies/suggestion_policy.rb' - 'app/policies/suggestion_policy.rb'
- 'app/policies/timebox_policy.rb' - 'app/policies/timebox_policy.rb'
- 'app/policies/timelog_policy.rb'
- 'app/policies/todo_policy.rb' - 'app/policies/todo_policy.rb'
- 'app/policies/user_policy.rb' - 'app/policies/user_policy.rb'
- 'app/policies/wiki_page_policy.rb' - 'app/policies/wiki_page_policy.rb'
...@@ -2265,7 +2266,6 @@ Gitlab/NamespacedClass: ...@@ -2265,7 +2266,6 @@ Gitlab/NamespacedClass:
- 'ee/app/policies/iteration_policy.rb' - 'ee/app/policies/iteration_policy.rb'
- 'ee/app/policies/push_rule_policy.rb' - 'ee/app/policies/push_rule_policy.rb'
- 'ee/app/policies/saml_provider_policy.rb' - 'ee/app/policies/saml_provider_policy.rb'
- 'ee/app/policies/timelog_policy.rb'
- 'ee/app/policies/vulnerability_policy.rb' - 'ee/app/policies/vulnerability_policy.rb'
- 'ee/app/presenters/approval_rule_presenter.rb' - 'ee/app/presenters/approval_rule_presenter.rb'
- 'ee/app/presenters/audit_event_presenter.rb' - 'ee/app/presenters/audit_event_presenter.rb'
......
...@@ -45,7 +45,6 @@ module Resolvers ...@@ -45,7 +45,6 @@ module Resolvers
end end
def timelogs_available_for_user? def timelogs_available_for_user?
group&.feature_available?(:group_timelogs) &&
group&.user_can_access_group_timelogs?(context[:current_user]) group&.user_can_access_group_timelogs?(context[:current_user])
end end
......
...@@ -114,6 +114,12 @@ module Types ...@@ -114,6 +114,12 @@ module Types
description: 'Labels available on this group.', description: 'Labels available on this group.',
resolver: Resolvers::GroupLabelsResolver resolver: Resolvers::GroupLabelsResolver
field :timelogs, ::Types::TimelogType.connection_type, null: false,
description: 'Time logged on issues in the group and its subgroups.',
extras: [:lookahead],
complexity: 5,
resolver: ::Resolvers::TimelogResolver
def avatar_url def avatar_url
object.avatar_url(only_path: false) object.avatar_url(only_path: false)
end end
......
...@@ -8,8 +8,6 @@ module HasTimelogsReport ...@@ -8,8 +8,6 @@ module HasTimelogsReport
end end
def user_can_access_group_timelogs?(current_user) def user_can_access_group_timelogs?(current_user)
return unless feature_available?(:group_timelogs)
Ability.allowed?(current_user, :read_group_timelogs, self) Ability.allowed?(current_user, :read_group_timelogs, self)
end end
......
...@@ -16,6 +16,7 @@ class Group < Namespace ...@@ -16,6 +16,7 @@ class Group < Namespace
include Gitlab::Utils::StrongMemoize include Gitlab::Utils::StrongMemoize
include GroupAPICompatibility include GroupAPICompatibility
include EachBatch include EachBatch
include HasTimelogsReport
ACCESS_REQUEST_APPROVERS_TO_BE_NOTIFIED_LIMIT = 10 ACCESS_REQUEST_APPROVERS_TO_BE_NOTIFIED_LIMIT = 10
......
...@@ -130,6 +130,7 @@ class GroupPolicy < BasePolicy ...@@ -130,6 +130,7 @@ class GroupPolicy < BasePolicy
enable :read_prometheus enable :read_prometheus
enable :read_package enable :read_package
enable :read_package_settings enable :read_package_settings
enable :read_group_timelogs
end end
rule { maintainer }.policy do rule { maintainer }.policy do
......
...@@ -259,6 +259,7 @@ class ProjectPolicy < BasePolicy ...@@ -259,6 +259,7 @@ class ProjectPolicy < BasePolicy
enable :read_confidential_issues enable :read_confidential_issues
enable :read_package enable :read_package
enable :read_product_analytics enable :read_product_analytics
enable :read_group_timelogs
end end
# We define `:public_user_access` separately because there are cases in gitlab-ee # We define `:public_user_access` separately because there are cases in gitlab-ee
......
---
title: Move graphql timelogs to CE
merge_request: 56633
author: Lee Tickett @leetickett
type: fixed
...@@ -3064,7 +3064,6 @@ Autogenerated return type of GitlabSubscriptionActivate. ...@@ -3064,7 +3064,6 @@ Autogenerated return type of GitlabSubscriptionActivate.
| `fullName` | [`String!`](#string) | Full name of the namespace. | | `fullName` | [`String!`](#string) | Full name of the namespace. |
| `fullPath` | [`ID!`](#id) | Full path of the namespace. | | `fullPath` | [`ID!`](#id) | Full path of the namespace. |
| `groupMembers` | [`GroupMemberConnection`](#groupmemberconnection) | A membership of a user within this group. | | `groupMembers` | [`GroupMemberConnection`](#groupmemberconnection) | A membership of a user within this group. |
| `groupTimelogsEnabled` | [`Boolean`](#boolean) | Indicates if Group timelogs are enabled for namespace |
| `id` | [`ID!`](#id) | ID of the namespace. | | `id` | [`ID!`](#id) | ID of the namespace. |
| `isTemporaryStorageIncreaseEnabled` | [`Boolean!`](#boolean) | Status of the temporary storage increase. | | `isTemporaryStorageIncreaseEnabled` | [`Boolean!`](#boolean) | Status of the temporary storage increase. |
| `issues` | [`IssueConnection`](#issueconnection) | Issues for projects in this group. | | `issues` | [`IssueConnection`](#issueconnection) | Issues for projects in this group. |
...@@ -3092,7 +3091,7 @@ Autogenerated return type of GitlabSubscriptionActivate. ...@@ -3092,7 +3091,7 @@ Autogenerated return type of GitlabSubscriptionActivate.
| `storageSizeLimit` | [`Float`](#float) | Total storage limit of the root namespace in bytes. | | `storageSizeLimit` | [`Float`](#float) | Total storage limit of the root namespace in bytes. |
| `subgroupCreationLevel` | [`String`](#string) | The permission level required to create subgroups within the group. | | `subgroupCreationLevel` | [`String`](#string) | The permission level required to create subgroups within the group. |
| `temporaryStorageIncreaseEndsOn` | [`Time`](#time) | Date until the temporary storage increase is active. | | `temporaryStorageIncreaseEndsOn` | [`Time`](#time) | Date until the temporary storage increase is active. |
| `timelogs` | [`TimelogConnection!`](#timelogconnection) | Time logged in issues by group members. | | `timelogs` | [`TimelogConnection!`](#timelogconnection) | Time logged on issues in the group and its subgroups. |
| `totalRepositorySize` | [`Float`](#float) | Total repository size of all projects in the root namespace in bytes. | | `totalRepositorySize` | [`Float`](#float) | Total repository size of all projects in the root namespace in bytes. |
| `totalRepositorySizeExcess` | [`Float`](#float) | Total excess repository size of all projects in the root namespace in bytes. | | `totalRepositorySizeExcess` | [`Float`](#float) | Total excess repository size of all projects in the root namespace in bytes. |
| `twoFactorGracePeriod` | [`Int`](#int) | Time before two-factor authentication is enforced. | | `twoFactorGracePeriod` | [`Int`](#int) | Time before two-factor authentication is enforced. |
......
...@@ -6,7 +6,7 @@ module EE ...@@ -6,7 +6,7 @@ module EE
extend ActiveSupport::Concern extend ActiveSupport::Concern
prepended do prepended do
%i[epics group_timelogs].each do |feature| %i[epics].each do |feature|
field "#{feature}_enabled", GraphQL::BOOLEAN_TYPE, null: true, field "#{feature}_enabled", GraphQL::BOOLEAN_TYPE, null: true,
description: "Indicates if #{feature.to_s.humanize} are enabled for namespace" description: "Indicates if #{feature.to_s.humanize} are enabled for namespace"
...@@ -43,12 +43,6 @@ module EE ...@@ -43,12 +43,6 @@ module EE
description: 'Find iteration cadences.', description: 'Find iteration cadences.',
resolver: ::Resolvers::Iterations::CadencesResolver resolver: ::Resolvers::Iterations::CadencesResolver
field :timelogs, ::Types::TimelogType.connection_type, null: false,
description: 'Time logged in issues by group members.',
extras: [:lookahead],
complexity: 5,
resolver: ::Resolvers::TimelogResolver
field :vulnerabilities, field :vulnerabilities,
::Types::VulnerabilityType.connection_type, ::Types::VulnerabilityType.connection_type,
null: true, null: true,
......
...@@ -12,7 +12,6 @@ module EE ...@@ -12,7 +12,6 @@ module EE
prepended do prepended do
include TokenAuthenticatable include TokenAuthenticatable
include InsightsFeature include InsightsFeature
include HasTimelogsReport
include HasWiki include HasWiki
include CanMoveRepositoryStorage include CanMoveRepositoryStorage
......
...@@ -127,7 +127,6 @@ class License < ApplicationRecord ...@@ -127,7 +127,6 @@ class License < ApplicationRecord
scoped_labels scoped_labels
smartcard_auth smartcard_auth
swimlanes swimlanes
group_timelogs
type_of_work_analytics type_of_work_analytics
minimal_access_role minimal_access_role
unprotection_restrictions unprotection_restrictions
......
...@@ -94,10 +94,6 @@ module EE ...@@ -94,10 +94,6 @@ module EE
@subject.saml_group_sync_available? @subject.saml_group_sync_available?
end end
condition(:group_timelogs_available) do
@subject.feature_available?(:group_timelogs)
end
with_scope :global with_scope :global
condition(:commit_committer_check_disabled_globally) do condition(:commit_committer_check_disabled_globally) do
!PushRule.global&.commit_committer_check !PushRule.global&.commit_committer_check
...@@ -152,7 +148,6 @@ module EE ...@@ -152,7 +148,6 @@ module EE
enable :admin_issue_board_list enable :admin_issue_board_list
enable :view_productivity_analytics enable :view_productivity_analytics
enable :view_type_of_work_charts enable :view_type_of_work_charts
enable :read_group_timelogs
enable :download_wiki_code enable :download_wiki_code
end end
...@@ -311,8 +306,6 @@ module EE ...@@ -311,8 +306,6 @@ module EE
enable :read_group_saml_identity enable :read_group_saml_identity
end end
rule { ~group_timelogs_available }.prevent :read_group_timelogs
rule { ~(admin | allow_to_manage_default_branch_protection) }.policy do rule { ~(admin | allow_to_manage_default_branch_protection) }.policy do
prevent :update_default_branch_protection prevent :update_default_branch_protection
end end
......
...@@ -164,10 +164,6 @@ module EE ...@@ -164,10 +164,6 @@ module EE
@subject.feature_available?(:status_page, @user) @subject.feature_available?(:status_page, @user)
end end
condition(:group_timelogs_available) do
@subject.feature_available?(:group_timelogs)
end
condition(:over_storage_limit, scope: :subject) do condition(:over_storage_limit, scope: :subject) do
@subject.root_namespace.over_storage_limit? @subject.root_namespace.over_storage_limit?
end end
...@@ -204,14 +200,11 @@ module EE ...@@ -204,14 +200,11 @@ module EE
prevent :admin_feature_flags_issue_links prevent :admin_feature_flags_issue_links
end end
rule { ~group_timelogs_available }.prevent :read_group_timelogs
rule { can?(:guest_access) & iterations_available }.enable :read_iteration rule { can?(:guest_access) & iterations_available }.enable :read_iteration
rule { can?(:reporter_access) }.policy do rule { can?(:reporter_access) }.policy do
enable :admin_issue_board enable :admin_issue_board
enable :admin_epic_issue enable :admin_epic_issue
enable :read_group_timelogs
end end
rule { oncall_schedules_available & can?(:reporter_access) }.enable :read_incident_management_oncall_schedule rule { oncall_schedules_available & can?(:reporter_access) }.enable :read_incident_management_oncall_schedule
......
...@@ -13,7 +13,6 @@ RSpec.describe GitlabSchema.types['Group'] do ...@@ -13,7 +13,6 @@ RSpec.describe GitlabSchema.types['Group'] do
it { expect(described_class).to have_graphql_field(:iterations) } it { expect(described_class).to have_graphql_field(:iterations) }
it { expect(described_class).to have_graphql_field(:iteration_cadences) } it { expect(described_class).to have_graphql_field(:iteration_cadences) }
it { expect(described_class).to have_graphql_field(:groupTimelogsEnabled) }
it { expect(described_class).to have_graphql_field(:timelogs, complexity: 5) } it { expect(described_class).to have_graphql_field(:timelogs, complexity: 5) }
it { expect(described_class).to have_graphql_field(:vulnerabilities) } it { expect(described_class).to have_graphql_field(:vulnerabilities) }
it { expect(described_class).to have_graphql_field(:vulnerability_scanners) } it { expect(described_class).to have_graphql_field(:vulnerability_scanners) }
......
...@@ -290,72 +290,6 @@ RSpec.describe GroupPolicy do ...@@ -290,72 +290,6 @@ RSpec.describe GroupPolicy do
it { is_expected.not_to be_allowed(:read_group_repository_analytics) } it { is_expected.not_to be_allowed(:read_group_repository_analytics) }
end end
context 'when timelogs report feature is enabled' do
before do
stub_licensed_features(group_timelogs: true)
end
context 'admin' do
let(:current_user) { admin }
context 'when admin mode is enabled', :enable_admin_mode do
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'when admin mode is disabled' do
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
end
context 'with owner' do
let(:current_user) { owner }
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'with maintainer' do
let(:current_user) { maintainer }
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'with reporter' do
let(:current_user) { reporter }
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'with guest' do
let(:current_user) { guest }
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
context 'with non member' do
let(:current_user) { create(:user) }
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
context 'with anonymous' do
let(:current_user) { nil }
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
end
context 'when timelogs report feature is disabled' do
let(:current_user) { admin }
before do
stub_licensed_features(group_timelogs: false)
end
it 'is disallowed even with admin mode', :enable_admin_mode do
is_expected.to be_disallowed(:read_group_timelogs)
end
end
describe 'per group SAML' do describe 'per group SAML' do
def stub_group_saml_config(enabled) def stub_group_saml_config(enabled)
allow(::Gitlab::Auth::GroupSaml::Config).to receive_messages(enabled?: enabled) allow(::Gitlab::Auth::GroupSaml::Config).to receive_messages(enabled?: enabled)
......
...@@ -1251,70 +1251,6 @@ RSpec.describe ProjectPolicy do ...@@ -1251,70 +1251,6 @@ RSpec.describe ProjectPolicy do
end end
end end
context 'when timelogs report feature is enabled' do
before do
stub_licensed_features(group_timelogs: true)
end
context 'admin' do
let(:current_user) { admin }
context 'when admin mode enabled', :enable_admin_mode do
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'when admin mode disabled' do
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
end
context 'with owner' do
let(:current_user) { owner }
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'with maintainer' do
let(:current_user) { maintainer }
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'with reporter' do
let(:current_user) { reporter }
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'with guest' do
let(:current_user) { guest }
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
context 'with non member' do
let(:current_user) { non_member }
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
context 'with anonymous' do
let(:current_user) { anonymous }
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
end
context 'when timelogs report feature is disabled' do
let(:current_user) { admin }
before do
stub_licensed_features(group_timelogs: false)
end
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
context 'when dora4 analytics is available' do context 'when dora4 analytics is available' do
let(:current_user) { developer } let(:current_user) { developer }
......
...@@ -17,7 +17,6 @@ RSpec.describe Resolvers::TimelogResolver do ...@@ -17,7 +17,6 @@ RSpec.describe Resolvers::TimelogResolver do
before do before do
group.add_developer(current_user) group.add_developer(current_user)
project.add_developer(current_user) project.add_developer(current_user)
stub_licensed_features(group_timelogs: true)
end end
describe '#resolve' do describe '#resolve' do
...@@ -40,12 +39,6 @@ RSpec.describe Resolvers::TimelogResolver do ...@@ -40,12 +39,6 @@ RSpec.describe Resolvers::TimelogResolver do
expect(resolve_timelogs(args)).to be_empty expect(resolve_timelogs(args)).to be_empty
end end
it 'returns nothing when feature is disabled' do
stub_licensed_features(group_timelogs: false)
expect(resolve_timelogs(args)).to be_empty
end
context 'when start_time and end_date are present' do context 'when start_time and end_date are present' do
let(:args) { { start_time: 6.days.ago, end_date: 2.days.ago } } let(:args) { { start_time: 6.days.ago, end_date: 2.days.ago } }
......
...@@ -34,19 +34,12 @@ RSpec.describe HasTimelogsReport do ...@@ -34,19 +34,12 @@ RSpec.describe HasTimelogsReport do
describe '#user_can_access_group_timelogs?' do describe '#user_can_access_group_timelogs?' do
before do before do
group.add_developer(user) group.add_developer(user)
stub_licensed_features(group_timelogs: true)
end end
it 'returns true if user can access group timelogs' do it 'returns true if user can access group timelogs' do
expect(group.user_can_access_group_timelogs?(user)).to be_truthy expect(group.user_can_access_group_timelogs?(user)).to be_truthy
end end
it 'returns false if feature group_timelogs is disabled' do
stub_licensed_features(group_timelogs: false)
expect(group.user_can_access_group_timelogs?(user)).to be_falsey
end
it 'returns false if user has insufficient permissions' do it 'returns false if user has insufficient permissions' do
group.add_guest(user) group.add_guest(user)
......
...@@ -922,4 +922,54 @@ RSpec.describe GroupPolicy do ...@@ -922,4 +922,54 @@ RSpec.describe GroupPolicy do
it { expect(described_class.new(current_user, subgroup)).to be_allowed(:read_label) } it { expect(described_class.new(current_user, subgroup)).to be_allowed(:read_label) }
end end
end end
context 'timelogs' do
context 'with admin' do
let(:current_user) { admin }
context 'when admin mode is enabled', :enable_admin_mode do
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'when admin mode is disabled' do
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
end
context 'with owner' do
let(:current_user) { owner }
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'with maintainer' do
let(:current_user) { maintainer }
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'with reporter' do
let(:current_user) { reporter }
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'with guest' do
let(:current_user) { guest }
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
context 'with non member' do
let(:current_user) { create(:user) }
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
context 'with anonymous' do
let(:current_user) { nil }
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
end
end end
...@@ -1353,4 +1353,54 @@ RSpec.describe ProjectPolicy do ...@@ -1353,4 +1353,54 @@ RSpec.describe ProjectPolicy do
end end
end end
end end
context 'timelogs' do
context 'with admin' do
let(:current_user) { admin }
context 'when admin mode enabled', :enable_admin_mode do
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'when admin mode disabled' do
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
end
context 'with owner' do
let(:current_user) { owner }
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'with maintainer' do
let(:current_user) { maintainer }
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'with reporter' do
let(:current_user) { reporter }
it { is_expected.to be_allowed(:read_group_timelogs) }
end
context 'with guest' do
let(:current_user) { guest }
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
context 'with non member' do
let(:current_user) { non_member }
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
context 'with anonymous' do
let(:current_user) { anonymous }
it { is_expected.to be_disallowed(:read_group_timelogs) }
end
end
end end
...@@ -16,7 +16,15 @@ RSpec.describe 'getting custom emoji within namespace' do ...@@ -16,7 +16,15 @@ RSpec.describe 'getting custom emoji within namespace' do
describe "Query CustomEmoji on Group" do describe "Query CustomEmoji on Group" do
def custom_emoji_query(group) 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 end
it 'returns emojis when authorised' do it 'returns emojis when authorised' do
......
...@@ -10,8 +10,7 @@ RSpec.describe 'Timelogs through GroupQuery' do ...@@ -10,8 +10,7 @@ RSpec.describe 'Timelogs through GroupQuery' do
let_it_be(:group) { create(:group) } let_it_be(:group) { create(:group) }
let_it_be(:project) { create(:project, :public, group: group) } let_it_be(:project) { create(:project, :public, group: group) }
let_it_be(:milestone) { create(:milestone, group: group) } let_it_be(:milestone) { create(:milestone, group: group) }
let_it_be(:epic) { create(:epic, group: group) } let_it_be(:issue) { create(:issue, project: project, milestone: milestone) }
let_it_be(:issue) { create(:issue, project: project, milestone: milestone, epic: epic) }
let_it_be(:timelog1) { create(:timelog, issue: issue, user: user, spent_at: '2019-08-13 14:00:00') } 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(: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_it_be(:params) { { startTime: '2019-08-10 12:00:00', endTime: '2019-08-21 12:00:00' } }
...@@ -19,7 +18,6 @@ RSpec.describe 'Timelogs through GroupQuery' do ...@@ -19,7 +18,6 @@ RSpec.describe 'Timelogs through GroupQuery' do
before do before do
group.add_developer(user) group.add_developer(user)
stub_licensed_features(group_timelogs: true, epics: true)
end end
context 'when the request is correct' do context 'when the request is correct' do
...@@ -33,7 +31,6 @@ RSpec.describe 'Timelogs through GroupQuery' do ...@@ -33,7 +31,6 @@ RSpec.describe 'Timelogs through GroupQuery' do
expect(response).to have_gitlab_http_status(:ok) expect(response).to have_gitlab_http_status(:ok)
expect(graphql_errors).to be_nil expect(graphql_errors).to be_nil
expect(timelog_array.size).to eq 1 expect(timelog_array.size).to eq 1
expect(graphql_data['group']['groupTimelogsEnabled']).to be_truthy
end end
it 'contains correct data', :aggregate_failures do it 'contains correct data', :aggregate_failures do
...@@ -42,14 +39,12 @@ RSpec.describe 'Timelogs through GroupQuery' do ...@@ -42,14 +39,12 @@ RSpec.describe 'Timelogs through GroupQuery' do
time_spent = timelog_array.map { |data| data['timeSpent'] } time_spent = timelog_array.map { |data| data['timeSpent'] }
issue_title = timelog_array.map {|data| data['issue']['title'] } issue_title = timelog_array.map {|data| data['issue']['title'] }
milestone_title = timelog_array.map {|data| data['issue']['milestone']['title'] } milestone_title = timelog_array.map {|data| data['issue']['milestone']['title'] }
epic_title = timelog_array.map {|data| data['issue']['epic']['title'] }
expect(username).to eq([user.username]) expect(username).to eq([user.username])
expect(spent_at.first).to be_like_time(timelog1.spent_at) expect(spent_at.first).to be_like_time(timelog1.spent_at)
expect(time_spent).to eq([timelog1.time_spent]) expect(time_spent).to eq([timelog1.time_spent])
expect(issue_title).to eq([issue.title]) expect(issue_title).to eq([issue.title])
expect(milestone_title).to eq([milestone.title]) expect(milestone_title).to eq([milestone.title])
expect(epic_title).to eq([epic.title])
end end
context 'when arguments with no time are present' do context 'when arguments with no time are present' do
...@@ -65,21 +60,6 @@ RSpec.describe 'Timelogs through GroupQuery' do ...@@ -65,21 +60,6 @@ RSpec.describe 'Timelogs through GroupQuery' do
end end
context 'when requests has errors' do context 'when requests has errors' do
context 'when group_timelogs feature is disabled' do
before do
stub_licensed_features(group_timelogs: false)
end
it 'returns empty' 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
expect(graphql_data['group']['groupTimelogsEnabled']).to be_falsey
end
end
context 'when there are no timelogs present' do context 'when there are no timelogs present' do
before do before do
Timelog.delete_all Timelog.delete_all
...@@ -91,7 +71,6 @@ RSpec.describe 'Timelogs through GroupQuery' do ...@@ -91,7 +71,6 @@ RSpec.describe 'Timelogs through GroupQuery' do
expect(response).to have_gitlab_http_status(:success) expect(response).to have_gitlab_http_status(:success)
expect(graphql_errors).to be_nil expect(graphql_errors).to be_nil
expect(timelogs_data).to be_empty expect(timelogs_data).to be_empty
expect(graphql_data['group']['groupTimelogsEnabled']).to be_truthy
end end
end end
...@@ -104,7 +83,6 @@ RSpec.describe 'Timelogs through GroupQuery' do ...@@ -104,7 +83,6 @@ RSpec.describe 'Timelogs through GroupQuery' do
expect(response).to have_gitlab_http_status(:success) expect(response).to have_gitlab_http_status(:success)
expect(graphql_errors).to be_nil expect(graphql_errors).to be_nil
expect(timelogs_data).to be_empty expect(timelogs_data).to be_empty
expect(graphql_data['group']['groupTimelogsEnabled']).to be_truthy
end end
end end
end end
...@@ -129,15 +107,12 @@ RSpec.describe 'Timelogs through GroupQuery' do ...@@ -129,15 +107,12 @@ RSpec.describe 'Timelogs through GroupQuery' do
milestone { milestone {
title title
} }
epic {
title
}
} }
} }
NODE NODE
graphql_query_for("group", { "fullPath" => group.full_path }, graphql_query_for("group", { "fullPath" => group.full_path },
['groupTimelogsEnabled', query_graphql_field( [query_graphql_field(
"timelogs", "timelogs",
timelog_params, timelog_params,
timelog_nodes timelog_nodes
......
...@@ -17,7 +17,15 @@ RSpec.describe 'getting group information' do ...@@ -17,7 +17,15 @@ RSpec.describe 'getting group information' do
# similar to the API "GET /groups/:id" # similar to the API "GET /groups/:id"
describe "Query group(fullPath)" do describe "Query group(fullPath)" do
def group_query(group) 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 end
it_behaves_like 'a working graphql query' do it_behaves_like 'a working graphql query' do
......
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