fastlane 2.157.0 → 2.158.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +72 -72
- data/deliver/lib/deliver/app_screenshot_iterator.rb +1 -1
- data/deliver/lib/deliver/runner.rb +5 -3
- data/fastlane/lib/fastlane/actions/.hockey.rb.swp +0 -0
- data/fastlane/lib/fastlane/actions/{.git_commit.rb.swp → .slack.rb.swp} +0 -0
- data/fastlane/lib/fastlane/actions/.update_project_provisioning.rb.swp +0 -0
- data/fastlane/lib/fastlane/actions/app_store_build_number.rb +12 -8
- data/fastlane/lib/fastlane/actions/download_dsyms.rb +89 -68
- data/fastlane/lib/fastlane/actions/set_changelog.rb +3 -2
- data/fastlane/lib/fastlane/version.rb +1 -1
- data/fastlane/swift/Deliverfile.swift +1 -1
- data/fastlane/swift/DeliverfileProtocol.swift +1 -1
- data/fastlane/swift/Fastlane.swift +18 -12
- data/fastlane/swift/FastlaneSwiftRunner/FastlaneSwiftRunner.xcodeproj/project.xcworkspace/xcuserdata/josh.xcuserdatad/UserInterfaceState.xcuserstate +0 -0
- data/fastlane/swift/Gymfile.swift +1 -1
- data/fastlane/swift/GymfileProtocol.swift +1 -1
- data/fastlane/swift/Matchfile.swift +1 -1
- data/fastlane/swift/MatchfileProtocol.swift +1 -1
- data/fastlane/swift/Precheckfile.swift +1 -1
- data/fastlane/swift/PrecheckfileProtocol.swift +5 -1
- data/fastlane/swift/Scanfile.swift +1 -1
- data/fastlane/swift/ScanfileProtocol.swift +1 -1
- data/fastlane/swift/Screengrabfile.swift +1 -1
- data/fastlane/swift/ScreengrabfileProtocol.swift +1 -1
- data/fastlane/swift/Snapshotfile.swift +1 -1
- data/fastlane/swift/SnapshotfileProtocol.swift +1 -1
- data/fastlane_core/lib/fastlane_core/command_executor.rb +1 -0
- data/match/lib/match/spaceship_ensure.rb +5 -5
- data/{fastlane/lib/fastlane/.erb_template_helper.rb.swp → pilot/lib/pilot/.manager.rb.swp} +0 -0
- data/pilot/lib/pilot/build_manager.rb +0 -3
- data/pilot/lib/pilot/manager.rb +1 -1
- data/precheck/lib/precheck/options.rb +9 -0
- data/precheck/lib/precheck/rule_processor.rb +94 -60
- data/precheck/lib/precheck/runner.rb +6 -4
- data/produce/lib/produce/itunes_connect.rb +3 -2
- data/screengrab/lib/screengrab/runner.rb +28 -10
- data/sigh/lib/assets/resign.sh +9 -6
- data/sigh/lib/sigh/runner.rb +3 -2
- data/spaceship/lib/spaceship/client.rb +1 -0
- data/spaceship/lib/spaceship/connect_api.rb +1 -0
- data/spaceship/lib/spaceship/{.DS_Store → connect_api/.DS_Store} +0 -0
- data/spaceship/lib/spaceship/connect_api/client.rb +32 -13
- data/spaceship/lib/spaceship/connect_api/file_uploader.rb +2 -0
- data/spaceship/lib/spaceship/connect_api/models/app.rb +5 -5
- data/spaceship/lib/spaceship/connect_api/models/app_price_point.rb +26 -0
- data/spaceship/lib/spaceship/connect_api/models/app_store_version.rb +7 -1
- data/spaceship/lib/spaceship/connect_api/models/app_store_version_phased_release.rb +21 -0
- data/spaceship/lib/spaceship/connect_api/spaceship.rb +10 -6
- data/spaceship/lib/spaceship/connect_api/testflight/testflight.rb +50 -50
- data/spaceship/lib/spaceship/connect_api/tunes/tunes.rb +20 -0
- metadata +25 -21
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 788ea487bca43498edde1360e40fe59761bc470b5028f3b7f6bcccf25f8348a9
|
4
|
+
data.tar.gz: 7333608271e41308100b68c9c56d572751b07feeed59d45ee72f0e972eff296d
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 3d173dc0f428264f2eaba63baf543e849525871cf7981f769fa72aa1ee8896b0b042b262ef0a0d3687423892ae9d2cfd5e28487100a887d78b703af83f847de2
|
7
|
+
data.tar.gz: ecfee323ba2035466bbb7efa6fd34a3af1339046ddc93f13de6a88dae9d65b4a65960bed69baa08b738e193cd050e66363699e682f051e0e4e5b5ab38a176007
|
data/README.md
CHANGED
@@ -34,29 +34,49 @@ If the above doesn't help, please [submit an issue](https://github.com/fastlane/
|
|
34
34
|
<!-- This table is regenerated and resorted on each release -->
|
35
35
|
<table id='team'>
|
36
36
|
<tr>
|
37
|
+
<td id='felix-krause'>
|
38
|
+
<a href='https://github.com/KrauseFx'>
|
39
|
+
<img src='https://github.com/KrauseFx.png?size=140'>
|
40
|
+
</a>
|
41
|
+
<h4 align='center'><a href='https://twitter.com/KrauseFx'>Felix Krause</a></h4>
|
42
|
+
</td>
|
37
43
|
<td id='olivier-halligon'>
|
38
44
|
<a href='https://github.com/AliSoftware'>
|
39
45
|
<img src='https://github.com/AliSoftware.png?size=140'>
|
40
46
|
</a>
|
41
47
|
<h4 align='center'><a href='https://twitter.com/aligatr'>Olivier Halligon</a></h4>
|
42
48
|
</td>
|
43
|
-
<td id='
|
44
|
-
<a href='https://github.com/
|
45
|
-
<img src='https://github.com/
|
49
|
+
<td id='danielle-tomlinson'>
|
50
|
+
<a href='https://github.com/endocrimes'>
|
51
|
+
<img src='https://github.com/endocrimes.png?size=140'>
|
46
52
|
</a>
|
47
|
-
<h4 align='center'><a href='https://twitter.com/
|
53
|
+
<h4 align='center'><a href='https://twitter.com/endocrimes'>Danielle Tomlinson</a></h4>
|
48
54
|
</td>
|
49
|
-
<td id='
|
50
|
-
<a href='https://github.com/
|
51
|
-
<img src='https://github.com/
|
55
|
+
<td id='luka-mirosevic'>
|
56
|
+
<a href='https://github.com/lmirosevic'>
|
57
|
+
<img src='https://github.com/lmirosevic.png?size=140'>
|
52
58
|
</a>
|
53
|
-
<h4 align='center'><a href='https://twitter.com/
|
59
|
+
<h4 align='center'><a href='https://twitter.com/lmirosevic'>Luka Mirosevic</a></h4>
|
54
60
|
</td>
|
55
|
-
<td id='
|
56
|
-
<a href='https://github.com/
|
57
|
-
<img src='https://github.com/
|
61
|
+
<td id='kohki-miki'>
|
62
|
+
<a href='https://github.com/giginet'>
|
63
|
+
<img src='https://github.com/giginet.png?size=140'>
|
58
64
|
</a>
|
59
|
-
<h4 align='center'><a href='https://twitter.com/
|
65
|
+
<h4 align='center'><a href='https://twitter.com/giginet'>Kohki Miki</a></h4>
|
66
|
+
</td>
|
67
|
+
</tr>
|
68
|
+
<tr>
|
69
|
+
<td id='aaron-brager'>
|
70
|
+
<a href='https://github.com/getaaron'>
|
71
|
+
<img src='https://github.com/getaaron.png?size=140'>
|
72
|
+
</a>
|
73
|
+
<h4 align='center'><a href='https://twitter.com/getaaron'>Aaron Brager</a></h4>
|
74
|
+
</td>
|
75
|
+
<td id='andrew-mcburney'>
|
76
|
+
<a href='https://github.com/armcburney'>
|
77
|
+
<img src='https://github.com/armcburney.png?size=140'>
|
78
|
+
</a>
|
79
|
+
<h4 align='center'><a href='https://twitter.com/armcburney'>Andrew McBurney</a></h4>
|
60
80
|
</td>
|
61
81
|
<td id='jorge-revuelta-h'>
|
62
82
|
<a href='https://github.com/minuscorp'>
|
@@ -64,89 +84,75 @@ If the above doesn't help, please [submit an issue](https://github.com/fastlane/
|
|
64
84
|
</a>
|
65
85
|
<h4 align='center'><a href='https://twitter.com/minuscorp'>Jorge Revuelta H</a></h4>
|
66
86
|
</td>
|
67
|
-
</tr>
|
68
|
-
<tr>
|
69
87
|
<td id='joshua-liebowitz'>
|
70
88
|
<a href='https://github.com/taquitos'>
|
71
89
|
<img src='https://github.com/taquitos.png?size=140'>
|
72
90
|
</a>
|
73
91
|
<h4 align='center'><a href='https://twitter.com/taquitos'>Joshua Liebowitz</a></h4>
|
74
92
|
</td>
|
75
|
-
<td id='manu-wallner'>
|
76
|
-
<a href='https://github.com/milch'>
|
77
|
-
<img src='https://github.com/milch.png?size=140'>
|
78
|
-
</a>
|
79
|
-
<h4 align='center'><a href='https://twitter.com/acrooow'>Manu Wallner</a></h4>
|
80
|
-
</td>
|
81
|
-
<td id='daniel-jankowski'>
|
82
|
-
<a href='https://github.com/mollyIV'>
|
83
|
-
<img src='https://github.com/mollyIV.png?size=140'>
|
84
|
-
</a>
|
85
|
-
<h4 align='center'><a href='https://twitter.com/mollyIV'>Daniel Jankowski</a></h4>
|
86
|
-
</td>
|
87
93
|
<td id='jimmy-dee'>
|
88
94
|
<a href='https://github.com/jdee'>
|
89
95
|
<img src='https://github.com/jdee.png?size=140'>
|
90
96
|
</a>
|
91
97
|
<h4 align='center'>Jimmy Dee</h4>
|
92
98
|
</td>
|
93
|
-
<td id='maksym-grebenets'>
|
94
|
-
<a href='https://github.com/mgrebenets'>
|
95
|
-
<img src='https://github.com/mgrebenets.png?size=140'>
|
96
|
-
</a>
|
97
|
-
<h4 align='center'><a href='https://twitter.com/mgrebenets'>Maksym Grebenets</a></h4>
|
98
|
-
</td>
|
99
99
|
</tr>
|
100
100
|
<tr>
|
101
|
-
<td id='
|
102
|
-
<a href='https://github.com/
|
103
|
-
<img src='https://github.com/
|
101
|
+
<td id='stefan-natchev'>
|
102
|
+
<a href='https://github.com/snatchev'>
|
103
|
+
<img src='https://github.com/snatchev.png?size=140'>
|
104
104
|
</a>
|
105
|
-
<h4 align='center'><a href='https://twitter.com/
|
105
|
+
<h4 align='center'><a href='https://twitter.com/snatchev'>Stefan Natchev</a></h4>
|
106
106
|
</td>
|
107
|
-
<td id='
|
108
|
-
<a href='https://github.com/
|
109
|
-
<img src='https://github.com/
|
107
|
+
<td id='jan-piotrowski'>
|
108
|
+
<a href='https://github.com/janpio'>
|
109
|
+
<img src='https://github.com/janpio.png?size=140'>
|
110
110
|
</a>
|
111
|
-
<h4 align='center'><a href='https://twitter.com/
|
111
|
+
<h4 align='center'><a href='https://twitter.com/Sujan'>Jan Piotrowski</a></h4>
|
112
112
|
</td>
|
113
|
-
<td id='
|
114
|
-
<a href='https://github.com/
|
115
|
-
<img src='https://github.com/
|
113
|
+
<td id='maksym-grebenets'>
|
114
|
+
<a href='https://github.com/mgrebenets'>
|
115
|
+
<img src='https://github.com/mgrebenets.png?size=140'>
|
116
116
|
</a>
|
117
|
-
<h4 align='center'><a href='https://twitter.com/
|
117
|
+
<h4 align='center'><a href='https://twitter.com/mgrebenets'>Maksym Grebenets</a></h4>
|
118
118
|
</td>
|
119
|
-
<td id='
|
120
|
-
<a href='https://github.com/
|
121
|
-
<img src='https://github.com/
|
119
|
+
<td id='max-ott'>
|
120
|
+
<a href='https://github.com/max-ott'>
|
121
|
+
<img src='https://github.com/max-ott.png?size=140'>
|
122
122
|
</a>
|
123
|
-
<h4 align='center'><a href='https://twitter.com/
|
123
|
+
<h4 align='center'><a href='https://twitter.com/ott_max'>Max Ott</a></h4>
|
124
124
|
</td>
|
125
|
-
<td id='
|
126
|
-
<a href='https://github.com/
|
127
|
-
<img src='https://github.com/
|
125
|
+
<td id='jérôme-lacoste'>
|
126
|
+
<a href='https://github.com/lacostej'>
|
127
|
+
<img src='https://github.com/lacostej.png?size=140'>
|
128
128
|
</a>
|
129
|
-
<h4 align='center'><a href='https://twitter.com/
|
129
|
+
<h4 align='center'><a href='https://twitter.com/lacostej'>Jérôme Lacoste</a></h4>
|
130
130
|
</td>
|
131
131
|
</tr>
|
132
132
|
<tr>
|
133
|
-
<td id='danielle-tomlinson'>
|
134
|
-
<a href='https://github.com/endocrimes'>
|
135
|
-
<img src='https://github.com/endocrimes.png?size=140'>
|
136
|
-
</a>
|
137
|
-
<h4 align='center'><a href='https://twitter.com/endocrimes'>Danielle Tomlinson</a></h4>
|
138
|
-
</td>
|
139
133
|
<td id='matthew-ellis'>
|
140
134
|
<a href='https://github.com/matthewellis'>
|
141
135
|
<img src='https://github.com/matthewellis.png?size=140'>
|
142
136
|
</a>
|
143
137
|
<h4 align='center'><a href='https://twitter.com/mellis1995'>Matthew Ellis</a></h4>
|
144
138
|
</td>
|
145
|
-
<td id='
|
146
|
-
<a href='https://github.com/
|
147
|
-
<img src='https://github.com/
|
139
|
+
<td id='fumiya-nakamura'>
|
140
|
+
<a href='https://github.com/nafu'>
|
141
|
+
<img src='https://github.com/nafu.png?size=140'>
|
148
142
|
</a>
|
149
|
-
<h4 align='center'><a href='https://twitter.com/
|
143
|
+
<h4 align='center'><a href='https://twitter.com/nafu003'>Fumiya Nakamura</a></h4>
|
144
|
+
</td>
|
145
|
+
<td id='daniel-jankowski'>
|
146
|
+
<a href='https://github.com/mollyIV'>
|
147
|
+
<img src='https://github.com/mollyIV.png?size=140'>
|
148
|
+
</a>
|
149
|
+
<h4 align='center'><a href='https://twitter.com/mollyIV'>Daniel Jankowski</a></h4>
|
150
|
+
</td>
|
151
|
+
<td id='manu-wallner'>
|
152
|
+
<a href='https://github.com/milch'>
|
153
|
+
<img src='https://github.com/milch.png?size=140'>
|
154
|
+
</a>
|
155
|
+
<h4 align='center'><a href='https://twitter.com/acrooow'>Manu Wallner</a></h4>
|
150
156
|
</td>
|
151
157
|
<td id='helmut-januschka'>
|
152
158
|
<a href='https://github.com/hjanuschka'>
|
@@ -154,12 +160,6 @@ If the above doesn't help, please [submit an issue](https://github.com/fastlane/
|
|
154
160
|
</a>
|
155
161
|
<h4 align='center'><a href='https://twitter.com/hjanuschka'>Helmut Januschka</a></h4>
|
156
162
|
</td>
|
157
|
-
<td id='felix-krause'>
|
158
|
-
<a href='https://github.com/KrauseFx'>
|
159
|
-
<img src='https://github.com/KrauseFx.png?size=140'>
|
160
|
-
</a>
|
161
|
-
<h4 align='center'><a href='https://twitter.com/KrauseFx'>Felix Krause</a></h4>
|
162
|
-
</td>
|
163
163
|
</tr>
|
164
164
|
<tr>
|
165
165
|
<td id='iulian-onofrei'>
|
@@ -168,11 +168,11 @@ If the above doesn't help, please [submit an issue](https://github.com/fastlane/
|
|
168
168
|
</a>
|
169
169
|
<h4 align='center'><a href='https://twitter.com/Revolt666'>Iulian Onofrei</a></h4>
|
170
170
|
</td>
|
171
|
-
<td id='
|
172
|
-
<a href='https://github.com/
|
173
|
-
<img src='https://github.com/
|
171
|
+
<td id='josh-holtz'>
|
172
|
+
<a href='https://github.com/joshdholtz'>
|
173
|
+
<img src='https://github.com/joshdholtz.png?size=140'>
|
174
174
|
</a>
|
175
|
-
<h4 align='center'><a href='https://twitter.com/
|
175
|
+
<h4 align='center'><a href='https://twitter.com/joshdholtz'>Josh Holtz</a></h4>
|
176
176
|
</td>
|
177
177
|
</table>
|
178
178
|
|
@@ -81,7 +81,7 @@ module Deliver
|
|
81
81
|
|
82
82
|
screenshots_per_display_type.each do |display_type, screenshots|
|
83
83
|
# create AppScreenshotSet for given display_type if it doesn't exsit
|
84
|
-
app_screenshot_set = app_screenshot_set_per_locale_and_display_type[language][display_type]
|
84
|
+
app_screenshot_set = (app_screenshot_set_per_locale_and_display_type[language] || {})[display_type]
|
85
85
|
app_screenshot_set ||= localization.create_app_screenshot_set(attributes: { screenshotDisplayType: display_type })
|
86
86
|
|
87
87
|
# iterate over screenshots per display size with index
|
@@ -26,9 +26,10 @@ module Deliver
|
|
26
26
|
end
|
27
27
|
|
28
28
|
def login
|
29
|
+
# Team selection passed though FASTLANE_TEAM_ID and FASTLANE_TEAM_NAME environment variables
|
30
|
+
# Prompts select team if multiple teams and none specified
|
29
31
|
UI.message("Login to App Store Connect (#{options[:username]})")
|
30
|
-
Spaceship::ConnectAPI.login(options[:username])
|
31
|
-
Spaceship::ConnectAPI.select_team
|
32
|
+
Spaceship::ConnectAPI.login(options[:username], nil, use_portal: false, use_tunes: true)
|
32
33
|
UI.message("Login successful")
|
33
34
|
end
|
34
35
|
|
@@ -67,7 +68,8 @@ module Deliver
|
|
67
68
|
default_rule_level: options[:precheck_default_rule_level],
|
68
69
|
include_in_app_purchases: options[:precheck_include_in_app_purchases],
|
69
70
|
app_identifier: options[:app_identifier],
|
70
|
-
username: options[:username]
|
71
|
+
username: options[:username],
|
72
|
+
platform: options[:platform]
|
71
73
|
}
|
72
74
|
|
73
75
|
precheck_config = FastlaneCore::Configuration.create(Precheck::Options.available_options, precheck_options)
|
Binary file
|
Binary file
|
Binary file
|
@@ -26,27 +26,31 @@ module Fastlane
|
|
26
26
|
end
|
27
27
|
|
28
28
|
def self.get_build_number(params)
|
29
|
+
# Prompts select team if multiple teams and none specified
|
29
30
|
UI.message("Login to App Store Connect (#{params[:username]})")
|
30
|
-
Spaceship::
|
31
|
-
Spaceship::Tunes.select_team(team_id: params[:team_id], team_name: params[:team_name])
|
31
|
+
Spaceship::ConnectAPI.login(params[:username], use_portal: false, use_tunes: true, tunes_team_id: params[:team_id], team_name: params[:team_name])
|
32
32
|
UI.message("Login successful")
|
33
33
|
|
34
|
-
|
34
|
+
platform = Spaceship::ConnectAPI::Platform.map(params[:platform])
|
35
|
+
|
36
|
+
app = Spaceship::ConnectAPI::App.find(params[:app_identifier])
|
35
37
|
UI.user_error!("Could not find an app on App Store Connect with app_identifier: #{params[:app_identifier]}") unless app
|
36
38
|
if params[:live]
|
37
39
|
UI.message("Fetching the latest build number for live-version")
|
38
|
-
|
39
|
-
|
40
|
+
live_version = app.get_live_app_store_version(platform: platform)
|
41
|
+
|
42
|
+
UI.user_error!("Could not find a live-version of #{params[:app_identifier]} on App Store Connect") unless live_version
|
43
|
+
build_nr = live_version.build.version
|
40
44
|
|
41
|
-
UI.message("Latest upload for live-version #{
|
45
|
+
UI.message("Latest upload for live-version #{live_version.version_string} is build: #{build_nr}")
|
42
46
|
|
43
|
-
return OpenStruct.new({ build_nr: build_nr, build_v:
|
47
|
+
return OpenStruct.new({ build_nr: build_nr, build_v: live_version.version_string })
|
44
48
|
else
|
45
49
|
version_number = params[:version]
|
46
50
|
platform = params[:platform]
|
47
51
|
|
48
52
|
# Create filter for get_builds with optional version number
|
49
|
-
filter = { app: app.
|
53
|
+
filter = { app: app.id }
|
50
54
|
if version_number
|
51
55
|
filter["preReleaseVersion.version"] = version_number
|
52
56
|
version_number_message = "version #{version_number}"
|
@@ -6,16 +6,18 @@ module Fastlane
|
|
6
6
|
class DownloadDsymsAction < Action
|
7
7
|
# rubocop:disable Metrics/PerceivedComplexity
|
8
8
|
def self.run(params)
|
9
|
+
require 'openssl'
|
9
10
|
require 'spaceship'
|
10
11
|
require 'net/http'
|
11
12
|
|
13
|
+
# Team selection passed though FASTLANE_ITC_TEAM_ID and FASTLANE_ITC_TEAM_NAME environment variables
|
14
|
+
# Prompts select team if multiple teams and none specified
|
12
15
|
UI.message("Login to App Store Connect (#{params[:username]})")
|
13
|
-
Spaceship::
|
14
|
-
Spaceship::Tunes.select_team
|
16
|
+
Spaceship::ConnectAPI.login(params[:username], use_portal: false, use_tunes: true)
|
15
17
|
UI.message("Login successful")
|
16
18
|
|
17
19
|
# Get App
|
18
|
-
app = Spaceship::
|
20
|
+
app = Spaceship::ConnectAPI::App.find(params[:app_identifier])
|
19
21
|
unless app
|
20
22
|
UI.user_error!("Could not find app with bundle identifier '#{params[:app_identifier]}' on account #{params[:username]}")
|
21
23
|
end
|
@@ -23,38 +25,35 @@ module Fastlane
|
|
23
25
|
# Process options
|
24
26
|
version = params[:version]
|
25
27
|
build_number = params[:build_number].to_s unless params[:build_number].nil?
|
26
|
-
|
28
|
+
itc_platform = params[:platform]
|
27
29
|
output_directory = params[:output_directory]
|
28
30
|
wait_for_dsym_processing = params[:wait_for_dsym_processing]
|
29
31
|
wait_timeout = params[:wait_timeout]
|
30
32
|
min_version = Gem::Version.new(params[:min_version]) if params[:min_version]
|
31
33
|
|
34
|
+
platform = Spaceship::ConnectAPI::Platform.map(itc_platform)
|
35
|
+
|
32
36
|
# Set version if it is latest
|
33
37
|
if version == 'latest'
|
34
38
|
# Try to grab the edit version first, else fallback to live version
|
35
39
|
UI.message("Looking for latest version...")
|
36
|
-
latest_version = app.
|
37
|
-
|
38
|
-
UI.user_error!("Could not find latest version for your app, please try setting a specific version") if latest_version.
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
else
|
45
|
-
# The build_version of a candidate build does not always match the one in latest_version so get the version and build number from the same place.
|
46
|
-
version = latest_candidate_build.train_version
|
47
|
-
build_number = latest_candidate_build.build_version
|
48
|
-
end
|
40
|
+
latest_version = app.get_edit_app_store_version(platform: platform) || app.get_live_app_store_version(platform: platform)
|
41
|
+
|
42
|
+
UI.user_error!("Could not find latest version for your app, please try setting a specific version") if latest_version.nil?
|
43
|
+
|
44
|
+
latest_build = get_latest_build!(app_id: app.id, version: latest_version.version_string, platform: platform)
|
45
|
+
|
46
|
+
version = latest_build.app_version
|
47
|
+
build_number = latest_build.version
|
49
48
|
elsif version == 'live'
|
50
49
|
UI.message("Looking for live version...")
|
51
|
-
live_version = app.
|
50
|
+
live_version = app.get_live_app_store_version(platform: platform)
|
52
51
|
|
53
52
|
UI.user_error!("Could not find live version for your app, please try setting 'latest' or a specific version") if live_version.nil?
|
54
53
|
|
55
54
|
# No need to search for candidates, because released App Store version should only have one build
|
56
|
-
version = live_version.
|
57
|
-
build_number = live_version.
|
55
|
+
version = live_version.version_string
|
56
|
+
build_number = live_version.build.version
|
58
57
|
end
|
59
58
|
|
60
59
|
# Remove leading zeros from version string (eg. 1.02 -> 1.2)
|
@@ -74,76 +73,98 @@ module Fastlane
|
|
74
73
|
message << "(#{build_number})" if build_number
|
75
74
|
UI.message(message.join(" "))
|
76
75
|
|
77
|
-
app
|
76
|
+
filter = { app: app.id }
|
77
|
+
filter["preReleaseVersion.platform"] = platform
|
78
|
+
build_resps = Spaceship::ConnectAPI.get_builds(filter: filter, sort: "-uploadedDate", includes: "preReleaseVersion").all_pages
|
79
|
+
builds = build_resps.flat_map(&:to_models)
|
80
|
+
|
81
|
+
builds.each do |build|
|
82
|
+
asc_app_version = build.app_version
|
83
|
+
asc_build_number = build.version
|
84
|
+
|
78
85
|
message = []
|
79
|
-
message << "Found train (version): #{
|
86
|
+
message << "Found train (version): #{asc_app_version}"
|
80
87
|
message << ", comparing to supplied version: #{version}" if version
|
81
88
|
UI.verbose(message.join(" "))
|
82
89
|
|
83
|
-
if version && version !=
|
84
|
-
UI.verbose("Version #{version} doesn't match: #{
|
90
|
+
if version && version != asc_app_version
|
91
|
+
UI.verbose("Version #{version} doesn't match: #{asc_app_version}")
|
85
92
|
next
|
86
93
|
end
|
87
94
|
|
88
|
-
if min_version && min_version > Gem::Version.new(
|
89
|
-
UI.verbose("Min version #{min_version} not reached: #{
|
95
|
+
if min_version && min_version > Gem::Version.new(asc_app_version)
|
96
|
+
UI.verbose("Min version #{min_version} not reached: #{asc_app_version}")
|
90
97
|
next
|
91
98
|
end
|
92
99
|
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
UI.verbose(message.join(" "))
|
100
|
+
message = []
|
101
|
+
message << "Found build version: #{asc_build_number}"
|
102
|
+
message << ", comparing to supplied build_number: #{build_number}" if build_number
|
103
|
+
UI.verbose(message.join(" "))
|
98
104
|
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
105
|
+
if build_number && asc_build_number != build_number
|
106
|
+
UI.verbose("build_version: #{asc_build_number} doesn't match: #{build_number}")
|
107
|
+
next
|
108
|
+
end
|
103
109
|
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
if !wait_for_dsym_processing || (Time.now - start) > wait_timeout
|
120
|
-
# In some cases, AppStoreConnect does not process the dSYMs, thus no error should be thrown.
|
121
|
-
UI.message("Could not find any dSYM for #{build.build_version} (#{train.version_string})")
|
122
|
-
else
|
123
|
-
UI.message("Waiting for dSYM file to appear...")
|
124
|
-
sleep(30)
|
125
|
-
next
|
126
|
-
end
|
127
|
-
end
|
128
|
-
|
129
|
-
break
|
130
|
-
end
|
110
|
+
UI.verbose("Build_version: #{asc_build_number} matches #{build_number}, grabbing dsym_url") if build_number
|
111
|
+
get_details_and_download_dsym(app: app, train: asc_app_version, build_number: asc_build_number, platform: itc_platform, wait_for_dsym_processing: wait_for_dsym_processing, wait_timeout: wait_timeout, output_directory: output_directory)
|
112
|
+
end
|
113
|
+
end
|
114
|
+
|
115
|
+
def self.get_details_and_download_dsym(app: nil, train: nil, build_number: nil, platform: nil, wait_for_dsym_processing: nil, wait_timeout: nil, output_directory: nil)
|
116
|
+
start = Time.now
|
117
|
+
download_url = nil
|
118
|
+
|
119
|
+
loop do
|
120
|
+
begin
|
121
|
+
resp = Spaceship::Tunes.client.build_details(app_id: app.id, train: train, build_number: build_number, platform: platform)
|
122
|
+
|
123
|
+
resp['apple_id'] = app.id
|
124
|
+
build_details = Spaceship::Tunes::BuildDetails.factory(resp)
|
131
125
|
|
132
|
-
|
133
|
-
|
134
|
-
|
126
|
+
download_url = build_details.dsym_url
|
127
|
+
UI.verbose("dsym_url: #{download_url}")
|
128
|
+
rescue Spaceship::TunesClient::ITunesConnectError => ex
|
129
|
+
UI.error("Error accessing dSYM file for build\n\n#{build}\n\nException: #{ex}")
|
130
|
+
end
|
131
|
+
|
132
|
+
unless download_url
|
133
|
+
if !wait_for_dsym_processing || (Time.now - start) > wait_timeout
|
134
|
+
# In some cases, AppStoreConnect does not process the dSYMs, thus no error should be thrown.
|
135
|
+
UI.message("Could not find any dSYM for #{build_number} (#{train})")
|
135
136
|
else
|
136
|
-
UI.message("
|
137
|
+
UI.message("Waiting for dSYM file to appear...")
|
138
|
+
sleep(30)
|
139
|
+
next
|
137
140
|
end
|
138
141
|
end
|
142
|
+
|
143
|
+
break
|
139
144
|
end
|
140
145
|
|
141
|
-
if
|
142
|
-
|
146
|
+
if download_url
|
147
|
+
self.download(download_url, app.bundle_id, train, build_number, output_directory)
|
148
|
+
return if build_number
|
149
|
+
else
|
150
|
+
UI.message("No dSYM URL for #{build_number} (#{train})")
|
143
151
|
end
|
144
152
|
end
|
145
153
|
# rubocop:enable Metrics/PerceivedComplexity
|
146
154
|
|
155
|
+
def self.get_latest_build!(app_id: nil, version: nil, platform: nil)
|
156
|
+
filter = { app: app_id }
|
157
|
+
filter["preReleaseVersion.version"] = version
|
158
|
+
filter["preReleaseVersion.platform"] = platform
|
159
|
+
latest_build = Spaceship::ConnectAPI.get_builds(filter: filter, sort: "-uploadedDate", includes: "preReleaseVersion").first
|
160
|
+
|
161
|
+
if latest_build.nil?
|
162
|
+
UI.user_error!("Could not find latest bulid for version #{version}")
|
163
|
+
end
|
164
|
+
|
165
|
+
return latest_build
|
166
|
+
end
|
167
|
+
|
147
168
|
def self.download(download_url, bundle_id, train_number, build_version, output_directory)
|
148
169
|
result = self.download_file(download_url)
|
149
170
|
path = write_dsym(result, bundle_id, train_number, build_version, output_directory)
|