fastlane 2.180.1 → 2.183.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +90 -90
- data/cert/lib/cert/commands_generator.rb +2 -1
- data/deliver/lib/assets/summary.html.erb +10 -10
- data/deliver/lib/deliver/commands_generator.rb +2 -1
- data/deliver/lib/deliver/languages.rb +1 -1
- data/deliver/lib/deliver/options.rb +2 -2
- data/deliver/lib/deliver/submit_for_review.rb +3 -3
- data/deliver/lib/deliver/upload_metadata.rb +1 -1
- data/fastlane/lib/fastlane/actions/actions_helper.rb +2 -2
- data/fastlane/lib/fastlane/actions/backup_xcarchive.rb +1 -1
- data/fastlane/lib/fastlane/actions/clipboard.rb +3 -6
- data/fastlane/lib/fastlane/actions/danger.rb +7 -1
- data/fastlane/lib/fastlane/actions/docs/capture_ios_screenshots.md +1 -1
- data/fastlane/lib/fastlane/actions/docs/frame_screenshots.md +18 -1
- data/fastlane/lib/fastlane/actions/ensure_env_vars.rb +2 -6
- data/fastlane/lib/fastlane/actions/get_managed_play_store_publishing_rights.rb +3 -1
- data/fastlane/lib/fastlane/actions/git_branch.rb +1 -1
- data/fastlane/lib/fastlane/actions/git_commit.rb +3 -1
- data/fastlane/lib/fastlane/actions/git_pull.rb +4 -10
- data/fastlane/lib/fastlane/actions/git_submodule_update.rb +16 -8
- data/fastlane/lib/fastlane/actions/hipchat.rb +2 -1
- data/fastlane/lib/fastlane/actions/import_from_git.rb +5 -5
- data/fastlane/lib/fastlane/actions/notification.rb +1 -1
- data/fastlane/lib/fastlane/actions/slack.rb +155 -133
- data/fastlane/lib/fastlane/actions/upload_symbols_to_crashlytics.rb +4 -2
- data/fastlane/lib/fastlane/actions/xcodebuild.rb +5 -5
- data/fastlane/lib/fastlane/cli_tools_distributor.rb +1 -1
- data/fastlane/lib/fastlane/commands_generator.rb +2 -1
- data/fastlane/lib/fastlane/fast_file.rb +10 -2
- data/fastlane/lib/fastlane/helper/git_helper.rb +9 -1
- data/fastlane/lib/fastlane/lane_manager.rb +3 -2
- data/fastlane/lib/fastlane/notification/slack.rb +56 -0
- data/fastlane/lib/fastlane/plugins/plugin_info.rb +2 -2
- data/fastlane/lib/fastlane/plugins/template/%gem_name%.gemspec.erb +7 -6
- data/fastlane/lib/fastlane/plugins/template/.rubocop.yml +30 -35
- data/fastlane/lib/fastlane/plugins/template/spec/spec_helper.rb.erb +1 -1
- data/fastlane/lib/fastlane/swift_fastlane_function.rb +35 -14
- data/fastlane/lib/fastlane/version.rb +2 -2
- data/fastlane/swift/Deliverfile.swift +1 -1
- data/fastlane/swift/DeliverfileProtocol.swift +1 -1
- data/fastlane/swift/Fastlane.swift +6621 -3802
- data/fastlane/swift/FastlaneSwiftRunner/FastlaneSwiftRunner.xcodeproj/project.pbxproj +4 -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/OptionalConfigValue.swift +131 -0
- 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 +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 +5 -1
- data/fastlane/swift/formatting/Brewfile.lock.json +16 -14
- data/fastlane/swift/upgrade_manifest.json +1 -1
- data/fastlane_core/lib/fastlane_core.rb +22 -21
- data/fastlane_core/lib/fastlane_core/build_watcher.rb +65 -11
- data/fastlane_core/lib/fastlane_core/clipboard.rb +20 -0
- data/fastlane_core/lib/fastlane_core/device_manager.rb +1 -1
- data/fastlane_core/lib/fastlane_core/helper.rb +4 -4
- data/fastlane_core/lib/fastlane_core/languages.rb +2 -2
- data/fastlane_core/lib/fastlane_core/swag.rb +1 -1
- data/fastlane_core/lib/fastlane_core/ui/help.erb +35 -0
- data/fastlane_core/lib/fastlane_core/ui/help_formatter.rb +16 -0
- data/fastlane_core/lib/fastlane_core/ui/implementations/shell.rb +4 -1
- data/frameit/lib/frameit/commands_generator.rb +2 -1
- data/frameit/lib/frameit/config_parser.rb +2 -2
- data/frameit/lib/frameit/frame_downloader.rb +2 -1
- data/gym/lib/gym/code_signing_mapping.rb +2 -2
- data/gym/lib/gym/commands_generator.rb +2 -1
- data/gym/lib/gym/generators/package_command_generator_xcode7.rb +6 -5
- data/gym/lib/gym/runner.rb +5 -1
- data/match/lib/match/commands_generator.rb +2 -1
- data/pem/lib/pem/commands_generator.rb +2 -1
- data/pilot/lib/pilot/build_manager.rb +3 -3
- data/pilot/lib/pilot/commands_generator.rb +2 -1
- data/pilot/lib/pilot/options.rb +2 -2
- data/pilot/lib/pilot/tester_exporter.rb +0 -1
- data/pilot/lib/pilot/tester_manager.rb +0 -1
- data/precheck/lib/precheck/commands_generator.rb +2 -1
- data/produce/lib/produce/commands_generator.rb +2 -1
- data/scan/lib/scan/commands_generator.rb +2 -1
- data/scan/lib/scan/runner.rb +3 -1
- data/scan/lib/scan/test_command_generator.rb +3 -1
- data/screengrab/lib/screengrab/commands_generator.rb +2 -1
- data/sigh/lib/sigh/commands_generator.rb +2 -1
- data/snapshot/lib/assets/SnapfileTemplate +1 -1
- data/snapshot/lib/snapshot/commands_generator.rb +3 -1
- data/snapshot/lib/snapshot/options.rb +5 -0
- data/snapshot/lib/snapshot/reports_generator.rb +4 -0
- data/snapshot/lib/snapshot/simulator_launchers/launcher_configuration.rb +2 -0
- data/snapshot/lib/snapshot/simulator_launchers/simulator_launcher.rb +1 -1
- data/snapshot/lib/snapshot/simulator_launchers/simulator_launcher_base.rb +8 -4
- data/spaceship/README.md +2 -12
- data/spaceship/lib/spaceship/base.rb +2 -2
- data/spaceship/lib/spaceship/commands_generator.rb +4 -2
- data/spaceship/lib/spaceship/connect_api/model.rb +1 -1
- data/spaceship/lib/spaceship/connect_api/models/profile.rb +6 -0
- data/spaceship/lib/spaceship/connect_api/provisioning/provisioning.rb +6 -2
- data/spaceship/lib/spaceship/spaceauth_runner.rb +19 -9
- data/spaceship/lib/spaceship/tunes/members.rb +1 -1
- data/spaceship/lib/spaceship/ui.rb +2 -2
- data/supply/lib/supply/client.rb +5 -3
- data/supply/lib/supply/commands_generator.rb +2 -1
- data/supply/lib/supply/options.rb +2 -2
- data/supply/lib/supply/uploader.rb +3 -2
- metadata +74 -88
- data/fastlane/lib/fastlane/.fastlane_require.rb.swp +0 -0
- data/fastlane/lib/fastlane/actions/.cocoapods.rb.swp +0 -0
- data/pilot/lib/pilot/tester_util.rb +0 -0
@@ -0,0 +1,20 @@
|
|
1
|
+
require 'fastlane_core'
|
2
|
+
require 'open3'
|
3
|
+
|
4
|
+
module FastlaneCore
|
5
|
+
class Clipboard
|
6
|
+
def self.copy(content: nil)
|
7
|
+
return UI.crash!("'pbcopy' or 'pbpaste' command not found.") unless is_supported?
|
8
|
+
Open3.popen3('pbcopy') { |input, _, _| input << content }
|
9
|
+
end
|
10
|
+
|
11
|
+
def self.paste
|
12
|
+
return UI.crash!("'pbcopy' or 'pbpaste' command not found.") unless is_supported?
|
13
|
+
return `pbpaste`
|
14
|
+
end
|
15
|
+
|
16
|
+
def self.is_supported?
|
17
|
+
return `which pbcopy`.length > 0 && `which pbpaste`.length > 0
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
@@ -118,7 +118,7 @@ module FastlaneCore
|
|
118
118
|
discover_devices(child_item, device_types, discovered_device_udids)
|
119
119
|
end
|
120
120
|
|
121
|
-
is_supported_device = device_types.any?
|
121
|
+
is_supported_device = device_types.any?(usb_item['_name'])
|
122
122
|
serial_num = usb_item['serial_num'] || ''
|
123
123
|
has_serial_number = serial_num.length == 40 || serial_num.length == 24
|
124
124
|
|
@@ -167,11 +167,11 @@ module FastlaneCore
|
|
167
167
|
@xcode_version
|
168
168
|
end
|
169
169
|
|
170
|
-
# @return true if Xcode version is
|
170
|
+
# @return true if installed Xcode version is 'greater than or equal to' the input parameter version
|
171
171
|
def self.xcode_at_least?(version)
|
172
|
-
|
173
|
-
|
174
|
-
Gem::Version.new(
|
172
|
+
installed_xcode_version = xcode_version
|
173
|
+
UI.user_error!("Unable to locate Xcode. Please make sure to have Xcode installed on your machine") if installed_xcode_version.nil?
|
174
|
+
Gem::Version.new(installed_xcode_version) >= Gem::Version.new(version)
|
175
175
|
end
|
176
176
|
|
177
177
|
# iTMSTransporter
|
@@ -3,7 +3,7 @@ module FastlaneCore
|
|
3
3
|
# These are all the languages which are available to use to upload app metadata and screenshots
|
4
4
|
|
5
5
|
# The old format which was used until August 2015 (good old times)
|
6
|
-
ALL_LANGUAGES_LEGACY = [
|
6
|
+
ALL_LANGUAGES_LEGACY = %w[da-DK de-DE el-GR en-AU en-CA en-GB en-US es-ES es-MX fi-FI fr-CA fr-FR id-ID it-IT ja-JP ko-KR ms-MY nl-NL no-NO pt-BR pt-PT ru-RU sv-SE th-TH tr-TR vi-VI cmn-Hans cmn-Hant]
|
7
7
|
|
8
8
|
# The new format used from September 2015 on
|
9
9
|
# This was generated from `Spaceship::Tunes.client.available_languages.sort`
|
@@ -11,6 +11,6 @@ module FastlaneCore
|
|
11
11
|
# - produce/lib/produce/available_default_languages.rb
|
12
12
|
# - spaceship/lib/assets/languageMapping.json
|
13
13
|
# See pull request for example: https://github.com/fastlane/fastlane/pull/14110
|
14
|
-
ALL_LANGUAGES = [
|
14
|
+
ALL_LANGUAGES = %w[ar-SA ca cs da de-DE el en-AU en-CA en-GB en-US es-ES es-MX fi fr-CA fr-FR he hi hr hu id it ja ko ms nl-NL no pl pt-BR pt-PT ro ru sk sv th tr uk vi zh-Hans zh-Hant]
|
15
15
|
end
|
16
16
|
end
|
@@ -4,7 +4,7 @@ require_relative 'helper'
|
|
4
4
|
|
5
5
|
module FastlaneCore
|
6
6
|
class Swag
|
7
|
-
# rubocop:disable LineLength
|
7
|
+
# rubocop:disable Layout/LineLength
|
8
8
|
require 'zlib'
|
9
9
|
FRAMES = ["x\x9C\xED[\xD9u\xDB0\x10\xFCO\v\xFEq\t<C\xE0\xB9\x14\xD7\xE0\x1ERE\nt%\x91D\x12<0\xB3\aH\xC9\x8A\x9F\xF3\xF2\x13\x02\xC4\xB13;{Pyyo\xE3[\x17?^O\xFF\xF3\xF2\xDE\xDDV\xFE\xF5\xF2\xB3\xC5\xCF\x16_\xB2\xC5\xFC\xC28?\xBC\xF5oM\xFD\xFB\x03>\xAE\xE0\xE3\xEA\xBA\x87}z\xBE\xB8\xCF\f\xBE\v\xEA\a\x98\x9E\xCD\x97i>>\xFF\xFE\xD9\x0FWQ\x1En6\xC3\xE2\x8C\xA0\xCE\xA0k\xC8\x87\xE0W\xE0\x808,\xEF1;\xDA{\xF0\e\xBD1\x0E\aq\xF8\xB23\xB2Vu\xFDWf\xA7\xF1Z\xE8\xA0\xFB\xC9\x96M\xACG,\x06t(\x06\xB4\x10\xCE\x1D\x11K\xAE\xB5\fC\x93\xD6\x03\x03&7@\xDD\xB7\xE8\xF1\xD0g\\\xAB\xEBz\x1Ck[\xB0\xE9\xD0\v\x83\xF5\xF5Dp\x14o\x97\x1D\xD6H\xA1\xD1\x1C\x84\a\x94\xAA\xE7B\x8D\xC00\xF1\x9BiV\xE2\xF0Et\xE1\r\b\x12\x17\x9B\xE6\xAB\xB5\xED\x1A\x88\xF5_\x06Y\xB6\xCCL\x1C\xD5sL\xEF0\xB2\xF5\xF3A\x11\xE2\x9CO:Q\xF9\xCA\xAB\xD3\xD8\x1C\x05\xD3\xE0 W\x14\x86\x1FSA\xE2\x03\x84A5\xA4,\xA1\x10\x9BE\\r\xBB\xCA~0\xDEMiZ\xA8\x82\xB9\xFE\xC8\x147qX<\xA8|\xFFv\xED{||\x02H\x9Cc\x90\x01\x8F\xF5U\x03\xEB\xBA\xE0\xF5\x12\x1E<\x8B%u`\xEE$\xA6\x05Hg\x90\xBB^\x81G\xCF\xC7e\xEC\xF3kS \xA73K\x8E\xB2cV\x11\xA7\xA4u\x1F\xE6\xEE[\xA9w/\xECpO\x83\xC5i\xF2\x15;\xF88\f8\x04\xE5\xD3\x1DTX;\xA8\x17=Q\x11zf\x0E\xEC\xD7\xAE\xE2\x93'C\x85\xAE_\x059T\xD2l-;\xAA\xDB\x05\x1F\xE8mQx\xF3\x86\x97MU\xE2|\xBE\xBE\x82\vU\xD30V\xAF.n\x86\xFD\v\xF0\xED\x95\xBC\xA5\xF7\xBB4c\xB8'\xAA\x15\xC6\xB4\x14s@S\xC5\xD75Q\n\xA3#U\xD1\x01\x12u\x8BzI\x1C8\x83cwz\e\x1F-\xD13\x02\xD2\x00C\xF4\xADHOIcE\xEE\xA6 \x98\xCBH9MQ\x01\x94\xC5\xB0<\e\xDE\xA5WJ1\xA3\xB6\xE9l\x17\xA2\x1C\xADD\xE6%\xF41\xBC\xBA|)\v\xF0\xED\xB1|\xF1\x92\xDB\x9C\x91\xE0j\x99\xFB\xAA\x97\x19\xBA0NL\x19\a;t\x910U\xE7\x1D\x02\xA5\xEB\xD7\x83%\\\xFF\xDF\x84\x95p\xF7\xAE\xAA\xE9P\xAE\xB8h\x16\xE5kA\xC6\xAFe\xD0X'\xB1\r\x15\xD6\xDA8+\xB3\xB23\f\x86Z\xE0s\xDD 3\x04R@\n\x85\xDF\x1D\xC46,nB2bo\xEB\xF4\xA9\xC8\x9C\xD3\x96X}\xCDu\x1F&>F\xDA\b\xB9UB\x17!\xC5\xF6\xDDM\x9C\xAD\x05\xEA\xED\xC3$z\x1C\xF0\xE3\xE6\xC1B[\xD1\xBBH\x7F\xCE\xA5\xA7\x92\x05\xA8\xF4\x14\x8F\xA82h\xAD]X\x81,T\xC9\xDEdbC;\xC9Dl>IwR\xEFI\x7F\x01\x80\x8A\xBE\x04O2\xFA \x00S\xD8\"\xBD\x17\x9EY#Sx\x00\\V\"\x9F\xA5\xCA\x00\xC4\x1D\xA6g\xF7\xC0%-\xED\x11\x87\x12\x84(\xDD\x11\xF1\xBD\xE4\r>\x0FE\x8A\xB8\x85v\xC4K\x9C\x81{kEZ\xFB\r\x9C\x15\x82-\xC1|\xC0\x8D\xB1I\"w\xF2i?\x96T\xA0lc7}\xC3_\x7F\xC5\x96N\xC7\x18\xFA$*p,\xC9\f\x03\e^\xED\x8A@\x88\xB6\xAF\xC6\n\x03a\xC4\x90(\x88\xEB\r\eAu\x91\xD2^\xD6v>1\xC8%\xA6\x1F)O\xE6\xFE\b\xE2\x05+\xD1z\xF0\xEB\xA7-\x0F3\t:\x81\xA6\xC9EXK\xDCM,d\x90\x064\x8CD\xE5\x13\x8A\x8Alq4u\x9D\x8B\xE2\xB2\xE5\x04\xF9\xF4\t\x14\xA0\xD9\x00Z]a\x0E8-\xFC\xD62\f\x9Ba\xA4,t\x81\xC4\#$!H\xA0d:\x16\xC5\xD3\xA4{F\xBE\x99\xE8\xC6%\xED.)\x14\x8Dmq\xD9\xD0$\x1F:6[D;$\xB3\x17\x9C\xF7\x94 iv\xDA\x03\x1D\x0F\xE9\x94\x10;\x15\x98\xB9\xEA\xA48\x86>=\x1F\x00\xDF\xAC9\xB4D-W\x05\x9A6\xE9\x8D\x9A\xDC\x17\x912\xC4\x05\xE1\x83\x82\xE1#\x0FV\x98\xF4\xCE\xA0\xB7\xCCwN\x0F\t\xAC\xA4J\xD6\b\xC6\xBE\x8A\x1C\xE0\xD4\xF3h\x8A\x90\x92\xDB\x05\xC8\xCE\xBF\x0Eo\xF7 \xFE\xD1I\x8A\x00\x86\xF9\x17\x84\x99Z\xB1\xA4k`Q.\b)\x1C}\xA9\xE5\xBF\xCC\x80/\x11wYr\xB2\x12w\xB1\xE6\x83\xC6\xE6\x85\xC3_\x8C\xE1La\xC4I\xF9\xCBi\r\x14\\^H\xCDt\xD1\x99\x11\xE0\\P\x89\x8F\x14,\x80\xB9\xE2\xF1\x8B\x15\xFAJ\x15q\xB0\xA0\x9Db\x06V6\xD0k\xE05\x8C%~\x1Cw\xA7S>\xE2HQg\xF1\x89\x00\x931\x9D |\x01\xC5{\f\xB5\x93\x90*$7\xC1\xBF\e\x8B\xCCE\xF1\xA1\x92p\x14\xB8\xC9\xD6\xE0\x19\x83X}\xCA\xD5\x12\x91C\xC9\x9B\x94\xC5h\x03\xE0\xCAo\xEF\xCF\xAA\n\xEA%\x03\x8D\xB8tce\xD3\xBAJ\x86\xBE\x91\xF3e\xB4c\xC6&):u5\xBB\"\xB2\x91;5\x16\xCC\x9F`.h*\x94\xC0\x1D\x18\xE9\xAD\xE9\x166\x017\xA0\x92\\\xC2\xB0\xFEj\xAF\x92c\xE1\xB1\x8E\xE1JM\xA9\xC1Q\n#\xBC8\x8D\xEE\xD3\x8C\x82;\x992s\xBD\x1D\xE5K\xF0\xF1Q\x94l\xE4l\x03#\e3_1\xD5\x02\xE7V$\xC5Fx\xCE\xFF\xEB\xFE\xB3\xC5w\xD8\xE2\x1F\x8E\x13\xC7\t",
|
10
10
|
"x\x9C\xED[\xDBq\xDB0\x10\xFCO\v\xFEI\t\x02\t\x9A\xE4\xA8\x14\xD7\xE0\x1ERE\nL%\xA1D\x11\x10\x89\xDD{\x00\xB4'3\x91\xC6\x1F\xB6@\xE2q\xB7\xBB\xF7 \xFD\xF6\xD1\xCF\xD78\x7F\xFE<\xFD\xF3\xF6\x11\xEF3\xFFx{-\xF1Z\xE2\xB5\x84\x7F\x89\xED\xCA\xF5\xC2\xE9:\\\xBB\xF0\xFE\x89\xBE\xBEt\xBB\xAF\x1F\x97\xE6\xC1?\xBF\x7F\x1D\x87/\xF3n8\xFD\x14\xD3\\\xC4i\xC2\xC8\x86\xD3\x96/\xC7-\x1F\x8E\\\xDE\x13\x86\x1E\x1Ds\x1C\x8AS.W\xAEc}\x0Fv\x17B\x10F\xC7\xE1y\x10\x9E^\x9E />\xE3\xB3\x1F6\xCCOGA`\x05\v\xC2\xC4\\b\xE2\xE0\xF4b\xB83\x0E\x1F\xCF\xBB\x1F^@\x8A\x86\xA7\xDB_\x04\x893u\x81:\xADqS&\x16 \xF8\x8E\x82\xB3t\xE7\xEEp\xB2\xE0A\x83\xE1a\xB0\x97\xE0\xDDK\xD3>o\b/\xCAm.\xDF+/+mX<*\xB7\x92\x00|#?\xB8jY@#\xE1f\x81\a\x18\xEE\xFA\x12\xEB\xEB\xF6\\bg\xD4FBtx\xB4[T\xC0;\xF3a:\xB9\x12\xADR\x8F\xDA\xBB\xE0\x9A-7C\xCB\x85a\x898\xE8\xFB\xA9\xA0\xF2:K\xD4\r\x1An\x88\x91\x8E\xDA@\x06\x12<\xCCa\xA2\x92\x037=n\x88\x05O\xE1\x1D\xA2\xC9\xA5\x81\xDB\x99\r\x1A(\nV}\x98\xA6v\xCA)\x80\x1F\xE9\xB3\x84\xF4\xC1\xA2\x11\x0F\x98g`\xA3\x89\x1E\x19Z\x80\x00\rq\xDE\r\xE3<\x87\xCF\xC1\xB9\x06v\x8A\xCE\xA4ZB\xB4a\xD8\xA4\xDA\x1E\x15j\xF9\xA0\x8A~\xCE\xA8\x89\x82\x12\x86\eN-d\xE0{\x85\x11~\xC8}\v\x80U\xDD\x82\x13l\xDB\x0FE\x8C#0\x8D\xD8\xF9\x19\\\x18\xBF\x10\xA0\xD2u\x84\x06!#\xF5d\xEFX\xEF<\x1D\x92Td]\x12\xCDs\xDB\xA2\x9Atp:\xC1CL\x12-\xE8s\xDD\x9A2W\xBB\x9E\xCAV\xBE\xCB\xAB\x8C\xDB\x02Q\b\x8F:\xB2\xED\xBC 1t\xD3B\xD9\xA8r\x10\x85;I\x13\x17\xBEl\x854O;\xB4rNWa\x06\xEB\v\xCC\x161\xDAm\xBB6C\xA1\xC2\xD1\xED\xD1\x95R\x82'\xD3-\x1E-\xAB)PS\xEC\x9D\x89\xAB$C\x99\x95\xAE\x98X\xF3\xC9~>\xC0\xFCs\"\x16\x8DD\x8C\xD7\xCA\xF6\\\x9D\xC1\xBB!\xBA\xBE\x91T9\xD2\x1C'pm$\xA7\xAAKQU\x11\xC2\xE5L6\xE7\xC1G\xF93\xC1\xD5\x83\xEB\xCD\x1C]Y\xF9>\xC5U\bJ-*OY\xA5<\x96\xFEG4\xE9<\x13+)\xB5#\x1A\xB4\x1A\xF2\x8Bd`\x1Akd@7%p\xD5\x00#\xDE\x14p\x1F\xE3\xF6K\x84\xFC\x1C\xF2\x9DZBB\xA2\xEA\x01\xE3m\xAD\x05\x9F\x16A\xD76\xE9\x91\x95BQ\xA8\xAC9\n\x12\xF6d\x1A\x0E\xC1@C\x155fO\xDF\xC11\b \x89\x8F\x1DG\x94\xBBo\x83p\xDA\x89\xA7#'k\xAC\xFCL\x80wg]\xD8\xCA\xFA\x8B\xB9t\xB9F\xB9\xA0m\xAE/\x14}\x12\xB1U\x9CV\x83\x10S\x12\x8C\xA0h@\x10\xBC\x13vZ\xD7\xFD \xF5\x81-]\xF8\xECK{\x1Ej/<H?D\xF9\x00j\x8F\xB8!\xDD\x0F\xB8\x7F\x1D\v%X\x15\xC6T;\x00\xEE\x9D!\x81\x9ETWA\x18\x93\xA8\xD0!z\xD84\n23W\xBBv\x9C\xA1(7;\x01\xA5\xA4\xDE\xA8\x9EUau<\xDB8f\x10\x81\xA3\xF7\xC3n\x98\xEC\xCB\x85,%\xC4\xB6\xE5Pi\xF2I\xE7\x9C\x13^]\xCFP`\x8Err\x12e\xEC\x9B\n\xBA\"\xE2\xC8\x1F\xF7\xBC\xE52\x93\xAD\t\xA0`\xEA\xB3\xA6\xF9p\x87r\xA6>\x03\xD0F\xD0\xE3C<\x17\xF4\x94~r;\xF4\x8E;\xDB\xB4\xCB\x1F:\xA7@`\xF9\xA4\x95*e-\r\x9Bw\x9A\xD1\xF2\x179L\x91[\xCF>\xD3(=\xA4\xF8N\x86\x0E_\xF0\x86FB\x9CU6\xE9\x15\x11\x1E)\r\x17\x88\xDE\x0F\xAF\xEC\xF1O0rjSIm\xAByH\xCAiJ\xAD\xBD\xA9\xE60c\xC4m<*\x95V\x97p)}\xE0Ur\xC6\xAD\xA3\x0E\a\xA4D\x93\xEC\xF8\r\xB3\x9A\xE6\xB2L\xD6\x141\x9A\xF9\x14\xA7\x96\x86\xB3H\xC3\x18\xCEb\xA9\x9BE\xF0\b\xE5\x9B#\x0F\x12\xD0\xD7R(\x9D0\xDB\xBE\x83\x8C*\eq\xE9'\xF2QL\xA9\xE4\xA8G\\\xB7G\xF0\x99]\x89m\x10\x8B\b\xEAY<`\x8F\a\xD8\ri\x19\\\xCDTk\x15e\xEF\x93\xCA\x98\x94j\xE7wS1\xB0\xC5\xBB/\x8C\xA6m<}\xA4or\x9Agi\xE2\xB5e\x92i\x18\xF7yR\xA3HSQ\x9D\xA8b\xF0t\x80\x18F\xDC\xA7%\xAD\x01Z#\x83A\nN\x8F\xDB\xC4\xCA\xDF\x9E(\xE2B)2\xBD\x99d1\xB7h\xFF\xEA\xAAm\x01\xBC=c\xCCp\xE0Q\x04'\x03`K$\xA9RK\x00\x1Fl\xA0t\r\xC9\x87 \xC4P\x9E\x03\xBDc\xAD\x13(\xBC\xA6\x99M`\xF2P\x9BK\x95P1\xA1\x98\xE3\xCD-\f5s\x93\xA4p\xCC\x18\x1E\x8A\x19\x9D\x94\x9AtE\xB1\xF8EN\xA2\e0uk\xECi\xB8\xC7\xD3\x9BYk\x12\xA2\xA3\xBB\x9D\xF7\xA7\xA5\xCD\r`\x18\vtG'K\x15v\xFE&G\xA3\xA8\xB1\xDF\xBB\xD2\xAF\xC0\b\xE0]f.\x01\x0E\xAE\xD3\xB4\x81\xBC\xE8D\x93t\xCF\xB3$\xE8b_;\xDDid%\xA4\x9F\x89\x8B\n`\xD4F \x1D\e=\xFE\xB7\xB8[%\x01\xC3I\x0F\xFE\xEF\xCF\xFD\x9C\xC3y\xCEj\xDF\xD48\xC7\xE9\x9E&\xBF\x99\xF8\xAE\x98\xAC\xAA\xC7Y\x9B\xD9\x9Eol\xDF\xE7\xB5\xC4\x7F\xB9\xC4_\x06\x16#\x10",
|
@@ -0,0 +1,35 @@
|
|
1
|
+
<%= program :name %>
|
2
|
+
|
3
|
+
<%= program :description %>
|
4
|
+
|
5
|
+
<%= "Commands:#{@default_command ? ' (* default)' : '' }" %>
|
6
|
+
<% for name, command in @commands.sort -%>
|
7
|
+
<% unless alias? name -%>
|
8
|
+
<%= "%-#{max_command_length}s #{@default_command.nil? ? '' : (command.name == @default_command.to_s ? '* ' : ' ') }%s" % [command.name, command.summary || command.description] %>
|
9
|
+
<% end -%>
|
10
|
+
<% end -%>
|
11
|
+
<% unless @aliases.empty? %>
|
12
|
+
Aliases:
|
13
|
+
<% for alias_name, args in @aliases.sort -%>
|
14
|
+
<%= "%-#{max_aliases_length}s %s %s" % [alias_name, command(alias_name).name, args.join(' ')] %>
|
15
|
+
<% end -%>
|
16
|
+
<% end %>
|
17
|
+
<% unless @options.empty? -%>
|
18
|
+
Global Options:
|
19
|
+
<% for option in @options -%>
|
20
|
+
<%= "%-20s %s" % [option[:switches].join(', '), option[:description]] %>
|
21
|
+
<% end -%>
|
22
|
+
<% end -%>
|
23
|
+
<% default_command_options = @commands.values.find {|c| c.name == @default_command.to_s }&.options || [] %>
|
24
|
+
<% unless default_command_options.empty? %>
|
25
|
+
<%= "Options for #{@default_command}:" %>
|
26
|
+
<% for option in default_command_options -%>
|
27
|
+
<%= "%-20s %s" % [option[:switches].join(', '), option[:description]] %>
|
28
|
+
<% end -%>
|
29
|
+
<% end -%>
|
30
|
+
<% if program :help -%>
|
31
|
+
<% for title, body in program(:help) %>
|
32
|
+
<%= title %>:
|
33
|
+
<%= body %>
|
34
|
+
<% end %>
|
35
|
+
<% end -%>
|
@@ -0,0 +1,16 @@
|
|
1
|
+
require 'commander'
|
2
|
+
|
3
|
+
module FastlaneCore
|
4
|
+
class HelpFormatter < ::Commander::HelpFormatter::TerminalCompact
|
5
|
+
def template(name)
|
6
|
+
# fastlane only customizes the global command help
|
7
|
+
return super unless name == :help
|
8
|
+
|
9
|
+
if Gem::Version.new(RUBY_VERSION) < Gem::Version.new('2.6')
|
10
|
+
ERB.new(File.read(File.join(File.dirname(__FILE__), "help.erb")), nil, '-')
|
11
|
+
else
|
12
|
+
ERB.new(File.read(File.join(File.dirname(__FILE__), "help.erb")), trim_mode: '-')
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
@@ -145,7 +145,10 @@ module FastlaneCore
|
|
145
145
|
def password(message)
|
146
146
|
verify_interactive!(message)
|
147
147
|
|
148
|
-
ask("#{format_string}#{message.to_s.yellow}")
|
148
|
+
ask("#{format_string}#{message.to_s.yellow}") do |q|
|
149
|
+
q.whitespace = :chomp
|
150
|
+
q.echo = "*"
|
151
|
+
end
|
149
152
|
end
|
150
153
|
|
151
154
|
private
|
@@ -1,5 +1,6 @@
|
|
1
1
|
require 'commander'
|
2
2
|
require 'fastlane/version'
|
3
|
+
require 'fastlane_core/ui/help_formatter'
|
3
4
|
require 'fastlane_core/globals'
|
4
5
|
require 'fastlane_core/configuration/configuration'
|
5
6
|
|
@@ -27,7 +28,7 @@ module Frameit
|
|
27
28
|
program :help, 'Author', 'Felix Krause <frameit@krausefx.com>'
|
28
29
|
program :help, 'Website', 'https://fastlane.tools'
|
29
30
|
program :help, 'Documentation', 'https://docs.fastlane.tools/actions/frameit/'
|
30
|
-
program :help_formatter,
|
31
|
+
program :help_formatter, FastlaneCore::HelpFormatter
|
31
32
|
|
32
33
|
global_option('--verbose') { FastlaneCore::Globals.verbose = true }
|
33
34
|
global_option('--env STRING[,STRING2]', String, 'Add environment(s) to use with `dotenv`')
|
@@ -121,12 +121,12 @@ module Frameit
|
|
121
121
|
|
122
122
|
def self.supported_color?(value)
|
123
123
|
return false if value.nil?
|
124
|
-
Color.all_colors.any?
|
124
|
+
Color.all_colors.any?(value)
|
125
125
|
end
|
126
126
|
|
127
127
|
def self.supported_platform?(value)
|
128
128
|
return false if value.nil?
|
129
|
-
Platform.all_platforms.any?
|
129
|
+
Platform.all_platforms.any?(value)
|
130
130
|
end
|
131
131
|
|
132
132
|
def self.supported_device?(value)
|
@@ -71,8 +71,9 @@ module Frameit
|
|
71
71
|
def download_file(path, txt: "file")
|
72
72
|
require 'uri'
|
73
73
|
require 'excon'
|
74
|
+
require 'addressable/uri'
|
74
75
|
|
75
|
-
url = File.join(HOST_URL, Frameit.frames_version, URI.
|
76
|
+
url = File.join(HOST_URL, Frameit.frames_version, Addressable::URI.encode(path))
|
76
77
|
UI.message("Downloading #{txt} from '#{url}' ...")
|
77
78
|
body = Excon.get(url).body
|
78
79
|
raise body if body.include?("<Error>")
|
@@ -17,8 +17,8 @@ module Gym
|
|
17
17
|
final_mapping = (primary_mapping || {}).dup # for verbose output at the end of the method
|
18
18
|
secondary_mapping ||= self.detect_project_profile_mapping # default to Xcode project
|
19
19
|
|
20
|
-
final_mapping =
|
21
|
-
secondary_mapping =
|
20
|
+
final_mapping = final_mapping.transform_keys(&:to_sym)
|
21
|
+
secondary_mapping = secondary_mapping.transform_keys(&:to_sym)
|
22
22
|
|
23
23
|
# Now it's time to merge the (potentially) existing mapping
|
24
24
|
# (e.g. coming from `provisioningProfiles` of the `export_options` or from previous match calls)
|
@@ -1,6 +1,7 @@
|
|
1
1
|
require 'commander'
|
2
2
|
|
3
3
|
require 'fastlane_core/configuration/configuration'
|
4
|
+
require 'fastlane_core/ui/help_formatter'
|
4
5
|
require_relative 'module'
|
5
6
|
require_relative 'manager'
|
6
7
|
require_relative 'options'
|
@@ -28,7 +29,7 @@ module Gym
|
|
28
29
|
program :help, "Author", "Felix Krause <gym@krausefx.com>"
|
29
30
|
program :help, "Website", "https://fastlane.tools"
|
30
31
|
program :help, "Documentation", "https://docs.fastlane.tools/actions/gym/"
|
31
|
-
program :help_formatter,
|
32
|
+
program :help_formatter, FastlaneCore::HelpFormatter
|
32
33
|
|
33
34
|
global_option("--verbose") { FastlaneCore::Globals.verbose = true }
|
34
35
|
|
@@ -4,6 +4,7 @@
|
|
4
4
|
# because of
|
5
5
|
# `incompatible encoding regexp match (UTF-8 regexp with ASCII-8BIT string) (Encoding::CompatibilityError)`
|
6
6
|
|
7
|
+
require 'addressable/uri'
|
7
8
|
require 'tempfile'
|
8
9
|
require 'xcodeproj'
|
9
10
|
|
@@ -154,12 +155,12 @@ module Gym
|
|
154
155
|
|
155
156
|
def normalize_export_options(hash)
|
156
157
|
# Normalize some values
|
157
|
-
hash[:onDemandResourcesAssetPacksBaseURL] = URI.
|
158
|
+
hash[:onDemandResourcesAssetPacksBaseURL] = Addressable::URI.encode(hash[:onDemandResourcesAssetPacksBaseURL]) if hash[:onDemandResourcesAssetPacksBaseURL]
|
158
159
|
if hash[:manifest]
|
159
|
-
hash[:manifest][:appURL] = URI.
|
160
|
-
hash[:manifest][:displayImageURL] = URI.
|
161
|
-
hash[:manifest][:fullSizeImageURL] = URI.
|
162
|
-
hash[:manifest][:assetPackManifestURL] = URI.
|
160
|
+
hash[:manifest][:appURL] = Addressable::URI.encode(hash[:manifest][:appURL]) if hash[:manifest][:appURL]
|
161
|
+
hash[:manifest][:displayImageURL] = Addressable::URI.encode(hash[:manifest][:displayImageURL]) if hash[:manifest][:displayImageURL]
|
162
|
+
hash[:manifest][:fullSizeImageURL] = Addressable::URI.encode(hash[:manifest][:fullSizeImageURL]) if hash[:manifest][:fullSizeImageURL]
|
163
|
+
hash[:manifest][:assetPackManifestURL] = Addressable::URI.encode(hash[:manifest][:assetPackManifestURL]) if hash[:manifest][:assetPackManifestURL]
|
163
164
|
end
|
164
165
|
hash
|
165
166
|
end
|
data/gym/lib/gym/runner.rb
CHANGED
@@ -243,8 +243,12 @@ module Gym
|
|
243
243
|
# Moves over the binary and dsym file to the output directory
|
244
244
|
# @return (String) The path to the resulting pkg file
|
245
245
|
def move_pkg
|
246
|
-
FileUtils.mv(PackageCommandGenerator.binary_path, File.expand_path(Gym.config[:output_directory]), force: true)
|
247
246
|
binary_path = File.expand_path(File.join(Gym.config[:output_directory], File.basename(PackageCommandGenerator.binary_path)))
|
247
|
+
if File.exist?(binary_path)
|
248
|
+
UI.important(" Removing #{File.basename(binary_path)}") if FastlaneCore::Globals.verbose?
|
249
|
+
FileUtils.rm_rf(binary_path)
|
250
|
+
end
|
251
|
+
FileUtils.mv(PackageCommandGenerator.binary_path, File.expand_path(Gym.config[:output_directory]), force: true)
|
248
252
|
|
249
253
|
UI.success("Successfully exported and signed the pkg file:")
|
250
254
|
UI.message(binary_path)
|
@@ -1,6 +1,7 @@
|
|
1
1
|
require 'commander'
|
2
2
|
|
3
3
|
require 'fastlane_core/configuration/configuration'
|
4
|
+
require 'fastlane_core/ui/help_formatter'
|
4
5
|
|
5
6
|
require_relative 'nuke'
|
6
7
|
require_relative 'change_password'
|
@@ -32,7 +33,7 @@ module Match
|
|
32
33
|
program :help, 'Author', 'Felix Krause <match@krausefx.com>'
|
33
34
|
program :help, 'Website', 'https://fastlane.tools'
|
34
35
|
program :help, 'Documentation', 'https://docs.fastlane.tools/actions/match/'
|
35
|
-
program :help_formatter,
|
36
|
+
program :help_formatter, FastlaneCore::HelpFormatter
|
36
37
|
|
37
38
|
global_option('--verbose') { FastlaneCore::Globals.verbose = true }
|
38
39
|
global_option('--env STRING[,STRING2]', String, 'Add environment(s) to use with `dotenv`')
|
@@ -2,6 +2,7 @@ require 'commander'
|
|
2
2
|
|
3
3
|
require 'fastlane/version'
|
4
4
|
require 'fastlane_core/configuration/configuration'
|
5
|
+
require 'fastlane_core/ui/help_formatter'
|
5
6
|
require_relative 'options'
|
6
7
|
require_relative 'manager'
|
7
8
|
|
@@ -22,7 +23,7 @@ module PEM
|
|
22
23
|
program :help, 'Author', 'Felix Krause <pem@krausefx.com>'
|
23
24
|
program :help, 'Website', 'https://fastlane.tools'
|
24
25
|
program :help, 'Documentation', 'https://docs.fastlane.tools/actions/pem/'
|
25
|
-
program :help_formatter,
|
26
|
+
program :help_formatter, FastlaneCore::HelpFormatter
|
26
27
|
|
27
28
|
global_option('--verbose') { FastlaneCore::Globals.verbose = true }
|
28
29
|
global_option('--env STRING[,STRING2]', String, 'Add environment(s) to use with `dotenv`')
|
@@ -447,7 +447,7 @@ module Pilot
|
|
447
447
|
end
|
448
448
|
|
449
449
|
def update_review_detail(build, info)
|
450
|
-
info = info.
|
450
|
+
info = info.transform_keys(&:to_sym)
|
451
451
|
|
452
452
|
attributes = {}
|
453
453
|
attributes[:contactEmail] = info[:contact_email] if info.key?(:contact_email)
|
@@ -463,7 +463,7 @@ module Pilot
|
|
463
463
|
end
|
464
464
|
|
465
465
|
def update_localized_app_review(build, info_by_lang, default_info: nil)
|
466
|
-
info_by_lang = info_by_lang.
|
466
|
+
info_by_lang = info_by_lang.transform_keys(&:to_sym)
|
467
467
|
|
468
468
|
if default_info
|
469
469
|
info_by_lang.delete(:default)
|
@@ -509,7 +509,7 @@ module Pilot
|
|
509
509
|
end
|
510
510
|
|
511
511
|
def update_localized_build_review(build, info_by_lang, default_info: nil)
|
512
|
-
info_by_lang = info_by_lang.
|
512
|
+
info_by_lang = info_by_lang.transform_keys(&:to_sym)
|
513
513
|
|
514
514
|
if default_info
|
515
515
|
info_by_lang.delete(:default)
|
@@ -1,6 +1,7 @@
|
|
1
1
|
require "commander"
|
2
2
|
|
3
3
|
require 'fastlane_core/configuration/configuration'
|
4
|
+
require 'fastlane_core/ui/help_formatter'
|
4
5
|
require_relative 'module'
|
5
6
|
require_relative 'tester_importer'
|
6
7
|
require_relative 'tester_exporter'
|
@@ -51,7 +52,7 @@ module Pilot
|
|
51
52
|
program :help, "Author", "Felix Krause <pilot@krausefx.com>"
|
52
53
|
program :help, "Website", "https://fastlane.tools"
|
53
54
|
program :help, "Documentation", "https://docs.fastlane.tools/actions/pilot/"
|
54
|
-
program :help_formatter,
|
55
|
+
program :help_formatter, FastlaneCore::HelpFormatter
|
55
56
|
|
56
57
|
global_option("--verbose") { FastlaneCore::Globals.verbose = true }
|
57
58
|
|
data/pilot/lib/pilot/options.rb
CHANGED
@@ -269,12 +269,12 @@ module Pilot
|
|
269
269
|
verify_block: proc do |value|
|
270
270
|
ENV["FASTLANE_TEAM_ID"] = value.to_s
|
271
271
|
end),
|
272
|
-
# rubocop:disable
|
272
|
+
# rubocop:disable Layout/LineLength
|
273
273
|
FastlaneCore::ConfigItem.new(key: :itc_provider,
|
274
274
|
env_name: "PILOT_ITC_PROVIDER",
|
275
275
|
description: "The provider short name to be used with the iTMSTransporter to identify your team. This value will override the automatically detected provider short name. To get provider short name run `pathToXcode.app/Contents/Applications/Application\\ Loader.app/Contents/itms/bin/iTMSTransporter -m provider -u 'USERNAME' -p 'PASSWORD' -account_type itunes_connect -v off`. The short names of providers should be listed in the second column",
|
276
276
|
optional: true),
|
277
|
-
# rubocop:enable
|
277
|
+
# rubocop:enable Layout/LineLength
|
278
278
|
|
279
279
|
# waiting and uploaded build
|
280
280
|
FastlaneCore::ConfigItem.new(key: :wait_processing_interval,
|
@@ -4,6 +4,7 @@ require "fastlane_core/configuration/commander_generator"
|
|
4
4
|
require "fastlane_core/configuration/configuration"
|
5
5
|
require "fastlane_core/helper"
|
6
6
|
require "fastlane/version"
|
7
|
+
require 'fastlane_core/ui/help_formatter'
|
7
8
|
|
8
9
|
require_relative 'module'
|
9
10
|
require_relative 'options'
|
@@ -26,7 +27,7 @@ module Precheck
|
|
26
27
|
program :help, "Author", "Joshua Liebowitz <taquitos@gmail.com>, @taquitos"
|
27
28
|
program :help, "Website", "https://fastlane.tools"
|
28
29
|
program :help, "Documentation", "https://docs.fastlane.tools/actions/precheck/"
|
29
|
-
program :help_formatter,
|
30
|
+
program :help_formatter, FastlaneCore::HelpFormatter
|
30
31
|
|
31
32
|
global_option("--verbose") { FastlaneCore::Globals.verbose = true }
|
32
33
|
|
@@ -1,6 +1,7 @@
|
|
1
1
|
require 'commander'
|
2
2
|
|
3
3
|
require 'fastlane/version'
|
4
|
+
require 'fastlane_core/ui/help_formatter'
|
4
5
|
require 'fastlane_core/configuration/config_item'
|
5
6
|
require_relative 'module'
|
6
7
|
require_relative 'manager'
|
@@ -23,7 +24,7 @@ module Produce
|
|
23
24
|
program :help, 'Author', 'Felix Krause <produce@krausefx.com>'
|
24
25
|
program :help, 'Website', 'https://fastlane.tools'
|
25
26
|
program :help, 'Documentation', 'https://docs.fastlane.tools/actions/produce/'
|
26
|
-
program :help_formatter,
|
27
|
+
program :help_formatter, FastlaneCore::HelpFormatter
|
27
28
|
|
28
29
|
global_option('--verbose') { FastlaneCore::Globals.verbose = true }
|
29
30
|
global_option('--env STRING[,STRING2]', String, 'Add environment(s) to use with `dotenv`')
|
@@ -1,6 +1,7 @@
|
|
1
1
|
require 'commander'
|
2
2
|
|
3
3
|
require 'fastlane_core/configuration/configuration'
|
4
|
+
require 'fastlane_core/ui/help_formatter'
|
4
5
|
require_relative 'module'
|
5
6
|
require_relative 'manager'
|
6
7
|
require_relative 'options'
|
@@ -28,7 +29,7 @@ module Scan
|
|
28
29
|
program :help, "Author", "Felix Krause <scan@krausefx.com>"
|
29
30
|
program :help, "Website", "https://fastlane.tools"
|
30
31
|
program :help, "Documentation", "https://docs.fastlane.tools/actions/scan/"
|
31
|
-
program :help_formatter,
|
32
|
+
program :help_formatter, FastlaneCore::HelpFormatter
|
32
33
|
|
33
34
|
global_option("--verbose") { FastlaneCore::Globals.verbose = true }
|
34
35
|
|
data/scan/lib/scan/runner.rb
CHANGED
@@ -55,6 +55,8 @@ module Scan
|
|
55
55
|
end
|
56
56
|
|
57
57
|
def execute(retries: 0)
|
58
|
+
Scan.cache[:retry_attempt] = Scan.config[:number_of_retries] - retries
|
59
|
+
|
58
60
|
command = @test_command_generator.generate
|
59
61
|
|
60
62
|
prefix_hash = [
|
@@ -120,7 +122,7 @@ module Scan
|
|
120
122
|
suites = failing_tests.split(/(?=\n\s+[\w\s]+:\n)/)
|
121
123
|
|
122
124
|
suites.each do |suite|
|
123
|
-
suite_name = suite.match(/\s*([\w\s]+):/).captures.first
|
125
|
+
suite_name = suite.match(/\s*([\w\s\S]+):/).captures.first
|
124
126
|
|
125
127
|
test_cases = suite.split(":\n").fetch(1, []).split("\n").each
|
126
128
|
.select { |line| line.match?(/^\s+/) }
|