Buat Build iOS Otomatis dengan GitHub Aksi menggunakan Match
Mengatur CI/CD untuk aplikasi Capacitor dapat kompleks dan memakan waktu lama. Berikut ini yang perlu Anda ketahui:
Dianjurkan untuk Build Baru: Gunakan Capgo Build
Sekarang kami merekomendasikan menggunakan Capgo Build dengan Capgo CLI untuk build native Capacitor. Petunjuk Fastlane Match ini dipertahankan untuk tim yang memelihara pipeline aksi GitHub yang sudah ada, tetapi build iOS baru harus menggunakan Capgo CLI sehingga Anda tidak perlu memelihara repositori Fastlane, Match, runner Xcode, sertifikat, dan skrip unggah sendiri.
Capgo Build untuk CI/CD oleh Capgo
Lepaskan diri dari pemeliharaan Fastlane Match, runner Xcode, sertifikat, profil pengaturan, dan skrip unggah. Capgo Build melakukan build iOS yang ditandatangani secara native dari pipeline CI/CD yang sudah ada Anda:
- Bekerja dengan pipeline Anda: Aktifkan Capgo Build dari GitHub Actions, GitLab CI, Jenkins, atau skrip lokal setelah pembangunan web Anda
npx cap sync. - Tanda Tangan dari Rahasia CI: Simpan kunci App Store Connect, sertifikat, profil pengaturan, kata sandi, dan ID tim di rahasia CI Anda sendiri.
- Tidak ada perawatan runner asli: Capgo Build menyediakan lingkungan pembangunan Apple yang dipelihara, sehingga Anda tidak perlu mengelola runner macOS, gambar Xcode, Fastlane, atau repositori Match.
- Artefak dan pengiriman: Unduh artefak yang ditandatangani untuk QA atau kirimkan rilis pembangunan melalui Capgo CLI.
Harga
- Rencana Capgo mulai dari $12/bulan
- Menggunakan pembaruan OTA dan sekitar 15 pembangunan asli per bulan
- Menit tambahan pembangunan akan dikenakan biaya per menit melalui kredit
Konfigurasi Capgo Build di CI/CD
Petunjuk Pengaturan Manual
Berikut adalah langkah-langkah yang perlu Anda lakukan:
Pengiriman Terus-menerus untuk iOS menggunakan Fastlane dan GitHub Aksi menggunakan match
Persyaratan
Sebelum melanjutkan dengan tutorial…
- Pastikan Anda telah menginstal Fastlane di mesin pengembangan Anda. Anggota program pengembang iOS.
- Ingin membaca 😆…
- Sebuah tim banyak dev, jika tidak, kami merekomendasikan untuk menggunakan
- fastlane cert Aksi menggunakan match untuk alur kerja yang lebih sederhana.
Penting tentang harga

https://github.com/features/actions
Jasa ini gratis hingga batas tertentu, tergantung pada mesin yang dipilih.
Kita akan menggunakan sebuah macOS mesin, Anda dapat melihat harga dan batasan (harga pada saat pembuatan tutorial, mereka mungkin mengalami perubahan di masa depan)
🔴 Setelah diingatkan tentang persyaratan dan harga, jika Anda suka, kita melanjutkan…
📣 Dalam postingan ini kita asumsikan bahwa kita telah membuat aplikasi di iTunes connect, kita memiliki sertifikat dari ekosistem Apple, semuanya akan dicopy oleh Fastlane!
Mari kita mulai menjelajahi!
Langkah-langkah yang perlu diikuti dalam postingan ini
- Menggunakan App Store Connect API dengan Fastlane Match
- Persyaratan
- Membuat Kunci App Store Connect API
- Menggunakan Kunci App Store Connect API
- Salin File Fastlane
- Konfigurasi Fastlane match
1. Menggunakan App Store Connect API dengan Fastlane Match
Mulai Februari 2021, verifikasi dua faktor atau verifikasi dua langkah diperlukan untuk semua pengguna untuk masuk ke App Store Connect. Layer keamanan tambahan untuk ID Apple Anda membantu memastikan bahwa Anda adalah satu-satunya orang yang dapat mengakses akun Anda.
Dari Dukungan Apple
Mulai menggunakan match memerlukan Anda untuk membatalkan sertifikat yang ada. Tapi jangan khawatir, Anda akan mendapatkan yang baru secara langsung.
Persyaratan
To dapat menggunakan App Store Connect API, Fastlane memerlukan tiga hal.
- ID Penerbit.
- ID Kunci.
- File Kunci atau Konten Kunci.
Membuat Kunci App Store Connect API
Untuk menghasilkan kunci, Anda harus memiliki izin Admin di App Store Connect. Jika Anda tidak memiliki izin tersebut, Anda dapat mengarahkan orang yang relevan ke artikel ini dan mengikuti instruksi berikut.
1 — Masuk ke App Store Connect.
2 — Pilih Pengguna dan Akses.

