marp | theme | class |
---|---|---|
true |
uncover |
invert |
$ cd ios
$ gem install bundler
$ bundle init
$ echo "gem 'fastlane'" >> Gemfile
$ bundle install
# ou simplesmente (nΓ£o recomendado)
# $ gem install fastlane
alias lane="bundle exec fastlane"
- Automatically create App ID on Apple Developer Portal
- Automatically create App on Apple Store Connect
- Configured Appfile
- Sample Fastfile
Appfile
app_identifier("io.github.mugbug.fastlaneDemo")
apple_id("[email protected]")
itc_team_id("464910") # App Store Connect Team ID
team_id("JZ2QTNWLCN") # Developer Portal Team ID
Fastfile
desc "Push a new beta build to TestFlight"
lane :beta do
build_app(workspace: "Runner.xcworkspace", scheme: "Runner")
upload_to_testflight
end
** ARCHIVE FAILED **
β error: "Runner" requires a provisioning profile. Select a provisioning profile in the Signing & Capabilities editor. (in target 'Runner' from project 'Runner')
Uncheck Automatically manage signing =]
Private keys + certificates => Github private repo
- Easy to setup new machines with only the repo access
- No need to create a profile for each team member
- Secure π
- cert will make sure you have a valid certificate and its private key installed on the local machine
- sigh will make sure you have a valid provisioning profile installed locally, that matches the installed certificate
To get started, create a new private Git repo and run:
# Repo where profiles and certs will be stored
git_url("[email protected]:mugbug/fastlane-demo-certs.git")
storage_mode("git")
# Apple Developer Portal username
username("[email protected]")
Creating new certificate and profile
# Fastfile
desc "Download provisioning profiles"
lane :rematch do
match(
type: "appstore", # or development/adhoc
# git_branch: "my-app",
username: "[email protected]",
force: true, # enable to always refresh profiles
# readonly: true, # enable to prevent refreshes
)
end
- Generate new certificate and import to local machine
- Create new provisioning profile for Bundle ID
- Setup Passphrase for Match storage
- Encrypt and upload certificate and profile to git repo
- Full control over what happens
- Share a single code signing identity across the team
- Automatically repair broken and expired credentials
- Clean setup in minutes
- It just worksβ’
Sounds good, now let's try this again:
- Version bump
- Screenshots
- Release notes
- Firebase App Distribution
- Slack message
- Integrate with any CI tool
- β -> beyond! π