fastlane-plugin-wpmreleasetoolkit 1.1.0 → 1.4.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_betabuild_prechecks.rb +17 -11
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_build_prechecks.rb +11 -5
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_bump_version_beta.rb +24 -24
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_bump_version_final_release.rb +25 -22
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_bump_version_hotfix.rb +23 -28
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_bump_version_release.rb +29 -38
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_codefreeze_prechecks.rb +14 -7
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_completecodefreeze_prechecks.rb +8 -2
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_current_branch_is_hotfix.rb +9 -1
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_finalize_prechecks.rb +6 -2
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_get_alpha_version.rb +7 -1
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_get_app_version.rb +7 -1
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_get_release_version.rb +7 -1
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_hotifx_prechecks.rb +4 -4
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_tag_build.rb +9 -3
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/common/check_translation_progress.rb +147 -0
- data/lib/fastlane/plugin/wpmreleasetoolkit/actions/ios/ios_bump_version_hotfix.rb +30 -15
- data/lib/fastlane/plugin/wpmreleasetoolkit/helper/android/android_git_helper.rb +14 -5
- data/lib/fastlane/plugin/wpmreleasetoolkit/helper/android/android_version_helper.rb +124 -46
- data/lib/fastlane/plugin/wpmreleasetoolkit/helper/filesystem_helper.rb +3 -1
- data/lib/fastlane/plugin/wpmreleasetoolkit/helper/glotpress_helper.rb +79 -0
- data/lib/fastlane/plugin/wpmreleasetoolkit/version.rb +1 -1
- metadata +18 -2
data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_completecodefreeze_prechecks.rb
CHANGED
@@ -9,8 +9,10 @@ module Fastlane
|
|
9
9
|
|
10
10
|
UI.user_error!('This is not a release branch. Abort.') unless other_action.git_branch.start_with?('release/')
|
11
11
|
|
12
|
-
|
13
|
-
|
12
|
+
app = params[:app]
|
13
|
+
|
14
|
+
version = Fastlane::Helper::Android::VersionHelper.get_public_version(app)
|
15
|
+
message = "Completing code freeze for: [#{app}]#{version}\n"
|
14
16
|
unless params[:skip_confirm]
|
15
17
|
UI.user_error!('Aborted by user request') unless UI.confirm("#{message}Do you want to continue?")
|
16
18
|
else
|
@@ -42,6 +44,10 @@ module Fastlane
|
|
42
44
|
description: 'Skips confirmation',
|
43
45
|
is_string: false, # true: verifies the input is a string, false: every kind of value
|
44
46
|
default_value: false), # the default value if the user didn't provide one
|
47
|
+
FastlaneCore::ConfigItem.new(key: :app,
|
48
|
+
env_name: 'PROJECT_NAME',
|
49
|
+
description: 'The name of the app to get the release version for',
|
50
|
+
is_string: true), # true: verifies the input is a string, false: every kind of value
|
45
51
|
]
|
46
52
|
end
|
47
53
|
|
data/lib/fastlane/plugin/wpmreleasetoolkit/actions/android/android_current_branch_is_hotfix.rb
CHANGED
@@ -7,7 +7,8 @@ module Fastlane
|
|
7
7
|
class AndroidCurrentBranchIsHotfixAction < Action
|
8
8
|
def self.run(params)
|
9
9
|
require_relative '../../helper/android/android_version_helper'
|
10
|
-
Fastlane::Helper::Android::VersionHelper.
|
10
|
+
version = Fastlane::Helper::Android::VersionHelper.get_release_version(product_name: params[:app])
|
11
|
+
Fastlane::Helper::Android::VersionHelper.is_hotfix?(version)
|
11
12
|
end
|
12
13
|
|
13
14
|
#####################################################
|
@@ -23,6 +24,13 @@ module Fastlane
|
|
23
24
|
end
|
24
25
|
|
25
26
|
def self.available_options
|
27
|
+
# Define all options your action supports.
|
28
|
+
[
|
29
|
+
FastlaneCore::ConfigItem.new(key: :app,
|
30
|
+
env_name: 'PROJECT_NAME',
|
31
|
+
description: 'The name of the app to get the release version for',
|
32
|
+
is_string: true), # true: verifies the input is a string, false: every kind of value
|
33
|
+
]
|
26
34
|
end
|
27
35
|
|
28
36
|
def self.output
|
@@ -13,8 +13,8 @@ module Fastlane
|
|
13
13
|
|
14
14
|
UI.user_error!('This is not a release branch. Abort.') unless other_action.git_branch.start_with?('release/')
|
15
15
|
|
16
|
-
version = Fastlane::Helper::Android::VersionHelper.get_public_version
|
17
|
-
message = "Finalizing release: #{version}\n"
|
16
|
+
version = Fastlane::Helper::Android::VersionHelper.get_public_version(params[:app])
|
17
|
+
message = "Finalizing #{params[:app]} release: #{version}\n"
|
18
18
|
if params[:skip_confirm]
|
19
19
|
UI.message(message)
|
20
20
|
else
|
@@ -49,6 +49,10 @@ module Fastlane
|
|
49
49
|
description: 'Skips confirmation',
|
50
50
|
is_string: false, # true: verifies the input is a string, false: every kind of value
|
51
51
|
default_value: false), # the default value if the user didn't provide one
|
52
|
+
FastlaneCore::ConfigItem.new(key: :app,
|
53
|
+
env_name: 'PROJECT_NAME',
|
54
|
+
description: 'The name of the app to get the release version for',
|
55
|
+
is_string: true), # true: verifies the input is a string, false: every kind of value
|
52
56
|
]
|
53
57
|
end
|
54
58
|
|
@@ -3,7 +3,7 @@ module Fastlane
|
|
3
3
|
class AndroidGetAlphaVersionAction < Action
|
4
4
|
def self.run(params)
|
5
5
|
require_relative '../../helper/android/android_version_helper'
|
6
|
-
Fastlane::Helper::Android::VersionHelper.get_alpha_version()
|
6
|
+
Fastlane::Helper::Android::VersionHelper.get_alpha_version(params[:app])
|
7
7
|
end
|
8
8
|
|
9
9
|
#####################################################
|
@@ -20,6 +20,12 @@ module Fastlane
|
|
20
20
|
|
21
21
|
def self.available_options
|
22
22
|
# Define all options your action supports.
|
23
|
+
[
|
24
|
+
FastlaneCore::ConfigItem.new(key: :app,
|
25
|
+
env_name: 'PROJECT_NAME',
|
26
|
+
description: 'The name of the app to get the release version for',
|
27
|
+
is_string: true), # true: verifies the input is a string, false: every kind of value
|
28
|
+
]
|
23
29
|
end
|
24
30
|
|
25
31
|
def self.output
|
@@ -3,7 +3,7 @@ module Fastlane
|
|
3
3
|
class AndroidGetAppVersionAction < Action
|
4
4
|
def self.run(params)
|
5
5
|
require_relative '../../helper/android/android_version_helper'
|
6
|
-
Fastlane::Helper::Android::VersionHelper.get_public_version
|
6
|
+
Fastlane::Helper::Android::VersionHelper.get_public_version(params[:app])
|
7
7
|
end
|
8
8
|
|
9
9
|
#####################################################
|
@@ -20,6 +20,12 @@ module Fastlane
|
|
20
20
|
|
21
21
|
def self.available_options
|
22
22
|
# Define all options your action supports.
|
23
|
+
[
|
24
|
+
FastlaneCore::ConfigItem.new(key: :app,
|
25
|
+
env_name: 'PROJECT_NAME',
|
26
|
+
description: 'The name of the app to get the release version for',
|
27
|
+
is_string: true), # true: verifies the input is a string, false: every kind of value
|
28
|
+
]
|
23
29
|
end
|
24
30
|
|
25
31
|
def self.output
|
@@ -3,7 +3,7 @@ module Fastlane
|
|
3
3
|
class AndroidGetReleaseVersionAction < Action
|
4
4
|
def self.run(params)
|
5
5
|
require_relative '../../helper/android/android_version_helper'
|
6
|
-
Fastlane::Helper::Android::VersionHelper.get_release_version()
|
6
|
+
Fastlane::Helper::Android::VersionHelper.get_release_version(product_name: params[:app])
|
7
7
|
end
|
8
8
|
|
9
9
|
#####################################################
|
@@ -20,6 +20,12 @@ module Fastlane
|
|
20
20
|
|
21
21
|
def self.available_options
|
22
22
|
# Define all options your action supports.
|
23
|
+
[
|
24
|
+
FastlaneCore::ConfigItem.new(key: :app,
|
25
|
+
env_name: 'PROJECT_NAME',
|
26
|
+
description: 'The name of the app to get the release version for',
|
27
|
+
is_string: true), # true: verifies the input is a string, false: every kind of value
|
28
|
+
]
|
23
29
|
end
|
24
30
|
|
25
31
|
def self.output
|
@@ -14,7 +14,7 @@ module Fastlane
|
|
14
14
|
|
15
15
|
# Confirm
|
16
16
|
message = "Requested Hotfix version: #{new_ver}\n"
|
17
|
-
message << "Branching from: #{prev_ver}\n"
|
17
|
+
message << "Branching from tag: #{prev_ver}\n"
|
18
18
|
|
19
19
|
if params[:skip_confirm]
|
20
20
|
UI.message(message)
|
@@ -50,13 +50,13 @@ module Fastlane
|
|
50
50
|
[
|
51
51
|
FastlaneCore::ConfigItem.new(key: :version_name,
|
52
52
|
env_name: 'FL_ANDROID_HOTFIX_PRECHECKS_VERSION',
|
53
|
-
description: 'The version to
|
53
|
+
description: 'The hotfix version number to create',
|
54
54
|
is_string: true),
|
55
55
|
FastlaneCore::ConfigItem.new(key: :skip_confirm,
|
56
56
|
env_name: 'FL_ANDROID_HOTFIX_PRECHECKS_SKIPCONFIRM',
|
57
57
|
description: 'Skips confirmation',
|
58
|
-
is_string: false, #
|
59
|
-
default_value: false),
|
58
|
+
is_string: false, # Boolean
|
59
|
+
default_value: false),
|
60
60
|
]
|
61
61
|
end
|
62
62
|
|
@@ -5,10 +5,12 @@ module Fastlane
|
|
5
5
|
require_relative '../../helper/android/android_version_helper'
|
6
6
|
require_relative '../../helper/android/android_git_helper'
|
7
7
|
|
8
|
-
|
9
|
-
|
8
|
+
app = ENV['PROJECT_NAME'].nil? ? params[:app] : ENV['PROJECT_NAME']
|
9
|
+
|
10
|
+
release_ver = Fastlane::Helper::Android::VersionHelper.get_release_version(product_name: app)
|
11
|
+
alpha_ver = Fastlane::Helper::Android::VersionHelper.get_alpha_version(app)
|
10
12
|
Fastlane::Helper::GitHelper.create_tag(release_ver[Fastlane::Helper::Android::VersionHelper::VERSION_NAME])
|
11
|
-
Fastlane::Helper::GitHelper.create_tag(alpha_ver[Fastlane::Helper::Android::VersionHelper::VERSION_NAME]) unless
|
13
|
+
Fastlane::Helper::GitHelper.create_tag(alpha_ver[Fastlane::Helper::Android::VersionHelper::VERSION_NAME]) unless alpha_ver.nil? || (params[:tag_alpha] == false)
|
12
14
|
end
|
13
15
|
|
14
16
|
#####################################################
|
@@ -30,6 +32,10 @@ module Fastlane
|
|
30
32
|
description: 'True to skip tagging the alpha version',
|
31
33
|
is_string: false,
|
32
34
|
default_value: true),
|
35
|
+
FastlaneCore::ConfigItem.new(key: :app,
|
36
|
+
env_name: 'PROJECT_NAME',
|
37
|
+
description: 'The name of the app to get the release version for',
|
38
|
+
is_string: true), # true: verifies the input is a string, false: every kind of value
|
33
39
|
]
|
34
40
|
end
|
35
41
|
|
@@ -0,0 +1,147 @@
|
|
1
|
+
module Fastlane
|
2
|
+
module Actions
|
3
|
+
class CheckTranslationProgressAction < Action
|
4
|
+
def self.run(params)
|
5
|
+
require_relative '../../helper/glotpress_helper'
|
6
|
+
|
7
|
+
UI.message('Checking translations status...')
|
8
|
+
|
9
|
+
under_threshold_langs = check_translations(
|
10
|
+
glotpress_url: params[:glotpress_url],
|
11
|
+
language_codes: params[:language_codes],
|
12
|
+
abort_on_violations: params[:abort_on_violations],
|
13
|
+
threshold: params[:min_acceptable_translation_percentage]
|
14
|
+
)
|
15
|
+
|
16
|
+
unless under_threshold_langs.empty?
|
17
|
+
check_results(
|
18
|
+
under_threshold_langs: under_threshold_langs,
|
19
|
+
threshold: params[:min_acceptable_translation_percentage],
|
20
|
+
skip_confirm: params[:skip_confirm]
|
21
|
+
)
|
22
|
+
end
|
23
|
+
|
24
|
+
UI.success('Done')
|
25
|
+
end
|
26
|
+
|
27
|
+
# Check the status of the translations and returns the list of violations
|
28
|
+
#
|
29
|
+
# @param [String] URL to the GlotPress project.
|
30
|
+
# @param [String] The list of codes (in GlotPress format) of the languages to check.
|
31
|
+
# @param [Bool] Whether to abort on the first found violation or not.
|
32
|
+
# @param [Integer] The minimum acceptable percentage of translated strings.
|
33
|
+
#
|
34
|
+
# @return [Array] The list of violations (array of hashes of "language code" and "current percentage")
|
35
|
+
#
|
36
|
+
def self.check_translations(glotpress_url:, language_codes:, abort_on_violations:, threshold:)
|
37
|
+
under_threshold_langs = []
|
38
|
+
|
39
|
+
data = begin
|
40
|
+
Fastlane::Helper::GlotPressHelper.get_translation_status_data(glotpress_url: glotpress_url)
|
41
|
+
rescue StandardError
|
42
|
+
nil
|
43
|
+
end
|
44
|
+
UI.abort_with_message!("Can't retrieve data from #{glotpress_url}") if data.nil? || data.empty?
|
45
|
+
|
46
|
+
language_codes.each do |language_code|
|
47
|
+
UI.message("> Getting translation status for #{language_code}")
|
48
|
+
progress = begin
|
49
|
+
Fastlane::Helper::GlotPressHelper.get_translation_status(
|
50
|
+
data: data,
|
51
|
+
language_code: language_code
|
52
|
+
)
|
53
|
+
rescue StandardError
|
54
|
+
-1
|
55
|
+
end
|
56
|
+
|
57
|
+
if abort_on_violations
|
58
|
+
UI.abort_with_message!("Can't get data for language #{language_code}") if progress == -1
|
59
|
+
UI.abort_with_message!("#{language_code} is translated #{progress}% which is under the required #{threshold}%.") if progress < threshold
|
60
|
+
end
|
61
|
+
|
62
|
+
UI.message("Language #{language_code} is #{progress}% translated.")
|
63
|
+
under_threshold_langs.push({ lang: language_code, progress: progress }) if progress < threshold
|
64
|
+
end
|
65
|
+
|
66
|
+
under_threshold_langs
|
67
|
+
end
|
68
|
+
|
69
|
+
# Report the status of the translations and verify whether to abort or not
|
70
|
+
#
|
71
|
+
# @param [Array] The list of violations (array of hashes of "language code" and "current percentage")
|
72
|
+
# @param [Integer] The minimum acceptable percentage of translated strings.
|
73
|
+
# @param [Bool] If true, continue after the report without asking the user.
|
74
|
+
#
|
75
|
+
def self.check_results(under_threshold_langs:, threshold:, skip_confirm:)
|
76
|
+
message = "The translations for the following languages are below the #{threshold}% threshold:\n"
|
77
|
+
|
78
|
+
under_threshold_langs.each do |lang|
|
79
|
+
message << " - #{lang[:lang]} is at #{lang[:progress]}%.\n"
|
80
|
+
end
|
81
|
+
|
82
|
+
if skip_confirm
|
83
|
+
UI.important(message)
|
84
|
+
elsif UI.interactive?
|
85
|
+
UI.abort_with_message!('Aborted by user!') unless UI.confirm("#{message}Do you want to continue?")
|
86
|
+
else
|
87
|
+
UI.abort_with_message!(message)
|
88
|
+
end
|
89
|
+
end
|
90
|
+
|
91
|
+
#####################################################
|
92
|
+
# @!group Documentation
|
93
|
+
#####################################################
|
94
|
+
|
95
|
+
def self.description
|
96
|
+
'Raises an error if the translation percentage is lower than the provided threshold'
|
97
|
+
end
|
98
|
+
|
99
|
+
def self.details
|
100
|
+
'This actions checks the current status of the translations on GlotPress ' \
|
101
|
+
'and raises an error if it\'s below the provided threshold'
|
102
|
+
end
|
103
|
+
|
104
|
+
def self.available_options
|
105
|
+
[
|
106
|
+
FastlaneCore::ConfigItem.new(key: :glotpress_url,
|
107
|
+
env_name: 'FL_CHECK_TRANSLATION_PROGRESS_GLOTPRESS_URL',
|
108
|
+
description: 'URL to the GlotPress project',
|
109
|
+
type: String),
|
110
|
+
FastlaneCore::ConfigItem.new(key: :language_codes,
|
111
|
+
env_name: 'FL_CHECK_TRANSLATION_PROGRESS_LANGUAGE_CODES',
|
112
|
+
description: 'The list of the codes of the languages to check',
|
113
|
+
type: Array,
|
114
|
+
optional: true,
|
115
|
+
# Default to Mag16.
|
116
|
+
default_value: 'ar de es fr he id it ja ko nl pt-br ru sv tr zh-cn zh-tw'.split()),
|
117
|
+
FastlaneCore::ConfigItem.new(key: :min_acceptable_translation_percentage,
|
118
|
+
env_name: 'FL_CHECK_TRANSLATION_PROGRESS_MIN_ACCEPTABLE_TRANSLATION_PERCENTAGE',
|
119
|
+
description: 'The threshold under which an error is raised',
|
120
|
+
type: Integer,
|
121
|
+
optional: true,
|
122
|
+
default_value: 100),
|
123
|
+
FastlaneCore::ConfigItem.new(key: :abort_on_violations,
|
124
|
+
env_name: 'FL_CHECK_TRANSLATION_ABORT_ON_VIOLATIONS',
|
125
|
+
description: 'Should we abort with a global error if any violations are found?',
|
126
|
+
optional: true,
|
127
|
+
default_value: true,
|
128
|
+
is_string: false),
|
129
|
+
FastlaneCore::ConfigItem.new(key: :skip_confirm,
|
130
|
+
env_name: 'FL_CHECK_TRANSLATION_SKIP_CONFIRM',
|
131
|
+
description: 'Move ahead without requesting confirmation if violations are found. Only works if "abort_on_violations" is disabled',
|
132
|
+
optional: true,
|
133
|
+
default_value: false,
|
134
|
+
is_string: false),
|
135
|
+
]
|
136
|
+
end
|
137
|
+
|
138
|
+
def self.authors
|
139
|
+
['loremattei']
|
140
|
+
end
|
141
|
+
|
142
|
+
def self.is_supported?(platform)
|
143
|
+
true
|
144
|
+
end
|
145
|
+
end
|
146
|
+
end
|
147
|
+
end
|
@@ -9,14 +9,18 @@ module Fastlane
|
|
9
9
|
create_config(params[:previous_version], params[:version])
|
10
10
|
show_config()
|
11
11
|
|
12
|
-
|
13
|
-
|
14
|
-
|
12
|
+
update_deliverfile = params[:skip_deliver] == false
|
13
|
+
if update_deliverfile
|
14
|
+
UI.message 'Updating Fastlane deliver file...'
|
15
|
+
Fastlane::Helper::Ios::VersionHelper.update_fastlane_deliver(@new_short_version)
|
16
|
+
UI.message 'Done!'
|
17
|
+
end
|
18
|
+
|
15
19
|
UI.message 'Updating XcConfig...'
|
16
20
|
Fastlane::Helper::Ios::VersionHelper.update_xc_configs(@new_version, @new_short_version, @new_version_internal)
|
17
21
|
UI.message 'Done!'
|
18
22
|
|
19
|
-
Fastlane::Helper::Ios::GitHelper.commit_version_bump(include_deliverfile:
|
23
|
+
Fastlane::Helper::Ios::GitHelper.commit_version_bump(include_deliverfile: update_deliverfile, include_metadata: false)
|
20
24
|
|
21
25
|
UI.message 'Done.'
|
22
26
|
end
|
@@ -34,18 +38,29 @@ module Fastlane
|
|
34
38
|
end
|
35
39
|
|
36
40
|
def self.available_options
|
37
|
-
# Define all options your action supports.
|
38
|
-
|
39
|
-
# Below a few examples
|
40
41
|
[
|
41
|
-
FastlaneCore::ConfigItem.new(
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
42
|
+
FastlaneCore::ConfigItem.new(
|
43
|
+
key: :version,
|
44
|
+
env_name: 'FL_IOS_BUMP_VERSION_HOTFIX_VERSION',
|
45
|
+
description: 'The version of the hotfix',
|
46
|
+
is_string: true
|
47
|
+
),
|
48
|
+
FastlaneCore::ConfigItem.new(
|
49
|
+
key: :previous_version,
|
50
|
+
env_name: 'FL_IOS_BUMP_VERSION_HOTFIX_PREVIOUS_VERSION',
|
51
|
+
description: 'The version to branch from',
|
52
|
+
is_string: true
|
53
|
+
),
|
54
|
+
FastlaneCore::ConfigItem.new(
|
55
|
+
key: :skip_deliver,
|
56
|
+
env_name: 'FL_IOS_BUMP_VERSION_HOTFIX_SKIP_DELIVER',
|
57
|
+
description: 'Skips Deliverfile key update',
|
58
|
+
is_string: false, # Boolean parameter
|
59
|
+
optional: true,
|
60
|
+
# Don't skip the Deliverfile by default. At the time of writing, 2 out of 3 consumers
|
61
|
+
# still have a Deliverfile.
|
62
|
+
default_value: false
|
63
|
+
),
|
49
64
|
]
|
50
65
|
end
|
51
66
|
|
@@ -12,11 +12,20 @@ module Fastlane
|
|
12
12
|
# @env PROJECT_NAME The name of the directory containing the project code (especially containing the `build.gradle` file)
|
13
13
|
#
|
14
14
|
def self.commit_version_bump
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
15
|
+
require_relative './android_version_helper'
|
16
|
+
if Fastlane::Helper::Android::VersionHelper.properties_file_exists
|
17
|
+
Fastlane::Helper::GitHelper.commit(
|
18
|
+
message: 'Bump version number',
|
19
|
+
files: File.join(ENV['PROJECT_ROOT_FOLDER'], 'version.properties'),
|
20
|
+
push: true
|
21
|
+
)
|
22
|
+
else
|
23
|
+
Fastlane::Helper::GitHelper.commit(
|
24
|
+
message: 'Bump version number',
|
25
|
+
files: File.join(ENV['PROJECT_ROOT_FOLDER'], ENV['PROJECT_NAME'], 'build.gradle'),
|
26
|
+
push: true
|
27
|
+
)
|
28
|
+
end
|
20
29
|
end
|
21
30
|
|
22
31
|
# Calls the `tools/update-translations.sh` script from the project repo, then lint them using the provided gradle task
|
@@ -26,26 +26,29 @@ module Fastlane
|
|
26
26
|
# "1.2" # Assuming build.gradle contains versionName "1.2.0"
|
27
27
|
# "1.2.3" # Assuming build.gradle contains versionName "1.2.3"
|
28
28
|
#
|
29
|
+
# @param [String] app The name of the app to be used for beta and alpha version update
|
30
|
+
#
|
29
31
|
# @return [String] The public-facing version number, extracted from the `versionName` of the `build.gradle` file.
|
30
32
|
# - If this version is a hotfix (more than 2 parts and 3rd part is non-zero), returns the "X.Y.Z" formatted string
|
31
33
|
# - Otherwise (not a hotfix / 3rd part of version is 0), returns "X.Y" formatted version number
|
32
34
|
#
|
33
|
-
def self.get_public_version
|
34
|
-
version = get_release_version
|
35
|
+
def self.get_public_version(app)
|
36
|
+
version = get_release_version(product_name: app)
|
35
37
|
vp = get_version_parts(version[VERSION_NAME])
|
36
38
|
return "#{vp[MAJOR_NUMBER]}.#{vp[MINOR_NUMBER]}" unless is_hotfix?(version)
|
37
39
|
|
38
40
|
"#{vp[MAJOR_NUMBER]}.#{vp[MINOR_NUMBER]}.#{vp[HOTFIX_NUMBER]}"
|
39
41
|
end
|
40
42
|
|
41
|
-
# Extract the version name and code from the
|
42
|
-
# or for the defaultConfig if `HAS_ALPHA_VERSION` is not defined.
|
43
|
+
# Extract the version name and code from the release version of the app from `version.properties file`
|
43
44
|
#
|
44
|
-
# @
|
45
|
+
# @param [String] product_name The name of the app to be used for beta and alpha version update
|
45
46
|
#
|
46
47
|
# @return [Hash] A hash with 2 keys "name" and "code" containing the extracted version name and code, respectively
|
47
48
|
#
|
48
|
-
def self.get_release_version
|
49
|
+
def self.get_release_version(product_name:)
|
50
|
+
return get_version_from_properties(product_name: product_name) if properties_file_exists
|
51
|
+
|
49
52
|
section = ENV['HAS_ALPHA_VERSION'].nil? ? 'defaultConfig' : 'vanilla {'
|
50
53
|
gradle_path = self.gradle_path
|
51
54
|
name = get_version_name_from_gradle_file(gradle_path, section)
|
@@ -53,12 +56,67 @@ module Fastlane
|
|
53
56
|
return { VERSION_NAME => name, VERSION_CODE => code }
|
54
57
|
end
|
55
58
|
|
56
|
-
|
59
|
+
def self.properties_file_exists
|
60
|
+
properties_file_path = File.join(ENV['PROJECT_ROOT_FOLDER'] || '.', 'version.properties')
|
61
|
+
|
62
|
+
return File.exist?(properties_file_path)
|
63
|
+
end
|
64
|
+
|
65
|
+
# Extract the version name and code from the `version.properties` file in the project root
|
66
|
+
#
|
67
|
+
# @param [String] product_name The name of the app to extract the version from e.g. wordpress, simplenote
|
68
|
+
# @param [Boolean] is_alpha true if the alpha version should be returned, false otherwise
|
69
|
+
#
|
70
|
+
# @return [Hash] A hash with 2 keys "name" and "code" containing the extracted version name and code, respectively
|
71
|
+
#
|
72
|
+
def self.get_version_from_properties(product_name:, is_alpha: false)
|
73
|
+
alpha_variant = is_alpha ? alpha_flavor_name : nil
|
74
|
+
version_name_key = [product_name, alpha_variant, 'versionName'].compact.join('.')
|
75
|
+
version_code_key = [product_name, alpha_variant, 'versionCode'].compact.join('.')
|
76
|
+
|
77
|
+
properties_file_path = File.join(ENV['PROJECT_ROOT_FOLDER'] || '.', 'version.properties')
|
78
|
+
|
79
|
+
return nil unless File.exist?(properties_file_path)
|
80
|
+
|
81
|
+
File.open(properties_file_path, 'r') do |f|
|
82
|
+
text = f.read
|
83
|
+
name = text.match(/#{version_name_key}=(\S*)/m)&.captures&.first
|
84
|
+
code = text.match(/#{version_code_key}=(\S*)/m)&.captures&.first
|
85
|
+
|
86
|
+
f.close
|
87
|
+
|
88
|
+
return nil if name.nil? || code.nil?
|
89
|
+
|
90
|
+
return { VERSION_NAME => name, VERSION_CODE => code.to_i }
|
91
|
+
end
|
92
|
+
end
|
93
|
+
|
94
|
+
# Returns the name of the flavor used for alpha builds
|
95
|
+
#
|
96
|
+
# @env HAS_ALPHA_VERSION Should contain the name of the flavor used for alpha
|
97
|
+
#
|
98
|
+
# @return [String] The flavor name as provided by the env var, defaulting to `zalpha` if the env var
|
99
|
+
# is not set or is set to '1' ('boolean' value used in legacy call sites)
|
100
|
+
def self.alpha_flavor_name
|
101
|
+
# TODO: Have each fastlane action which depends on this take the alpha flavor name as ConfigItem/parameter
|
102
|
+
# explicitly instead (and get rid of the HAS_ALPHA_VERSION global / env var after that)
|
103
|
+
|
104
|
+
# For now we pass the alpha flavor name by reusing the HAS_ALPHA_VERSION env var.
|
105
|
+
return ENV['HAS_ALPHA_VERSION'] if ENV['HAS_ALPHA_VERSION'] && ENV['HAS_ALPHA_VERSION'] != '1'
|
106
|
+
|
107
|
+
'zalpha' # Default value if HAS_ALPHA_VERSION is not set or hasn't been updated at call site to the flavor name instead of '1'
|
108
|
+
end
|
109
|
+
|
110
|
+
# Extract the version name and code from the `version.properties` file in the project root
|
111
|
+
#
|
112
|
+
# @param [String] app The name of the app to be used for beta and alpha version update
|
57
113
|
#
|
58
114
|
# @return [Hash] A hash with 2 keys `"name"` and `"code"` containing the extracted version name and code, respectively,
|
59
115
|
# or `nil` if `$HAS_ALPHA_VERSION` is not defined.
|
60
116
|
#
|
61
|
-
def self.get_alpha_version
|
117
|
+
def self.get_alpha_version(app)
|
118
|
+
return get_version_from_properties(product_name: app, is_alpha: true) if properties_file_exists
|
119
|
+
|
62
120
|
return nil if ENV['HAS_ALPHA_VERSION'].nil?
|
63
121
|
|
64
122
|
section = 'defaultConfig'
|
@@ -95,8 +153,8 @@ module Fastlane
|
|
95
153
|
# - The final version name corresponds to the beta's versionName, without the `-rc` suffix
|
96
154
|
# - The final version code corresponds to the versionCode for the alpha (or for the beta if alpha_version is nil) incremented by one.
|
97
155
|
#
|
98
|
-
# @param [Hash] beta_version The version hash for the beta
|
99
|
-
# @param [Hash] alpha_version The version hash for the alpha
|
156
|
+
# @param [Hash] beta_version The version hash for the beta, containing values for keys "name" and "code"
|
157
|
+
# @param [Hash] alpha_version The version hash for the alpha, containing values for keys "name" and "code",
|
100
158
|
# or `nil` if no alpha version to consider.
|
101
159
|
#
|
102
160
|
# @return [Hash] A version hash with keys "name" and "code", containing the version name and code to use for final release.
|
@@ -254,11 +312,12 @@ module Fastlane
|
|
254
312
|
|
255
313
|
# Prints the current and next release version names to stdout, then returns the next release version
|
256
314
|
#
|
315
|
+
# @param [String] app The name of the app to be used for beta and alpha version update
|
257
316
|
# @return [String] The next release version name to use after bumping the currently used release version.
|
258
317
|
#
|
259
|
-
def self.bump_version_release
|
318
|
+
def self.bump_version_release(app)
|
260
319
|
# Bump release
|
261
|
-
current_version = get_release_version()
|
320
|
+
current_version = get_release_version(product_name: app)
|
262
321
|
UI.message("Current version: #{current_version[VERSION_NAME]}")
|
263
322
|
new_version = calc_next_release_base_version(current_version)
|
264
323
|
UI.message("New version: #{new_version[VERSION_NAME]}")
|
@@ -267,15 +326,30 @@ module Fastlane
|
|
267
326
|
return verified_version
|
268
327
|
end
|
269
328
|
|
270
|
-
# Update the `
|
329
|
+
# Update the `version.properties` file with new `versionName` and `versionCode` values
|
271
330
|
#
|
272
|
-
# @param [
|
273
|
-
# @param [Hash]
|
274
|
-
# @
|
331
|
+
# @param [String] app The name of the app to be used for beta and alpha version update
|
332
|
+
# @param [Hash] new_version_beta The version hash for the beta, containing values for keys "name" and "code"
|
333
|
+
# @param [Hash] new_version_alpha The version hash for the alpha , containing values for keys "name" and "code"
|
275
334
|
#
|
276
|
-
def self.update_versions(new_version_beta, new_version_alpha)
|
277
|
-
|
278
|
-
|
335
|
+
def self.update_versions(app, new_version_beta, new_version_alpha)
|
336
|
+
if properties_file_exists
|
337
|
+
new_version_name_beta_key = "#{app}.versionName"
|
338
|
+
new_version_code_beta_key = "#{app}.versionCode"
|
339
|
+
Action.sh('./gradlew', 'updateVersionProperties', "-Pkey=#{new_version_name_beta_key}", "-Pvalue=#{new_version_beta[VERSION_NAME]}")
|
340
|
+
Action.sh('./gradlew', 'updateVersionProperties', "-Pkey=#{new_version_code_beta_key}", "-Pvalue=#{new_version_beta[VERSION_CODE]}")
|
341
|
+
|
342
|
+
unless new_version_alpha.nil?
|
343
|
+
new_version_name_alpha_key = "#{app}.#{alpha_flavor_name}.versionName"
|
344
|
+
new_version_code_alpha_key = "#{app}.#{alpha_flavor_name}.versionCode"
|
345
|
+
|
346
|
+
Action.sh('./gradlew', 'updateVersionProperties', "-Pkey=#{new_version_name_alpha_key}", "-Pvalue=#{new_version_alpha[VERSION_NAME]}") unless new_version_alpha.nil?
|
347
|
+
Action.sh('./gradlew', 'updateVersionProperties', "-Pkey=#{new_version_code_alpha_key}", "-Pvalue=#{new_version_alpha[VERSION_CODE]}") unless new_version_alpha.nil?
|
348
|
+
end
|
349
|
+
else
|
350
|
+
self.update_version(new_version_beta, ENV['HAS_ALPHA_VERSION'].nil? ? 'defaultConfig' : 'vanilla {')
|
351
|
+
self.update_version(new_version_alpha, 'defaultConfig') unless new_version_alpha.nil?
|
352
|
+
end
|
279
353
|
end
|
280
354
|
|
281
355
|
# Compute the name of the previous hotfix version.
|
@@ -337,6 +411,37 @@ module Fastlane
|
|
337
411
|
return parts
|
338
412
|
end
|
339
413
|
|
414
|
+
# Ensure that a version string is correctly formatted (that is, each of its parts is a number) and returns the 2-parts version number
|
415
|
+
#
|
416
|
+
# @param [String] version The version string to verify
|
417
|
+
#
|
418
|
+
# @return [String] The "major.minor" version string, only with the first 2 components
|
419
|
+
# @raise [UserError] If any of the parts of the version string is not a number
|
420
|
+
#
|
421
|
+
def self.verify_version(version)
|
422
|
+
v_parts = get_version_parts(version)
|
423
|
+
|
424
|
+
v_parts.each do |part|
|
425
|
+
UI.user_error!('Version value can only contains numbers.') unless is_int?(part)
|
426
|
+
end
|
427
|
+
|
428
|
+
"#{v_parts[MAJOR_NUMBER]}.#{v_parts[MINOR_NUMBER]}"
|
429
|
+
end
|
430
|
+
|
431
|
+
# Check if a string is an integer.
|
432
|
+
#
|
433
|
+
# @param [String] string The string to test
|
434
|
+
#
|
435
|
+
# @return [Bool] true if the string is representing an integer value, false if not
|
436
|
+
#
|
437
|
+
def self.is_int? string
|
438
|
+
true if Integer(string) rescue false
|
439
|
+
end
|
440
|
+
|
441
|
+
#########
|
442
|
+
# Functions to support versioning through build.gradle - can be removed once all projects adopt version.properties
|
443
|
+
########
|
444
|
+
|
340
445
|
# Extract the versionName from a build.gradle file
|
341
446
|
#
|
342
447
|
# @param [String] file_path The path to the `.gradle` file
|
@@ -387,33 +492,6 @@ module Fastlane
|
|
387
492
|
return nil
|
388
493
|
end
|
389
494
|
|
390
|
-
# Ensure that a version string is correctly formatted (that is, each of its parts is a number) and returns the 2-parts version number
|
391
|
-
#
|
392
|
-
# @param [String] version The version string to verify
|
393
|
-
#
|
394
|
-
# @return [String] The "major.minor" version string, only with the first 2 components
|
395
|
-
# @raise [UserError] If any of the parts of the version string is not a number
|
396
|
-
#
|
397
|
-
def self.verify_version(version)
|
398
|
-
v_parts = get_version_parts(version)
|
399
|
-
|
400
|
-
v_parts.each do |part|
|
401
|
-
UI.user_error!('Version value can only contains numbers.') unless is_int?(part)
|
402
|
-
end
|
403
|
-
|
404
|
-
"#{v_parts[MAJOR_NUMBER]}.#{v_parts[MINOR_NUMBER]}"
|
405
|
-
end
|
406
|
-
|
407
|
-
# Check if a string is an integer.
|
408
|
-
#
|
409
|
-
# @param [String] string The string to test
|
410
|
-
#
|
411
|
-
# @return [Bool] true if the string is representing an integer value, false if not
|
412
|
-
#
|
413
|
-
def self.is_int? string
|
414
|
-
true if Integer(string) rescue false
|
415
|
-
end
|
416
|
-
|
417
495
|
# The path to the build.gradle file for the project.
|
418
496
|
#
|
419
497
|
# @env PROJECT_ROOT_FOLDER The path to the root of the project (the folder containing the `.git` directory).
|