3 — Pilih tab Integrasi.

4 — Klik Generate API Key atau tombol (+) Tambah.

5 — Masukkan nama untuk kunci. Nama hanya untuk referensi Anda dan bukan bagian dari kunci itu sendiri.

6 — Di bawah Akses, pilih peran untuk kunci. Peran yang berlaku untuk kunci sama dengan peran yang berlaku untuk pengguna di tim Anda. Lihat izin akses. Kami merekomendasikan untuk memilih Manajer Aplikasi.
7 — Klik Generate.
Sebuah kunci API tidak dapat di batasi aksesnya hanya untuk aplikasi tertentu.
Nama kunci baru, ID kunci, tautan download, dan informasi lainnya muncul di halaman.

Anda dapat mendapatkan semua tiga informasi yang diperlukan di sini.
<1> ID Masalah.
<2> ID Kunci.
<3> Klik "Unduh Kunci API" untuk mengunduh kunci pribadi Anda API. Tautan download hanya muncul jika kunci pribadi belum diunduh. Apple tidak menyimpan salinan kunci pribadi. Jadi, Anda hanya dapat mengunduhnya sekali.
🔴 Simpan kunci pribadi Anda di tempat yang aman. Anda tidak boleh berbagi kunci, menyimpan kunci di repositori code, atau termasuk kunci di sisi klien code.
Menggunakan Kunci App Store Connect API
File Kunci API (file p8 yang Anda download), ID kunci, dan ID penggung adalah yang diperlukan untuk membuat token JWT untuk otorisasi. Ada beberapa cara bahwa informasi ini dapat diinputkan ke Fastlane menggunakan aksi baru Fastlane, app_store_connect_api_key Anda dapat mengetahui cara lainnya di Dokumentasi Fastlane. Saya menunjukkan metode ini karena saya pikir ini adalah cara termudah untuk bekerja dengan CI yang paling umum, di mana Anda dapat menetapkan variabel lingkungan.
Sekarang kita dapat mengelola Fastlane dengan kunci App Store Connect API yang luar biasa!
2. Salin file Fastlane
Fastlane adalah sebuah library Ruby yang dibuat untuk mengotomatisasi tugas pengembangan mobile yang umum. Dengan menggunakan Fastlane, Anda dapat mengonfigurasi jalur
lanes
default_platform(:ios)
DEVELOPER_APP_IDENTIFIER = ENV["DEVELOPER_APP_IDENTIFIER"]
DEVELOPER_APP_ID = ENV["DEVELOPER_APP_ID"]
PROVISIONING_PROFILE_SPECIFIER = ENV["PROVISIONING_PROFILE_SPECIFIER"]
TEMP_KEYCHAIN_USER = ENV["TEMP_KEYCHAIN_USER"]
TEMP_KEYCHAIN_PASSWORD = ENV["TEMP_KEYCHAIN_PASSWORD"]
APPLE_ISSUER_ID = ENV["APPLE_ISSUER_ID"]
APPLE_KEY_ID = ENV["APPLE_KEY_ID"]
APPLE_KEY_CONTENT = ENV["APPLE_KEY_CONTENT"]
GIT_USERNAME = ENV["GIT_USERNAME"]
GIT_TOKEN = ENV["GIT_TOKEN"]
def delete_temp_keychain(name)
delete_keychain(
name: name
) if File.exist? File.expand_path("~/Library/Keychains/#{name}-db")
end
def create_temp_keychain(name, password)
create_keychain(
name: name,
password: password,
unlock: false,
timeout: 0
)
end
def ensure_temp_keychain(name, password)
delete_temp_keychain(name)
create_temp_keychain(name, password)
end
platform :ios do
lane :build do
build_app(
configuration: "Release",
workspace: "./ios/App/App.xcworkspace",
scheme: "App",
export_method: "app-store",
export_options: {
provisioningProfiles: {
DEVELOPER_APP_ID => "#{PROVISIONING_PROFILE_SPECIFIER}"
}
}
)
end
lane :refresh_profiles do
match(
type: "development",
force: true)
match(
type: "adhoc",
force: true)
end
desc "Register new device"
lane :register_new_device do |options|
device_name = prompt(text: "Enter the device name: ")
device_udid = prompt(text: "Enter the device UDID: ")
device_hash = {}
device_hash[device_name] = device_udid
register_devices(
devices: device_hash
)
refresh_profiles
end
lane :closed_beta do
keychain_name = TEMP_KEYCHAIN_USER
keychain_password = TEMP_KEYCHAIN_PASSWORD
ensure_temp_keychain(keychain_name, keychain_password)
api_key = app_store_connect_api_key(
key_id: APPLE_KEY_ID,
issuer_id: APPLE_ISSUER_ID,
key_content: APPLE_KEY_CONTENT,
duration: 1200,
in_house: false
)
match(
type: 'appstore',
git_basic_authorization: Base64.strict_encode64("#{GIT_USERNAME}:#{GIT_TOKEN}"),
readonly: true,
keychain_name: keychain_name,
keychain_password: keychain_password,
api_key: api_key
)
gym(
configuration: "Release",
workspace: "./ios/App/App.xcworkspace",
scheme: "App",
export_method: "app-store",
export_options: {
provisioningProfiles: {
DEVELOPER_APP_ID => "#{PROVISIONING_PROFILE_SPECIFIER}"
}
}
)
pilot(
apple_id: "#{DEVELOPER_APP_ID}",
app_identifier: "#{DEVELOPER_APP_IDENTIFIER}",
skip_waiting_for_build_processing: true,
skip_submission: true,
distribute_external: false,
notify_external_testers: false,
ipa: "./App.ipa"
)
delete_temp_keychain(keychain_name)
end
lane :submit_review do
version = ''
Dir.chdir("..") do
file = File.read("package.json")
data = JSON.parse(file)
version = data["version"]
end
deliver(
app_version: version,
submit_for_review: true,
automatic_release: true,
force: true, # Skip HTMl report verification
skip_metadata: false,
skip_screenshots: false,
skip_binary_upload: true
)
end
end
yang mengumpulkan serangkaian
app_identifier(ENV["DEVELOPER_APP_IDENTIFIER"])
apple_id(ENV["FASTLANE_APPLE_ID"])
itc_team_id(ENV["APP_STORE_CONNECT_TEAM_ID"])
team_id(ENV["DEVELOPER_PORTAL_TEAM_ID"])
actions
yang melakukan tugas yang biasanya Anda lakukan menggunakan Android Studio. Anda dapat melakukan banyak hal dengan Fastlane, tetapi untuk tujuan tutorial ini, kita akan menggunakan hanya beberapa aksi inti. Buat folder Fastlane di root proyek Anda dan salin file berikut: Fastfile is a new approach to iOS’s code signing. Fastlane match makes it easy for teams to manage the required certificates and provisioning profiles for your iOS apps.
Konfigurasi Fastlane match certificates, for example on your GitHub personal account or organization.
Menginisialisasi Fastlane match untuk aplikasi iOS Anda.
fastlane match init
Lalu pilih opsi #1 (Penyimpanan Git).
[01:00:00]: fastlane match supports multiple storage modes, please select the one you want to use:1. git2. google_cloud3. s3?
Menetapkan URL repositori yang baru saja dibuat.
[01:00:00]: Please create a new, private git repository to store the certificates and profiles there[01:00:00]: URL of the Git Repo: <YOUR_CERTIFICATES_REPO_URL>
Sekarang Anda memiliki di folder Fastlane sebuah file bernama Matchfile dan
_git_url_harus diset ke URL HTTPS repositori sertifikat. Jika Anda ingin menggunakan SSH, Anda dapat melakukannya, tetapi itu memerlukan langkah tambahan.
# ios/Matchfilegit_url("https://github.com/gitusername/certificates")storage_mode("git")type("appstore")
Selanjutnya, kita akan mengenerate sertifikat dan meminta Anda untuk memasukkan kreditensi Anda ketika diminta dengan Fastlane Match.
Anda akan diminta untuk memasukkan kata sandi. Ingatlah dengan benar karena kata sandi tersebut akan digunakan oleh GitHub Actions untuk mengenkripsi repositori sertifikat Anda.
fastlane match appstore
Jika semuanya berjalan lancar, Anda seharusnya melihat sesuatu seperti itu:
[01:40:52]: All required keys, certificates and provisioning profiles are installed 🙌
Jika Anda mengalami masalah dengan GitHub dan hak akses yang diperlukan, mungkin Anda dapat membaca postingan ini akan membantu Anda untuk menghasilkan token autentikasi untuk git.
Sertifikat dan profil pengaturan yang dihasilkan diunggah ke sumber daya repositori sertifikat

