fastlane 2.201.0.rc1 → 2.201.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +88 -81
- data/fastlane/lib/fastlane/actions/.run_tests.rb.swp +0 -0
- data/fastlane/lib/fastlane/actions/run_tests.rb +8 -0
- data/fastlane/lib/fastlane/actions/xcov.rb +5 -0
- 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 +142 -43
- data/fastlane/swift/Gymfile.swift +1 -1
- data/fastlane/swift/GymfileProtocol.swift +10 -6
- 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 +1 -1
- data/fastlane/swift/Scanfile.swift +1 -1
- data/fastlane/swift/ScanfileProtocol.swift +18 -6
- 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 +9 -5
- data/fastlane/swift/formatting/Brewfile.lock.json +14 -14
- data/fastlane_core/lib/fastlane_core/ui/fastlane_runner.rb +7 -0
- data/gym/lib/gym/options.rb +1 -1
- data/scan/lib/scan/.error_handler.rb.swp +0 -0
- data/scan/lib/scan/.runner.rb.swp +0 -0
- data/scan/lib/scan/error_handler.rb +9 -0
- data/scan/lib/scan/options.rb +6 -1
- data/scan/lib/scan/runner.rb +70 -6
- data/scan/lib/scan/test_command_generator.rb +3 -2
- data/snapshot/lib/snapshot/options.rb +1 -1
- data/trainer/lib/assets/junit.xml.erb +3 -3
- data/trainer/lib/trainer/.options.rb.swp +0 -0
- data/trainer/lib/trainer/options.rb +11 -0
- data/trainer/lib/trainer/test_parser.rb +62 -21
- metadata +27 -22
@@ -104,7 +104,10 @@ public protocol GymfileProtocol: class {
|
|
104
104
|
/// Suppress the output of xcodebuild to stdout. Output is still saved in buildlog_path
|
105
105
|
var suppressXcodeOutput: Bool? { get }
|
106
106
|
|
107
|
-
///
|
107
|
+
/// xcodebuild formatter to use (ex: 'xcbeautify', 'xcbeautify --quieter', 'xcpretty', 'xcpretty -test'). Use empty string (ex: '') to disable any formatter (More information: https://docs.fastlane.tools/best-practices/xcodebuild-formatters/)
|
108
|
+
var xcodebuildFormatter: String { get }
|
109
|
+
|
110
|
+
/// **DEPRECATED!** Use `xcodebuild_formatter: ''` instead - Disable xcpretty formatting of build output
|
108
111
|
var disableXcpretty: Bool? { get }
|
109
112
|
|
110
113
|
/// Use the test (RSpec style) format for build output
|
@@ -122,12 +125,12 @@ public protocol GymfileProtocol: class {
|
|
122
125
|
/// Have xcpretty create a JSON compilation database at the provided path
|
123
126
|
var xcprettyReportJson: String? { get }
|
124
127
|
|
125
|
-
/// Analyze the project build time and store the output in 'culprits.txt' file
|
126
|
-
var analyzeBuildTime: Bool? { get }
|
127
|
-
|
128
128
|
/// Have xcpretty use unicode encoding when reporting builds
|
129
129
|
var xcprettyUtf: Bool? { get }
|
130
130
|
|
131
|
+
/// Analyze the project build time and store the output in 'culprits.txt' file
|
132
|
+
var analyzeBuildTime: Bool? { get }
|
133
|
+
|
131
134
|
/// Do not try to build a profile mapping from the xcodeproj. Match or a manually provided mapping should be used
|
132
135
|
var skipProfileDetection: Bool { get }
|
133
136
|
|
@@ -182,14 +185,15 @@ public extension GymfileProtocol {
|
|
182
185
|
var xcargs: String? { return nil }
|
183
186
|
var xcconfig: String? { return nil }
|
184
187
|
var suppressXcodeOutput: Bool? { return nil }
|
188
|
+
var xcodebuildFormatter: String { return "xcbeautify" }
|
185
189
|
var disableXcpretty: Bool? { return nil }
|
186
190
|
var xcprettyTestFormat: Bool? { return nil }
|
187
191
|
var xcprettyFormatter: String? { return nil }
|
188
192
|
var xcprettyReportJunit: String? { return nil }
|
189
193
|
var xcprettyReportHtml: String? { return nil }
|
190
194
|
var xcprettyReportJson: String? { return nil }
|
191
|
-
var analyzeBuildTime: Bool? { return nil }
|
192
195
|
var xcprettyUtf: Bool? { return nil }
|
196
|
+
var analyzeBuildTime: Bool? { return nil }
|
193
197
|
var skipProfileDetection: Bool { return false }
|
194
198
|
var xcodebuildCommand: String { return "xcodebuild" }
|
195
199
|
var clonedSourcePackagesPath: String? { return nil }
|
@@ -200,4 +204,4 @@ public extension GymfileProtocol {
|
|
200
204
|
|
201
205
|
// Please don't remove the lines below
|
202
206
|
// They are used to detect outdated files
|
203
|
-
// FastlaneRunnerAPIVersion [0.9.
|
207
|
+
// FastlaneRunnerAPIVersion [0.9.95]
|
@@ -80,9 +80,6 @@ public protocol ScanfileProtocol: class {
|
|
80
80
|
/// Should the HTML report be opened when tests are completed?
|
81
81
|
var openReport: Bool { get }
|
82
82
|
|
83
|
-
/// Disable xcpretty formatting of build, similar to `output_style='raw'` but this will also skip the test results table
|
84
|
-
var disableXcpretty: Bool? { get }
|
85
|
-
|
86
83
|
/// The directory in which all reports will be stored
|
87
84
|
var outputDirectory: String { get }
|
88
85
|
|
@@ -104,9 +101,21 @@ public protocol ScanfileProtocol: class {
|
|
104
101
|
/// Suppress the output of xcodebuild to stdout. Output is still saved in buildlog_path
|
105
102
|
var suppressXcodeOutput: Bool? { get }
|
106
103
|
|
107
|
-
///
|
104
|
+
/// xcodebuild formatter to use (ex: 'xcbeautify', 'xcbeautify --quieter', 'xcpretty', 'xcpretty -test'). Use empty string (ex: '') to disable any formatter (More information: https://docs.fastlane.tools/best-practices/xcodebuild-formatters/)
|
105
|
+
var xcodebuildFormatter: String { get }
|
106
|
+
|
107
|
+
/// Remove retry attempts from test results table and the JUnit report (if not using xcpretty)
|
108
|
+
var outputRemoveRetryAttempts: Bool { get }
|
109
|
+
|
110
|
+
/// **DEPRECATED!** Use `output_style: 'raw'` instead - Disable xcpretty formatting of build, similar to `output_style='raw'` but this will also skip the test results table
|
111
|
+
var disableXcpretty: Bool? { get }
|
112
|
+
|
113
|
+
/// **DEPRECATED!** Use 'xcpretty_formatter' instead - A custom xcpretty formatter to use
|
108
114
|
var formatter: String? { get }
|
109
115
|
|
116
|
+
/// A custom xcpretty formatter to use
|
117
|
+
var xcprettyFormatter: String? { get }
|
118
|
+
|
110
119
|
/// Pass in xcpretty additional command line arguments (e.g. '--test --no-color' or '--tap --no-utf')
|
111
120
|
var xcprettyArgs: String? { get }
|
112
121
|
|
@@ -246,7 +255,6 @@ public extension ScanfileProtocol {
|
|
246
255
|
var addressSanitizer: Bool? { return nil }
|
247
256
|
var threadSanitizer: Bool? { return nil }
|
248
257
|
var openReport: Bool { return false }
|
249
|
-
var disableXcpretty: Bool? { return nil }
|
250
258
|
var outputDirectory: String { return "./test_output" }
|
251
259
|
var outputStyle: String? { return nil }
|
252
260
|
var outputTypes: String { return "html,junit" }
|
@@ -254,7 +262,11 @@ public extension ScanfileProtocol {
|
|
254
262
|
var buildlogPath: String { return "~/Library/Logs/scan" }
|
255
263
|
var includeSimulatorLogs: Bool { return false }
|
256
264
|
var suppressXcodeOutput: Bool? { return nil }
|
265
|
+
var xcodebuildFormatter: String { return "xcbeautify" }
|
266
|
+
var outputRemoveRetryAttempts: Bool { return false }
|
267
|
+
var disableXcpretty: Bool? { return nil }
|
257
268
|
var formatter: String? { return nil }
|
269
|
+
var xcprettyFormatter: String? { return nil }
|
258
270
|
var xcprettyArgs: String? { return nil }
|
259
271
|
var derivedDataPath: String? { return nil }
|
260
272
|
var shouldZipBuildProducts: Bool { return false }
|
@@ -296,4 +308,4 @@ public extension ScanfileProtocol {
|
|
296
308
|
|
297
309
|
// Please don't remove the lines below
|
298
310
|
// They are used to detect outdated files
|
299
|
-
// FastlaneRunnerAPIVersion [0.9.
|
311
|
+
// FastlaneRunnerAPIVersion [0.9.100]
|
@@ -86,9 +86,6 @@ public protocol SnapshotfileProtocol: class {
|
|
86
86
|
/// The configuration to use when building the app. Defaults to 'Release'
|
87
87
|
var configuration: String? { get }
|
88
88
|
|
89
|
-
/// Additional xcpretty arguments
|
90
|
-
var xcprettyArgs: String? { get }
|
91
|
-
|
92
89
|
/// The SDK that should be used for building the application
|
93
90
|
var sdk: String? { get }
|
94
91
|
|
@@ -137,6 +134,12 @@ public protocol SnapshotfileProtocol: class {
|
|
137
134
|
/// Array of strings matching Test Bundle/Test Suite/Test Cases to skip
|
138
135
|
var skipTesting: String? { get }
|
139
136
|
|
137
|
+
/// xcodebuild formatter to use (ex: 'xcbeautify', 'xcbeautify --quieter', 'xcpretty', 'xcpretty -test'). Use empty string (ex: '') to disable any formatter (More information: https://docs.fastlane.tools/best-practices/xcodebuild-formatters/)
|
138
|
+
var xcodebuildFormatter: String { get }
|
139
|
+
|
140
|
+
/// **DEPRECATED!** Use `xcodebuild_formatter: ''` instead - Additional xcpretty arguments
|
141
|
+
var xcprettyArgs: String? { get }
|
142
|
+
|
140
143
|
/// Disable xcpretty formatting of build
|
141
144
|
var disableXcpretty: Bool? { get }
|
142
145
|
|
@@ -176,7 +179,6 @@ public extension SnapshotfileProtocol {
|
|
176
179
|
var clean: Bool { return false }
|
177
180
|
var testWithoutBuilding: Bool? { return nil }
|
178
181
|
var configuration: String? { return nil }
|
179
|
-
var xcprettyArgs: String? { return nil }
|
180
182
|
var sdk: String? { return nil }
|
181
183
|
var scheme: String? { return nil }
|
182
184
|
var numberOfRetries: Int { return 1 }
|
@@ -193,6 +195,8 @@ public extension SnapshotfileProtocol {
|
|
193
195
|
var testplan: String? { return nil }
|
194
196
|
var onlyTesting: String? { return nil }
|
195
197
|
var skipTesting: String? { return nil }
|
198
|
+
var xcodebuildFormatter: String { return "xcbeautify" }
|
199
|
+
var xcprettyArgs: String? { return nil }
|
196
200
|
var disableXcpretty: Bool? { return nil }
|
197
201
|
var suppressXcodeOutput: Bool? { return nil }
|
198
202
|
var useSystemScm: Bool { return false }
|
@@ -200,4 +204,4 @@ public extension SnapshotfileProtocol {
|
|
200
204
|
|
201
205
|
// Please don't remove the lines below
|
202
206
|
// They are used to detect outdated files
|
203
|
-
// FastlaneRunnerAPIVersion [0.9.
|
207
|
+
// FastlaneRunnerAPIVersion [0.9.84]
|
@@ -2,35 +2,35 @@
|
|
2
2
|
"entries": {
|
3
3
|
"brew": {
|
4
4
|
"swiftformat": {
|
5
|
-
"version": "0.49.
|
5
|
+
"version": "0.49.2",
|
6
6
|
"bottle": {
|
7
7
|
"rebuild": 0,
|
8
8
|
"root_url": "https://ghcr.io/v2/homebrew/core",
|
9
9
|
"files": {
|
10
10
|
"arm64_monterey": {
|
11
11
|
"cellar": ":any_skip_relocation",
|
12
|
-
"url": "https://ghcr.io/v2/homebrew/core/swiftformat/blobs/sha256:
|
13
|
-
"sha256": "
|
12
|
+
"url": "https://ghcr.io/v2/homebrew/core/swiftformat/blobs/sha256:2279db95259ddbc7ad83e47f5bbf8c308db55b74d5464ac79a027bd33138b023",
|
13
|
+
"sha256": "2279db95259ddbc7ad83e47f5bbf8c308db55b74d5464ac79a027bd33138b023"
|
14
14
|
},
|
15
15
|
"arm64_big_sur": {
|
16
16
|
"cellar": ":any_skip_relocation",
|
17
|
-
"url": "https://ghcr.io/v2/homebrew/core/swiftformat/blobs/sha256:
|
18
|
-
"sha256": "
|
17
|
+
"url": "https://ghcr.io/v2/homebrew/core/swiftformat/blobs/sha256:2f6bddbef7d750d6ed546ed5decd4d54d439f16009491bdb4e4999c99d877bcf",
|
18
|
+
"sha256": "2f6bddbef7d750d6ed546ed5decd4d54d439f16009491bdb4e4999c99d877bcf"
|
19
19
|
},
|
20
20
|
"monterey": {
|
21
21
|
"cellar": ":any_skip_relocation",
|
22
|
-
"url": "https://ghcr.io/v2/homebrew/core/swiftformat/blobs/sha256:
|
23
|
-
"sha256": "
|
22
|
+
"url": "https://ghcr.io/v2/homebrew/core/swiftformat/blobs/sha256:190bf822a188ec8e8be754de2fcd34166ffb07bbd40d67385653d898a251b167",
|
23
|
+
"sha256": "190bf822a188ec8e8be754de2fcd34166ffb07bbd40d67385653d898a251b167"
|
24
24
|
},
|
25
25
|
"big_sur": {
|
26
26
|
"cellar": ":any_skip_relocation",
|
27
|
-
"url": "https://ghcr.io/v2/homebrew/core/swiftformat/blobs/sha256:
|
28
|
-
"sha256": "
|
27
|
+
"url": "https://ghcr.io/v2/homebrew/core/swiftformat/blobs/sha256:fe294ff0fa69548876a70ef7aaf30b7221a43adc9f75f7c157c6f881089da6eb",
|
28
|
+
"sha256": "fe294ff0fa69548876a70ef7aaf30b7221a43adc9f75f7c157c6f881089da6eb"
|
29
29
|
},
|
30
30
|
"catalina": {
|
31
31
|
"cellar": ":any_skip_relocation",
|
32
|
-
"url": "https://ghcr.io/v2/homebrew/core/swiftformat/blobs/sha256:
|
33
|
-
"sha256": "
|
32
|
+
"url": "https://ghcr.io/v2/homebrew/core/swiftformat/blobs/sha256:2a174bf9c47a070b1fcaa32c066cd7c82604fc428db952f11c9bf1e4448c567a",
|
33
|
+
"sha256": "2a174bf9c47a070b1fcaa32c066cd7c82604fc428db952f11c9bf1e4448c567a"
|
34
34
|
}
|
35
35
|
}
|
36
36
|
}
|
@@ -56,10 +56,10 @@
|
|
56
56
|
"macOS": "11.6"
|
57
57
|
},
|
58
58
|
"monterey": {
|
59
|
-
"HOMEBREW_VERSION": "3.3.
|
59
|
+
"HOMEBREW_VERSION": "3.3.11-103-g768b172",
|
60
60
|
"HOMEBREW_PREFIX": "/opt/homebrew",
|
61
|
-
"Homebrew/homebrew-core": "
|
62
|
-
"CLT": "13.
|
61
|
+
"Homebrew/homebrew-core": "3636e44542f6dbd859a4bd8a143a433e8930361f",
|
62
|
+
"CLT": "13.2.0.0.1.1638488800",
|
63
63
|
"Xcode": "13.2.1",
|
64
64
|
"macOS": "12.0.1"
|
65
65
|
}
|
@@ -114,6 +114,13 @@ module Commander
|
|
114
114
|
action_launch_context = FastlaneCore::ActionLaunchContext.context_for_action_name(@program[:name], fastlane_client_language: fastlane_client_language, args: ARGV)
|
115
115
|
FastlaneCore.session.action_launched(launch_context: action_launch_context)
|
116
116
|
|
117
|
+
# Trainer has been added to fastlane as of 2.201.0
|
118
|
+
# We need to make sure that the trainer fastlane plugin is no longer installed
|
119
|
+
# to avoid any clashes
|
120
|
+
if Gem::Specification.any? { |s| (s.name == 'fastlane-plugin-trainer') && Gem::Requirement.default =~ (s.version) }
|
121
|
+
FastlaneCore::UI.user_error!("Migration Needed: As of 2.201.0, trainer is included in fastlane. Please remove the trainer plugin from your Gemfile or Pluginfile (or with 'gem uninstall fastlane-plugin-trainer') - More information: https://docs.fastlane.tools/best-practices/xcodebuild-formatters/")
|
122
|
+
end
|
123
|
+
|
117
124
|
return_value = run_active_command
|
118
125
|
|
119
126
|
action_completed(@program[:name], status: FastlaneCore::ActionCompletionStatus::SUCCESS)
|
data/gym/lib/gym/options.rb
CHANGED
@@ -234,7 +234,7 @@ module Gym
|
|
234
234
|
|
235
235
|
FastlaneCore::ConfigItem.new(key: :xcodebuild_formatter,
|
236
236
|
env_names: ["GYM_XCODEBUILD_FORMATTER", "FASTLANE_XCODEBUILD_FORMATTER"],
|
237
|
-
description: "xcodebuild formatter to use (ex: 'xcbeautify', 'xcbeautify --quieter', 'xcpretty', 'xcpretty -test')",
|
237
|
+
description: "xcodebuild formatter to use (ex: 'xcbeautify', 'xcbeautify --quieter', 'xcpretty', 'xcpretty -test'). Use empty string (ex: '') to disable any formatter (More information: https://docs.fastlane.tools/best-practices/xcodebuild-formatters/)",
|
238
238
|
type: String,
|
239
239
|
default_value: Fastlane::Helper::XcodebuildFormatterHelper.xcbeautify_installed? ? 'xcbeautify' : 'xcpretty',
|
240
240
|
default_value_dynamic: true),
|
Binary file
|
Binary file
|
@@ -27,6 +27,15 @@ module Scan
|
|
27
27
|
print("If you are using zshell or another shell, make sure to edit the correct bash file.")
|
28
28
|
print("For more information visit this stackoverflow answer:")
|
29
29
|
print("https://stackoverflow.com/a/17031697/445598")
|
30
|
+
when /Testing failed on/
|
31
|
+
# This is important because xcbeautify and raw output will print:
|
32
|
+
# Testing failed on 'iPhone 13 Pro Max'
|
33
|
+
# when multiple devices are use.
|
34
|
+
# xcpretty hides this output so its not an issue with xcpretty.
|
35
|
+
# We need to catch "Testing failed on" before "Test failed"
|
36
|
+
# so that an error isn't raised.
|
37
|
+
# Raising an error prevents trainer from processing the xcresult
|
38
|
+
return
|
30
39
|
when /Testing failed/
|
31
40
|
UI.build_failure!("Error building the application. #{details}")
|
32
41
|
when /Executed/, /Failing tests:/
|
data/scan/lib/scan/options.rb
CHANGED
@@ -264,10 +264,15 @@ module Scan
|
|
264
264
|
|
265
265
|
FastlaneCore::ConfigItem.new(key: :xcodebuild_formatter,
|
266
266
|
env_names: ["SCAN_XCODEBUILD_FORMATTER", "FASTLANE_XCODEBUILD_FORMATTER"],
|
267
|
-
description: "xcodebuild formatter to use (ex: 'xcbeautify', 'xcbeautify --quieter', 'xcpretty', 'xcpretty -test')",
|
267
|
+
description: "xcodebuild formatter to use (ex: 'xcbeautify', 'xcbeautify --quieter', 'xcpretty', 'xcpretty -test'). Use empty string (ex: '') to disable any formatter (More information: https://docs.fastlane.tools/best-practices/xcodebuild-formatters/)",
|
268
268
|
type: String,
|
269
269
|
default_value: Fastlane::Helper::XcodebuildFormatterHelper.xcbeautify_installed? ? 'xcbeautify' : 'xcpretty',
|
270
270
|
default_value_dynamic: true),
|
271
|
+
FastlaneCore::ConfigItem.new(key: :output_remove_retry_attempts,
|
272
|
+
env_name: "SCAN_OUTPUT_REMOVE_RETRY_ATTEMPS",
|
273
|
+
description: "Remove retry attempts from test results table and the JUnit report (if not using xcpretty)",
|
274
|
+
type: Boolean,
|
275
|
+
default_value: false),
|
271
276
|
|
272
277
|
# xcpretty
|
273
278
|
FastlaneCore::ConfigItem.new(key: :disable_xcpretty,
|
data/scan/lib/scan/runner.rb
CHANGED
@@ -51,13 +51,18 @@ module Scan
|
|
51
51
|
end
|
52
52
|
end
|
53
53
|
|
54
|
-
|
55
|
-
retries = Helper.xcode_at_least?(13) ? 0 : Scan.config[:number_of_retries]
|
54
|
+
retries = Scan.config[:number_of_retries]
|
56
55
|
execute(retries: retries)
|
57
56
|
end
|
58
57
|
|
59
58
|
def execute(retries: 0)
|
60
|
-
|
59
|
+
# Set retries to 0 if Xcode 13 because TestCommandGenerator will set '-retry-tests-on-failure -test-iterations'
|
60
|
+
if Helper.xcode_at_least?(13)
|
61
|
+
retries = 0
|
62
|
+
Scan.cache[:retry_attempt] = 0
|
63
|
+
else
|
64
|
+
Scan.cache[:retry_attempt] = Scan.config[:number_of_retries] - retries
|
65
|
+
end
|
61
66
|
|
62
67
|
command = @test_command_generator.generate
|
63
68
|
|
@@ -137,6 +142,36 @@ module Scan
|
|
137
142
|
return retryable_tests.uniq
|
138
143
|
end
|
139
144
|
|
145
|
+
def find_filename(type)
|
146
|
+
index = Scan.config[:output_types].split(',').index(type)
|
147
|
+
return nil if index.nil?
|
148
|
+
return (Scan.config[:output_files] || "").split(',')[index]
|
149
|
+
end
|
150
|
+
|
151
|
+
def output_html?
|
152
|
+
return Scan.config[:output_types].split(',').include?('html')
|
153
|
+
end
|
154
|
+
|
155
|
+
def output_junit?
|
156
|
+
return Scan.config[:output_types].split(',').include?('junit')
|
157
|
+
end
|
158
|
+
|
159
|
+
def output_json_compilation_database?
|
160
|
+
return Scan.config[:output_types].split(',').include?('json-compilation-database')
|
161
|
+
end
|
162
|
+
|
163
|
+
def output_html_filename
|
164
|
+
return find_filename('html')
|
165
|
+
end
|
166
|
+
|
167
|
+
def output_junit_filename
|
168
|
+
return find_filename('junit')
|
169
|
+
end
|
170
|
+
|
171
|
+
def output_json_compilation_database_filename
|
172
|
+
return find_filename('json-compilation-database')
|
173
|
+
end
|
174
|
+
|
140
175
|
def trainer_test_results
|
141
176
|
require "trainer"
|
142
177
|
|
@@ -147,17 +182,44 @@ module Scan
|
|
147
182
|
}
|
148
183
|
|
149
184
|
result_bundle_path = Scan.cache[:result_bundle_path]
|
185
|
+
|
150
186
|
output_path = Scan.config[:output_directory] || Dir.mktmpdir
|
187
|
+
output_path = File.absolute_path(output_path)
|
151
188
|
|
152
189
|
UI.crash!("A -resultBundlePath is needed to parse the test results. This should not have happened. Please file an issue.") unless result_bundle_path
|
153
190
|
|
154
191
|
params = {
|
155
192
|
path: result_bundle_path,
|
156
|
-
|
157
|
-
silent:
|
158
|
-
extension: "xml"
|
193
|
+
output_remove_retry_attempts: Scan.config[:output_remove_retry_attempts],
|
194
|
+
silent: !FastlaneCore::Globals.verbose?
|
159
195
|
}
|
160
196
|
|
197
|
+
formatter = Scan.config[:xcodebuild_formatter].chomp
|
198
|
+
show_output_types_tip = false
|
199
|
+
if output_html? && formatter != 'xcpretty'
|
200
|
+
UI.important("Skipping HTML... only available with `xcodebuild_formatter: 'xcpretty'` right now")
|
201
|
+
show_output_types_tip = true
|
202
|
+
end
|
203
|
+
|
204
|
+
if output_json_compilation_database? && formatter != 'xcpretty'
|
205
|
+
UI.important("Skipping JSON Compilation Database... only available with `xcodebuild_formatter: 'xcpretty'` right now")
|
206
|
+
show_output_types_tip = true
|
207
|
+
end
|
208
|
+
|
209
|
+
if show_output_types_tip
|
210
|
+
UI.important("Your 'xcodebuild_formatter' doesn't support these 'output_types'. Change your 'output_types' to prevent these warnings from showing...")
|
211
|
+
end
|
212
|
+
|
213
|
+
if output_junit?
|
214
|
+
if formatter == 'xcpretty'
|
215
|
+
UI.verbose("Generating junit report with xcpretty")
|
216
|
+
else
|
217
|
+
UI.verbose("Generating junit report with trainer")
|
218
|
+
params[:output_filename] = output_junit_filename || "report.junit"
|
219
|
+
params[:output_directory] = output_path
|
220
|
+
end
|
221
|
+
end
|
222
|
+
|
161
223
|
resulting_paths = Trainer::TestParser.auto_convert(params)
|
162
224
|
resulting_paths.each do |path, data|
|
163
225
|
results[:number_of_tests] += data[:number_of_tests_excluding_retries]
|
@@ -169,6 +231,8 @@ module Scan
|
|
169
231
|
end
|
170
232
|
|
171
233
|
def handle_results(tests_exit_status)
|
234
|
+
return if Scan.config[:build_for_testing]
|
235
|
+
|
172
236
|
results = trainer_test_results
|
173
237
|
|
174
238
|
number_of_retries = results[:number_of_retries]
|
@@ -119,7 +119,9 @@ module Scan
|
|
119
119
|
formatter = Scan.config[:xcodebuild_formatter].chomp
|
120
120
|
options = legacy_xcpretty_options
|
121
121
|
|
122
|
-
if
|
122
|
+
if formatter == ''
|
123
|
+
UI.verbose("Not using an xcodebuild formatter")
|
124
|
+
elsif !options.empty?
|
123
125
|
UI.important("Detected legacy xcpretty being used so formatting wth xcpretty")
|
124
126
|
UI.important("Option(s) used: #{options.join(', ')}")
|
125
127
|
pipe << pipe_xcpretty
|
@@ -150,7 +152,6 @@ module Scan
|
|
150
152
|
options << "formatter" if Scan.config[:formatter]
|
151
153
|
options << "xcpretty_formatter" if Scan.config[:xcpretty_formatter]
|
152
154
|
options << "output_style" if Scan.config[:output_style]
|
153
|
-
options << "output_files" if Scan.config[:output_files]
|
154
155
|
options << "output_types" if (Scan.config[:output_types] || "").include?("json-compilation-database")
|
155
156
|
options << "custom_report_file_name" if Scan.config[:custom_report_file_name]
|
156
157
|
|
@@ -291,7 +291,7 @@ module Snapshot
|
|
291
291
|
|
292
292
|
FastlaneCore::ConfigItem.new(key: :xcodebuild_formatter,
|
293
293
|
env_names: ["SNAPSHOT_XCODEBUILD_FORMATTER", "FASTLANE_XCODEBUILD_FORMATTER"],
|
294
|
-
description: "xcodebuild formatter to use (ex: 'xcbeautify', 'xcbeautify --quieter', 'xcpretty', 'xcpretty -test')",
|
294
|
+
description: "xcodebuild formatter to use (ex: 'xcbeautify', 'xcbeautify --quieter', 'xcpretty', 'xcpretty -test'). Use empty string (ex: '') to disable any formatter (More information: https://docs.fastlane.tools/best-practices/xcodebuild-formatters/)",
|
295
295
|
type: String,
|
296
296
|
default_value: Fastlane::Helper::XcodebuildFormatterHelper.xcbeautify_installed? ? 'xcbeautify' : 'xcpretty',
|
297
297
|
default_value_dynamic: true),
|
@@ -1,12 +1,12 @@
|
|
1
1
|
<?xml version="1.0" encoding="UTF-8"?>
|
2
2
|
<% number_of_tests = 0 %>
|
3
3
|
<% number_of_failures = 0 %>
|
4
|
-
<% @results.each { |a| number_of_tests += a[:
|
5
|
-
<% @results.each { |a| number_of_failures += a[:
|
4
|
+
<% @results.each { |a| number_of_tests += a[:number_of_tests_excluding_retries] } %>
|
5
|
+
<% @results.each { |a| number_of_failures += a[:number_of_failures_excluding_retries] } %>
|
6
6
|
|
7
7
|
<testsuites tests="<%= number_of_tests %>" failures="<%= number_of_failures %>">
|
8
8
|
<% @results.each do |testsuite| %>
|
9
|
-
<testsuite name=<%= (testsuite[:target_name].nil? ? testsuite[:test_name] : testsuite[:target_name]).encode(:xml => :attr) %> tests="<%= testsuite[:
|
9
|
+
<testsuite name=<%= (testsuite[:target_name].nil? ? testsuite[:test_name] : testsuite[:target_name]).encode(:xml => :attr) %> tests="<%= testsuite[:number_of_tests_excluding_retries] %>" failures="<%= testsuite[:number_of_failures_excluding_retries] %>" time="<%= testsuite[:duration] %>">
|
10
10
|
<% testsuite[:tests].each do |test| %>
|
11
11
|
<testcase classname=<%= test[:test_group].encode(:xml => :attr) %> name=<%= test[:name].encode(:xml => :attr) %> time="<%= test[:duration] %>">
|
12
12
|
<% (test[:failures] || []).each do |failure| %>
|
Binary file
|
@@ -33,6 +33,12 @@ module Trainer
|
|
33
33
|
default_value: nil,
|
34
34
|
optional: true,
|
35
35
|
description: "Directoy in which the xml files should be written to. Same directory as source by default"),
|
36
|
+
FastlaneCore::ConfigItem.new(key: :output_filename,
|
37
|
+
short_option: "-f",
|
38
|
+
env_name: "TRAINER_OUTPUT_FILENAME",
|
39
|
+
default_value: nil,
|
40
|
+
optional: true,
|
41
|
+
description: "Filename the xml file should be written to. Defaults to name of input file. (Only works if one input file is used)"),
|
36
42
|
FastlaneCore::ConfigItem.new(key: :fail_build,
|
37
43
|
env_name: "TRAINER_FAIL_BUILD",
|
38
44
|
description: "Should this step stop the build if the tests fail? Set this to false if you're handling this with a test reporter",
|
@@ -48,6 +54,11 @@ module Trainer
|
|
48
54
|
env_name: "TRAINER_SILENT",
|
49
55
|
description: "Silences all output",
|
50
56
|
is_string: false,
|
57
|
+
default_value: false),
|
58
|
+
FastlaneCore::ConfigItem.new(key: :output_remove_retry_attempts,
|
59
|
+
env_name: "TRAINER_OUTPUT_REMOVE_RETRY_ATTEMPTS",
|
60
|
+
description: "Doesn't include retry attempts in the output",
|
61
|
+
is_string: false,
|
51
62
|
default_value: false)
|
52
63
|
]
|
53
64
|
end
|