Tutorial ini berfokus pada hosting GitHub, tetapi Anda dapat mengadaptasinya dengan sedikit penyesuaian untuk platform CI/CD lainnya
Pendahuluan
Pastikan Anda telah menambahkan aplikasi Capacitor Anda terlebih dahulu ke Capgo, tutorial ini hanya berfokus pada fase upload
Konvensi commit
Pertama Anda perlu mulai mengikuti konvensi commit conventional commits ini akan membantu peralatan memahami bagaimana meningkatkan nomor versi, hanya butuh 5 menit untuk mempelajarinya
GitHub actions untuk tag
Kemudian Anda perlu membuat GitHub action pertama Anda untuk secara otomatis membangun dan membuat tag
Buat file di path ini: .github/workflows/bump_version.yml
dengan konten ini:
name: Bump version
on: push: branches: - main - development
jobs: bump-version: if: "!startsWith(github.event.head_commit.message, 'chore(release):')" runs-on: ubuntu-latest name: "Bump version and create changelog with standard version" steps: - name: Check out uses: actions/checkout@v4 with: fetch-depth: 0 token: '${{ secrets.PERSONAL_ACCESS_TOKEN }}' - name: Git config run: | git config --local user.name "github-actions[bot]" git config --local user.email "github-actions[bot]@users.noreply.github.com" - name: Create bump and changelog if: github.ref == 'refs/heads/main' run: npx capacitor-standard-version - name: Create bump and changelog if: github.ref != 'refs/heads/main' run: npx capacitor-standard-version --prerelease alpha - name: Push to origin run: | CURRENT_BRANCH=$(git rev-parse --abbrev-ref HEAD) remote_repo="https://${GITHUB_ACTOR}:${{ secrets.PERSONAL_ACCESS_TOKEN }}@github.com/${GITHUB_REPOSITORY}.git" git pull $remote_repo $CURRENT_BRANCH git push $remote_repo HEAD:$CURRENT_BRANCH --follow-tags --tags
Ini akan merilis tag untuk setiap commit di branch main Anda Dan rilis alpha
untuk development
, dan terakhir entri changelog untuk setiap commit di CHANGELOG.md
Jangan khawatir jika Anda tidak memiliki file ini, file akan dibuat untuk Anda
Untuk membuat ini berfungsi, Anda perlu membuat PERSONAL ACCESS dan menyimpannya di secret GitHub Anda sebagai PERSONAL_ACCESS_TOKEN
Ini diperlukan agar CI dapat melakukan commit changelog dan pembaruan versi
Saat membuat token, pilih kadaluarsa sebagai never
dan scope sebagai repo
Atur kunci version
di file package.json
Anda. Gunakan versi terakhir yang dirilis di Store
Ini hanya diperlukan pertama kali, kemudian tools akan memperbarui secara otomatis
Anda sekarang dapat melakukan commit kedua file ini dan melihat tag pertama Anda muncul di GitHub!
capacitor-standard-version
adalah paket yang melakukan keajaiban, secara default, dia juga memperbarui nomor versi di Android dan iOS
GitHub actions untuk build
Buat file di path ini: .github/workflows/build.yml
dengan konten ini:
name: Build source code and send to Capgo
on: push: tags: - '*'
jobs: deploy: runs-on: ubuntu-latest name: "Build code and release" steps: - name: Check out uses: actions/checkout@v4 - name: Install dependencies id: install_code run: npm i - name: Build id: build_code run: npm build env: MY_ENV_VAR: ${{ secrets.MY_ENV_VAR }} - name: Create Release Alpha if: "contains(github.ref, '-alpha.')" id: create_release_prepro run: npx @capgo/cli@latest bundle upload -a ${{ secrets.CAPGO_TOKEN }} -c development - name: Create Release Production if: "!contains(github.ref, '-alpha.')" id: create_release_prod run: npx @capgo/cli@latest bundle upload -a ${{ secrets.CAPGO_TOKEN }} -c production
Ini akan menginstal dan membangun dependensi Anda sebelum mengirimkannya ke Capgo
Jika perintah build Anda berbeda, Anda dapat mengubahnya di langkah build_code
Jika Anda memerlukan variabel lingkungan, gunakan MY_ENV_VAR
dan atur secret
di pengaturan proyek GitHub Anda, kemudian secret lalu GitHub Action
Untuk membuat upload Capgo berfungsi, Anda perlu mendapatkan API key untuk Capgo, tambahkan di secret repositori GitHub Anda sebagai CAPGO_TOKEN
Anda sekarang dapat melakukan commit kedua file ini dan melihat versi pertama Anda muncul di Capgo!
Menambahkan commit akan menghasilkan build Capacitor baru untuk channel production dan development
Anda harus menambahkan tes Anda di langkah build Ionic untuk memastikan kode Anda berfungsi
Pergi ke dashboard Capgo Anda dan periksa build Anda yang baru saja muncul, sekarang Anda memiliki sistem CI/CD Anda