Class: Fastlane::Actions::CreateJiraVersionAction

Inherits:
Action
  • Object
show all
Defined in:
lib/fastlane/plugin/jira_util/actions/create_jira_version.rb

Documentation collapse

Class Method Summary collapse

Class Method Details

.authorsObject



184
185
186
# File 'lib/fastlane/plugin/jira_util/actions/create_jira_version.rb', line 184

def self.authors
  [ "https://github.com/SandyChapman", "https://github.com/alexeyn-martynov" ]
end

.available_optionsObject



92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
# File 'lib/fastlane/plugin/jira_util/actions/create_jira_version.rb', line 92

def self.available_options
  [
    FastlaneCore::ConfigItem.new(key: :url,
                                env_name: "FL_JIRA_UTIL_SITE",
                                description: "URL for Jira instance",
                                type: String,
                                verify_block: proc do |value|
                                  UI.user_error!("No url for Jira given, pass using `url: 'url'`") unless value and !value.empty?
                                end),
    FastlaneCore::ConfigItem.new(key: :username,
                                 env_name: "FL_JIRA_UTIL_USERNAME",
                                 description: "Username for JIRA instance",
                                 type: String,
                                 verify_block: proc do |value|
                                   UI.user_error!("No username given, pass using `username: 'jira_user'`") unless value and !value.empty?
                                 end),
    FastlaneCore::ConfigItem.new(key: :password,
                                 env_name: "FL_JIRA_UTIL_PASSWORD",
                                 description: "Password for Jira",
                                 type: String,
                                 verify_block: proc do |value|
                                   UI.user_error!("No password given, pass using `password: 'T0PS3CR3T'`") unless value and !value.empty?
                                 end),
    FastlaneCore::ConfigItem.new(key: :project_name,
                                 env_name: "FL_JIRA_UTIL_PROJECT_NAME",
                                 description: "Project ID for the JIRA project. E.g. the short abbreviation in the JIRA ticket tags",
                                 type: String,
                                 optional: true,
                                 conflicting_options: [:project_id],
                                 conflict_block: proc do |value|
                                   UI.user_error!("You can't use 'project_name' and '#{project_id}' options in one run")
                                 end,
                                 verify_block: proc do |value|
                                   UI.user_error!("No Project ID given, pass using `project_id: 'PROJID'`") unless value and !value.empty?
                                 end),
    FastlaneCore::ConfigItem.new(key: :project_id,
                                 env_name: "FL_JIRA_UTIL_PROJECT_ID",
                                 description: "Project ID for the JIRA project. E.g. the short abbreviation in the JIRA ticket tags",
                                 type: String,
                                 optional: true,
                                 conflicting_options: [:project_name],
                                 conflict_block: proc do |value|
                                   UI.user_error!("You can't use 'project_id' and '#{project_name}' options in one run")
                                 end,
                                 verify_block: proc do |value|
                                   UI.user_error!("No Project ID given, pass using `project_id: 'PROJID'`") unless value and !value.empty?
                                 end),
    FastlaneCore::ConfigItem.new(key: :name,
                                 is_string: true,
                                 optional: true,
                                 description: "The name of the version. E.g. 1.0.0",
                                 verify_block: proc do |value|
                                   UI.user_error!("No version name given, pass using `name: '1.0.0'`") unless value and !value.empty?
                                 end),
    FastlaneCore::ConfigItem.new(key: :description,
                                 is_string: true,
                                 optional: true,
                                 description: "The description of the JIRA project version",
                                 default_value: ''),
    FastlaneCore::ConfigItem.new(key: :archived,
                                 is_string: false,
                                 optional: true,
                                 description: "Whether the version should be archived",
                                 default_value: false),
    FastlaneCore::ConfigItem.new(key: :released,
                                 is_string: false,
                                 optional: true,
                                 description: "Whether the version should be released",
                                 default_value: false),
    FastlaneCore::ConfigItem.new(key: :start_date,
                                 is_string: true,
                                 optional: true,
                                 description: "The date this version will start on",
                                 default_value: Date.today.to_s),
    FastlaneCore::ConfigItem.new(key: :update_if_exists,
                                 is_string: false,
                                 optional: true,
                                 description: "If version with 'name' exists it will be updated",
                                 default_value: false),
  ]
end

.descriptionObject



84
85
86
# File 'lib/fastlane/plugin/jira_util/actions/create_jira_version.rb', line 84

def self.description
  "Creates a new version in your JIRA project"
end

.detailsObject



88
89
90
# File 'lib/fastlane/plugin/jira_util/actions/create_jira_version.rb', line 88

def self.details
  "Use this action to create a new version in JIRA"
end

.is_supported?(platform) ⇒ Boolean

Returns:

  • (Boolean)


188
189
190
# File 'lib/fastlane/plugin/jira_util/actions/create_jira_version.rb', line 188

def self.is_supported?(platform)
  true
end

.outputObject



174
175
176
177
178
# File 'lib/fastlane/plugin/jira_util/actions/create_jira_version.rb', line 174

def self.output
  [
    ['JIRA_UTIL_CREATE_JIRA_VERSION_VERSION_ID', 'The versionId for the newly created JIRA project version']
  ]
end

.return_valueObject



180
181
182
# File 'lib/fastlane/plugin/jira_util/actions/create_jira_version.rb', line 180

def self.return_value
  'The versionId for the newly create JIRA project version'
end

.run(params) ⇒ Object



8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
# File 'lib/fastlane/plugin/jira_util/actions/create_jira_version.rb', line 8

def self.run(params)
  Actions.verify_gem!('jira-ruby')
  require 'jira-ruby'

  site              = params[:url]
  context_path      = ""
  auth_type         = :basic
  username          = params[:username]
  password          = params[:password]
  project_name      = params[:project_name]
  project_id        = params[:project_id]
  name              = params[:name]
  description       = params[:description]
  archived          = params[:archived]
  released          = params[:released]
  start_date        = params[:start_date]
  update_if_exists  = params[:update_if_exists]

  options = {
    username:     username,
    password:     password,
    site:         site,
    context_path: context_path,
    auth_type:    auth_type,
    read_timeout: 120
  }

  client = JIRA::Client.new(options)

  unless project_name.nil?
    project = client.Project.find(project_name)
    project_id = project.id
  end
  raise ArgumentError.new("Project not found.") if project_id.nil?

  if start_date.nil?
    start_date = Date.today.to_s
  end

  version = project.versions.find { |version| version.name == name }
  if version.nil?
    version = client.Version.build
    version.save!({
      "description" => description,
      "name" => name,
      "archived" => archived,
      "released" => released,
      "startDate" => start_date,
      "projectId" => project_id
    })
  elsif update_if_exists
    version.save!({
      "description" => description,
      "archived" => archived,
      "released" => released,
      "startDate" => start_date,
    })
  else
    raise RuntimeError.new("Version with such name already exists.")
  end

  version.fetch
  Actions.lane_context[SharedValues::JIRA_UTIL_CREATE_JIRA_VERSION_VERSION_ID] = version.id
  version.id
rescue JIRA::HTTPError
  UI.user_error!("Failed to create JIRA issue: #{$!.response.body}")
  nil
rescue
  UI.user_error!("Failed to create JIRA issue: #{$!}")
  nil
end