Terakhir, buka aplikasi project di Xcode, dan perbarui profil pengaturan untuk konfigurasi rilis aplikasi Anda.

Beberapa hal yang perlu diperhatikan 💡
MATCH
Untuk CI/CD untuk mengimport sertifikat dan profil pengaturan, perlu memiliki akses ke repositori sertifikat. Anda dapat melakukannya dengan menghasilkan token akses pribadi (harus digunakan sebelumnya) yang memiliki ruang lingkup untuk mengakses atau membaca repositori pribadi.
Di GitHub, buka Pengaturan → Pengaturan Pengembang → Token akses pribadi → klik Generate New Token → centang repo ruang lingkup → kemudian klik Generate token.

Anda memiliki salinan token akses pribadi yang dihasilkan. Anda akan menggunakan itu kemudian untuk variabel lingkungan GIT_TOKEN.
Lalu ganti file match yang dihasilkan di folder Fastlane dengan Matchfile
CERTIFICATE_STORE_URL = ENV["CERTIFICATE_STORE_URL"]
GIT_USERNAME = ENV["GIT_USERNAME"]
GIT_TOKEN = ENV["GIT_TOKEN"]
FASTLANE_APPLE_ID = ENV["FASTLANE_APPLE_ID"]
git_url(CERTIFICATE_STORE_URL)
storage_mode("git")
type("appstore")
git_basic_authorization(Base64.strict_encode64("#{GIT_USERNAME}:#{GIT_TOKEN}"))
username(FASTLANE_APPLE_ID)
This will be used by GitHub Actions to import the certificates and provisioning profiles. And var will be set in GitHub Secrets, instead of hard-coding them in the file.
Dan var akan ditetapkan di __CAPGO_KEEP_1__ Secrets, bukan dengan mengkodekan mereka secara keras di file.
In GitHub Actions, Di __CAPGO_KEEP_0__ Actions, Anda dikenakan biaya berdasarkan menit yang telah digunakan untuk menjalankan alur kerja CI/CD Anda. Dari pengalaman, membutuhkan sekitar 10-15 menit sebelum bangun dapat diproses di App Store Connect.
For proyek pribadi, biaya perkiraan per build bisa mencapai $0.08/min x 15 menit = $1.2, atau lebih, tergantung pada konfigurasi atau dependensi proyek Anda.
Jika Anda memiliki kekhawatiran yang sama tentang harga seperti saya untuk proyek pribadi, Anda bisa mempertahankan skip_waiting_for_build_processing ke true.
Apa yang salah? Anda harus memperbarui manual kompatibilitas aplikasi Anda di App Store Connect setelah build telah diproses, agar Anda bisa mendistribusikan build ke pengguna Anda.
Ini hanya parameter opsional untuk memperbarui jika Anda ingin menghemat menit build untuk proyek pribadi. Untuk proyek gratis, ini tidak akan menjadi masalah sama sekali. Lihat harga.
3. Konfigurasi GitHub Aksi
Konfigurasi GitHub rahasia
Pernahkah Anda bertanya-tanya dari mana nilai-nilai dari ENV berasal? Nah, itu tidak lagi rahasia – itu dari rahasia proyek Anda.

