Class: Fastlane::Actions::ChangelogFromGitCommitsAction

Inherits:
Fastlane::Action show all
Defined in:
fastlane/lib/fastlane/actions/changelog_from_git_commits.rb

Constant Summary

Constants inherited from Fastlane::Action

Fastlane::Action::AVAILABLE_CATEGORIES, Fastlane::Action::RETURN_TYPES

Documentation collapse

Class Method Summary collapse

Methods inherited from Fastlane::Action

action_name, authors, deprecated_notes, lane_context, method_missing, other_action, sample_return_value, shell_out_should_use_bundle_exec?, step_text

Class Method Details

.authorObject



161
162
163
# File 'fastlane/lib/fastlane/actions/changelog_from_git_commits.rb', line 161

def self.author
  ['mfurtak', 'asfalcone', 'SiarheiFedartsou', 'allewun']
end

.available_optionsObject



72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
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
# File 'fastlane/lib/fastlane/actions/changelog_from_git_commits.rb', line 72

def self.available_options
  [
    FastlaneCore::ConfigItem.new(key: :between,
                                 env_name: 'FL_CHANGELOG_FROM_GIT_COMMITS_BETWEEN',
                                 description: 'Array containing two Git revision values between which to collect messages, you mustn\'t use it with :commits_count key at the same time',
                                 optional: true,
                                 is_string: false,
                                 conflicting_options: [:commits_count],
                                 verify_block: proc do |value|
                                   if value.kind_of?(String)
                                     UI.user_error!(":between must contain comma") unless value.include?(',')
                                   else
                                     UI.user_error!(":between must be of type array") unless value.kind_of?(Array)
                                     UI.user_error!(":between must not contain nil values") if value.any?(&:nil?)
                                     UI.user_error!(":between must be an array of size 2") unless (value || []).size == 2
                                   end
                                 end),
    FastlaneCore::ConfigItem.new(key: :commits_count,
                                 env_name: 'FL_CHANGELOG_FROM_GIT_COMMITS_COUNT',
                                 description: 'Number of commits to include in changelog, you mustn\'t use it with :between key at the same time',
                                 optional: true,
                                 is_string: false,
                                 conflicting_options: [:between],
                                 type: Integer,
                                 verify_block: proc do |value|
                                   UI.user_error!(":commits_count must be >= 1") unless value.to_i >= 1
                                 end),
    FastlaneCore::ConfigItem.new(key: :path,
                                 env_name: 'FL_CHANGELOG_FROM_GIT_COMMITS_PATH',
                                 description: 'Path of the git repository',
                                 optional: true,
                                 default_value: './'),
    FastlaneCore::ConfigItem.new(key: :pretty,
                                 env_name: 'FL_CHANGELOG_FROM_GIT_COMMITS_PRETTY',
                                 description: 'The format applied to each commit while generating the collected value',
                                 optional: true,
                                 default_value: '%B',
                                 is_string: true),
    FastlaneCore::ConfigItem.new(key: :date_format,
                                 env_name: 'FL_CHANGELOG_FROM_GIT_COMMITS_DATE_FORMAT',
                                 description: 'The date format applied to each commit while generating the collected value',
                                 optional: true,
                                 is_string: true),
    FastlaneCore::ConfigItem.new(key: :ancestry_path,
                                 env_name: 'FL_CHANGELOG_FROM_GIT_COMMITS_ANCESTRY_PATH',
                                 description: 'Whether or not to use ancestry-path param',
                                 optional: true,
                                 default_value: false,
                                 is_string: false),
    FastlaneCore::ConfigItem.new(key: :tag_match_pattern,
                                 env_name: 'FL_CHANGELOG_FROM_GIT_COMMITS_TAG_MATCH_PATTERN',
                                 description: 'A glob(7) pattern to match against when finding the last git tag',
                                 optional: true),
    FastlaneCore::ConfigItem.new(key: :match_lightweight_tag,
                                 env_name: 'FL_CHANGELOG_FROM_GIT_COMMITS_MATCH_LIGHTWEIGHT_TAG',
                                 description: 'Whether or not to match a lightweight tag when searching for the last one',
                                 optional: true,
                                 default_value: true,
                                 is_string: false),
    FastlaneCore::ConfigItem.new(key: :include_merges,
                                 deprecated: "Use `:merge_commit_filtering` instead",
                                 env_name: 'FL_CHANGELOG_FROM_GIT_COMMITS_INCLUDE_MERGES',
                                 description: "Whether or not to include any commits that are merges",
                                 optional: true,
                                 is_string: false,
                                 type: Boolean,
                                 verify_block: proc do |value|
                                   UI.important("The :include_merges option is deprecated. Please use :merge_commit_filtering instead") unless value.nil?
                                 end),
    FastlaneCore::ConfigItem.new(key: :merge_commit_filtering,
                                 env_name: 'FL_CHANGELOG_FROM_GIT_COMMITS_MERGE_COMMIT_FILTERING',
                                 description: "Controls inclusion of merge commits when collecting the changelog. Valid values: #{GIT_MERGE_COMMIT_FILTERING_OPTIONS.map { |o| "`:#{o}`" }.join(', ')}",
                                 optional: true,
                                 default_value: 'include_merges',
                                 verify_block: proc do |value|
                                   matches_option = GIT_MERGE_COMMIT_FILTERING_OPTIONS.any? { |opt| opt.to_s == value }
                                   UI.user_error!("Valid values for :merge_commit_filtering are #{GIT_MERGE_COMMIT_FILTERING_OPTIONS.map { |o| "'#{o}'" }.join(', ')}") unless matches_option
                                 end)
  ]
