Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab_style_deprecations.rb « concerns « types « graphql « app - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: ad19535493050511a8c515dc43e23d9198c68a93 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# frozen_string_literal: true

# Concern for handling deprecation arguments.
# https://docs.gitlab.com/ee/development/api_graphql_styleguide.html#deprecating-fields-and-enum-values
module GitlabStyleDeprecations
  extend ActiveSupport::Concern

  private

  def gitlab_deprecation(kwargs)
    if kwargs[:deprecation_reason].present?
      raise ArgumentError, 'Use `deprecated` property instead of `deprecation_reason`. ' \
                           'See https://docs.gitlab.com/ee/development/api_graphql_styleguide.html#deprecating-fields-arguments-and-enum-values'
    end

    deprecation = kwargs.delete(:deprecated)
    return kwargs unless deprecation

    milestone, reason = deprecation.values_at(:milestone, :reason).map(&:presence)

    raise ArgumentError, 'Please provide a `milestone` within `deprecated`' unless milestone
    raise ArgumentError, 'Please provide a `reason` within `deprecated`' unless reason
    raise ArgumentError, '`milestone` must be a `String`' unless milestone.is_a?(String)

    deprecated_in = "Deprecated in #{milestone}"
    kwargs[:deprecation_reason] = "#{reason}. #{deprecated_in}."
    kwargs[:description] += " #{deprecated_in}: #{reason}." if kwargs[:description]

    kwargs
  end
end