1. APP_STORE_CONNECT_TEAM_ID - ID tim Anda di App Store Connect jika Anda bergabung dengan beberapa tim.
2. DEVELOPER_APP_ID - di App Store Connect, pergi ke aplikasi → Informasi Aplikasi → Gulir ke bawah ke bagian General Information informasi aplikasi Anda dan cari Apple ID.
3. DEVELOPER_APP_IDENTIFIER - ID paket aplikasi Anda.
4. DEVELOPER_PORTAL_TEAM_ID - ID tim Portal Pengembang Anda jika Anda bergabung dengan beberapa tim.
5. FASTLANE_APPLE_ID - ID Apple atau alamat email pengembang yang Anda gunakan untuk mengelola aplikasi.
6. GIT_USERNAME & GIT_TOKEN - Nama pengguna Git Anda dan token akses pribadi Anda.
7. MATCH_PASSWORD - kata sandi yang Anda tentukan ketika menginisialisasi match, akan digunakan untuk mendekripsi sertifikat dan profil pengembangan.
8. PROVISIONING_PROFILE_SPECIFIER - match AppStore <YOUR_APP_BUNDLE_IDENTIFIER>, contoh. match AppStore com.domain.blabla.demo.
9. TEMP_KEYCHAIN_USER & TEMP_KEYCHAIN_PASSWORD - Tambahkan pengguna dan kata sandi sementara untuk alur kerja Anda.
10. APPLE_KEY_ID — App Store Connect API Kunci 🔺ID Kunci.
11. APPLE_ISSUER_ID — App Store Connect API Kunci 🔺ID Penerbit.
12. APPLE_KEY_CONTENT — App Store Connect API Kunci 🔺 File Kunci atau Konten Kunci dari .p8 periksa itu, — URL repositori dari kunci Match Anda (misal:
13. CERTIFICATE_STORE_URL https://__CAPGO_KEEP_0__.com/***/fastlane_match.git 4. Konfigurasi file alur kerja github)
Buat direktori alur kerja GitHub
5. Tambahkan pengaturan GitHub
cd .github/workflows
Di dalam folder, buatlah sebuah file bernama __CAPGO_KEEP_0__ workflow dan tambahkan kode berikut: build-upload-ios.ymlAlur kerja ini harus diaktifkan setelah setiap __CAPGO_KEEP_0__
name: Build source code on ios
on:
push:
tags:
- '*'
jobs:
build_ios:
runs-on: macOS-latest
steps:
- uses: actions/checkout@v6
- name: set Node.js
uses: actions/setup-node@v6
with:
node-version: '24'
cache: npm
- name: Install dependencies
id: install_code
run: npm ci
- name: Build
id: build_code
run: npm run build
- uses: actions/cache@v5
with:
path: ios/App/Pods
key: ${{ runner.os }}-pods-${{ hashFiles('**/Podfile.lock') }}
restore-keys: |
${{ runner.os }}-pods-
- name: Sync
id: sync_code
run: npx cap sync
- uses: ruby/setup-ruby@v1
with:
ruby-version: 2.7.2
- uses: maierj/fastlane-action@v2.3.0
env:
DEVELOPER_APP_IDENTIFIER: ${{ secrets.DEVELOPER_APP_IDENTIFIER }}
DEVELOPER_APP_ID: ${{ secrets.DEVELOPER_APP_ID }}
PROVISIONING_PROFILE_SPECIFIER: match AppStore ${{ secrets.DEVELOPER_APP_IDENTIFIER }}
TEMP_KEYCHAIN_USER: ${{ secrets.TEMP_KEYCHAIN_USER }}
TEMP_KEYCHAIN_PASSWORD: ${{ secrets.TEMP_KEYCHAIN_PASSWORD }}
APPLE_ISSUER_ID: ${{ secrets.APPLE_ISSUER_ID }}
APPLE_KEY_ID: ${{ secrets.APPLE_KEY_ID }}
APPLE_KEY_CONTENT: ${{ secrets.APPLE_KEY_CONTENT }}
CERTIFICATE_STORE_URL: https://github.com/${{ secrets.CERTIFICATE_STORE_REPO }}.git
GIT_USERNAME: ${{ secrets.GIT_USERNAME }}
GIT_TOKEN: ${{ secrets.PERSONAL_ACCESS_TOKEN }}
FASTLANE_APPLE_ID: ${{ secrets.FASTLANE_APPLE_ID }}
MATCH_USERNAME: ${{ secrets.FASTLANE_APPLE_ID }}
MATCH_PASSWORD: ${{ secrets.MATCH_PASSWORD }}
APP_STORE_CONNECT_TEAM_ID: ${{ secrets.APP_STORE_CONNECT_TEAM_ID }}
DEVELOPER_PORTAL_TEAM_ID: ${{ secrets.DEVELOPER_PORTAL_TEAM_ID }}
with:
lane: closed_beta
- name: Upload release bundle
uses: actions/upload-artifact@v2
with:
name: ios-release
path: ./App.ipa
retention-days: 60
This workflow should be triggered after each GitHub Jika Anda memerlukan otomatisasi tag, silakan lihatAutomatic build dan release dengan __CAPGO_KEEP_0__ actions Automatic build and release with GitHub actions Kemudian alur kerja ini akan menarik dependensi NodeJS Anda, menginstalnya, dan membangun aplikasi JavaScript Anda.
Setiap kali Anda mengirimkan commit baru, rilis akan dibangun di TestFlight.
Aplikasi Anda tidak perlu menggunakan Ionic, hanya __CAPGO_KEEP_0__ dasar yang wajib, dan dapat memiliki modul Cordova lama, tetapi __CAPGO_KEEP_1__ plugin JavaScript lebih disarankan.
Your App doesn’t need to use Ionic, only Capacitor base is mandatory., it can have old Cordova module, but Capacitor JS plugin should be preferred.
6. Trigger workflow
Buat Komit
Buat komit, Anda harus melihat alur kerja aktif di repository.
Aktifkan alur kerja
Push komit baru ke cabang main atau development untuk mengaktifkan alur kerja.

Setelah beberapa menit, hasil build seharusnya tersedia di dashboard App Store Connect Anda.

Bisa mengundeploy dari mesin lokal?
Ya, kamu bisa, dan itu sangat mudah.
Bayangkan kamu memiliki repositori pribadi, dan kamu telah menggunakan menit gratis dari rencana gratis dan kamu tidak ingin membayar untuk rilis baru, atau mungkin kamu lebih suka mengirimkan aplikasi secara manual.
Mari kita lakukan itu
Baik, pertama kita perlu membuat di my_project_path/fastlane jalan sebuah file yang disebut .env, hanya di jalur yang sama seperti Fastfile, agar kita bisa membuat sifat rahasia yang sama seperti yang ditemukan di ___CAPGO_KEEP_0___, yaitu a_s di bawah ini: GitHub
.env file untuk mengdeploy dari mesin lokal
Sekarang, Anda dapat pergi ke terminal dan meluncurkan Fastlane dari mesin Anda:
fastlane closed_beta
❌ Hal penting tentang .env file, karena kami lebih suka tidak mengekspos data ini, kami harus menambahkannya di .gitignore, seperti itu: ❌
fastlane/*.env
Hal ini harus berfungsi sama seperti yang terjadi dari GitHub Actions pada mesin jarak jauh tetapi di mesin lokal. 🍻

Eksekusi Terminal: $ Fastlane closed_beta
Jika Anda telah mencapai tahap ini, selamat, Anda telah memiliki proses otomatisasi yang lengkap untuk aplikasi iOS Anda dengan Fastlane dan GitHub Aksi.
Setiap kali Anda mengirimkan komit baru, rilis akan dibangun di Google Play Console, saluran beta. martin@capgo.app
martin@__CAPGO_KEEP_0__.app
Bangun di Perangkat Anda
Sambungkan perangkat Anda ke Mac Anda dan buka menu perangkat
Lalu salin identifier Anda
fastlane register_new_device
Cari identifier iOS

Jika Anda mengalami masalah
Jika Anda mengalami masalah dengan perangkat pengembang yang tidak dapat diuji, dll. Biasanya masalah ini dapat diatasi dengan cara:
Ada perintah ajaib yang dapat menyelamatkan Anda:
fastlane match nuke development
fastlane match development
Lalu : Bersihkan proyek dengan menekan Shift(⇧)+Command(⌘)+K atau memilih Product > Bersihkan (mungkin terlabel sebagai “Bersihkan Folder Pembangunan”)
Lalu coba jalankan aplikasi lagi pada perangkat Anda.
Terima kasih
Artikel ini didasarkan pada artikel berikut:
- Pengiriman terus-menerus untuk IOS menggunakan Fastlane dan GitHub aksi
- Dokumentasi Fastlane
- This GitHub message from @mrogunlana
Keep going from Automatic Capacitor IOS build with GitHub actions using match
Jika Anda menggunakan Pembangunan Otomatis Capacitor IOS dengan GitHub aksi menggunakan match untuk merencanakan otomatisasi CI/CD, hubungkannya dengan Capgo CI/CD untuk alur kerja produk di Capgo CI/CD, Capgo Pembangunan Asli untuk alur kerja produk di Capgo Pembangunan Asli, Capgo Integrasi untuk alur kerja produk di Capgo Integrasi, Integrasi CI/CD untuk detail implementasi di Integrasi CI/CD, dan GitHub Integrasi Aksi untuk detail implementasi di GitHub Integrasi Aksi.