end

.categoryObject



182
183
184
# File 'fastlane/lib/fastlane/actions/changelog_from_git_commits.rb', line 182

def self.category
  :source_control
end

.descriptionObject



60
61
62
# File 'fastlane/lib/fastlane/actions/changelog_from_git_commits.rb', line 60

def self.description
  "Collect git commit messages into a changelog"
end

.detailsObject



64
65
66
# File 'fastlane/lib/fastlane/actions/changelog_from_git_commits.rb', line 64

def self.details
  "By default, messages will be collected back to the last tag, but the range can be controlled"
end

.example_codeObject



169
170
171
172
173
174
175
176
177
178
179
180
# File 'fastlane/lib/fastlane/actions/changelog_from_git_commits.rb', line 169

def self.example_code
  [
    'changelog_from_git_commits',
    'changelog_from_git_commits(
      between: ["7b092b3", "HEAD"],            # Optional, lets you specify a revision/tag range between which to collect commit info
      pretty: "- (%ae) %s",                    # Optional, lets you provide a custom format to apply to each commit when generating the changelog text
      date_format: "short",                    # Optional, lets you provide an additional date format to dates within the pretty-formatted string
      match_lightweight_tag: false,            # Optional, lets you ignore lightweight (non-annotated) tags when searching for the last tag
      merge_commit_filtering: "exclude_merges" # Optional, lets you filter out merge commits
    )'
  ]
end

.is_supported?(platform) ⇒ Boolean

Returns:



165
166
167
# File 'fastlane/lib/fastlane/actions/changelog_from_git_commits.rb', line 165

def self.is_supported?(platform)
  true
end

.outputObject



68
69
70
# File 'fastlane/lib/fastlane/actions/changelog_from_git_commits.rb', line 68

def self.output
  ['FL_CHANGELOG', 'The changelog String generated from the collected Git commit messages']
end

.return_typeObject



157
158
159
# File 'fastlane/lib/fastlane/actions/changelog_from_git_commits.rb', line 157

def self.return_type
  :string
end

.return_valueObject



153
154
155
# File 'fastlane/lib/fastlane/actions/changelog_from_git_commits.rb', line 153

def self.return_value
  "Returns a String containing your formatted git commits"
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
# File 'fastlane/lib/fastlane/actions/changelog_from_git_commits.rb', line 8

def self.run(params)
  if params[:commits_count]
    UI.success("Collecting the last #{params[:commits_count]} Git commits")
  else
    if params[:between]
      if params[:between].kind_of?(String) && params[:between].include?(",") # :between is string
        from, to = params[:between].split(",", 2)
      elsif params[:between].kind_of?(Array)
        from, to = params[:between]
      end
    else
      from = Actions.last_git_tag_name(params[:match_lightweight_tag], params[:tag_match_pattern])
      UI.verbose("Found the last Git tag: #{from}")
      to = 'HEAD'
    end
    UI.success("Collecting Git commits between #{from} and #{to}")
  end

  # Normally it is not good practice to take arbitrary input and convert it to a symbol
  # because prior to Ruby 2.2, symbols are never garbage collected. However, we've
  # already validated that the input matches one of our allowed values, so this is OK
  merge_commit_filtering = params[:merge_commit_filtering].to_sym

  # We want to be specific and exclude nil for this comparison
  if params[:include_merges] == false
    merge_commit_filtering = :exclude_merges
  end

  params[:path] = './' unless params[:path]

  Dir.chdir(params[:path]) do
    if params[:commits_count]
      changelog = Actions.git_log_last_commits(params[:pretty], params[:commits_count], merge_commit_filtering, params[:date_format], params[:ancestry_path])
    else
      changelog = Actions.git_log_between(params[:pretty], from, to, merge_commit_filtering, params[:date_format], params[:ancestry_path])
    end

    changelog = changelog.gsub("\n\n", "\n") if changelog # as there are duplicate newlines
    Actions.lane_context[SharedValues::FL_CHANGELOG] = changelog

    puts("")
    puts(changelog)
    puts("")

    changelog
  end
end