123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 |
- name: insider-macos
- on:
- workflow_dispatch:
- inputs:
- release_version:
- type: string
- description: Forced release version
- schedule:
- - cron: '0 7 * * *'
- push:
- branches: [ insider ]
- paths-ignore:
- - '**/*.md'
- pull_request:
- branches: [ insider ]
- paths-ignore:
- - '**/*.md'
- jobs:
- build:
- runs-on: ${{ matrix.runner }}
- env:
- OS_NAME: 'osx'
- VSCODE_ARCH: ${{ matrix.vscode_arch }}
- VSCODE_QUALITY: 'insider'
- strategy:
- fail-fast: false
- matrix:
- include:
- - runner: macos-12
- vscode_arch: x64
- - runner: [self-hosted, macOS, ARM64]
- vscode_arch: arm64
- steps:
- - uses: actions/checkout@v3
- with:
- ref: insider
- - name: Setup Node.js environment
- uses: actions/setup-node@v3
- with:
- node-version: 16
- - name: Clone VSCode repo
- env:
- RELEASE_VERSION: ${{ github.event.inputs.release_version }}
- run: . get_repo.sh
- - name: Check PR or cron
- run: . check_cron_or_pr.sh
- - name: Check existing VSCodium tags/releases
- env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- run: . check_tags.sh
- if: env.SHOULD_DEPLOY == 'yes'
- - name: Compute cache key
- id: yarnCacheKey
- run: echo "::set-output name=value::$(node build/azure-pipelines/computeYarnCacheKey.js)"
- if: env.SHOULD_BUILD == 'yes'
- - name: Get yarn cache directory path
- id: yarnCacheDirPath
- run: echo "::set-output name=dir::$(yarn cache dir)"
- if: env.SHOULD_BUILD == 'yes'
- - name: Cache yarn directory
- uses: actions/cache@v3
- with:
- path: ${{ steps.yarnCacheDirPath.outputs.dir }}
- key: ${{ env.OS_NAME }}-${{ env.VSCODE_ARCH }}-yarnCacheDir-${{ steps.yarnCacheKey.outputs.value }}
- restore-keys: ${{ env.OS_NAME }}-${{ env.VSCODE_ARCH }}-yarnCacheDir-
- if: env.SHOULD_BUILD == 'yes'
- - name: Build
- env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- run: ./build.sh
- if: env.SHOULD_BUILD == 'yes'
- - name: Prepare artifacts
- env:
- CERTIFICATE_OSX_P12: ${{ secrets.CERTIFICATE_OSX_P12 }}
- CERTIFICATE_OSX_PASSWORD: ${{ secrets.CERTIFICATE_OSX_PASSWORD }}
- CERTIFICATE_OSX_ID: ${{ secrets.CERTIFICATE_OSX_ID }}
- run: ./prepare_artifacts.sh
- if: env.SHOULD_BUILD == 'yes' && env.SHOULD_DEPLOY == 'yes'
- - name: Release
- env:
- GITHUB_TOKEN: ${{ secrets.STRONGER_GITHUB_TOKEN }}
- run: ./release.sh
- if: env.SHOULD_BUILD == 'yes' && env.SHOULD_DEPLOY == 'yes'
- - name: Update versions repo
- if: env.SHOULD_BUILD == 'yes' && env.SHOULD_DEPLOY == 'yes'
- run: ./update_version.sh
- env:
- GITHUB_TOKEN: ${{ secrets.STRONGER_GITHUB_TOKEN }}
- GITHUB_USERNAME: ${{ github.repository_owner }}
- - name: Clean up keychain
- if: always()
- run: |
- KEYCHAIN=$RUNNER_TEMP/build.keychain
- if [ -f "$KEYCHAIN" ];
- then
- security delete-keychain $KEYCHAIN
- fi
|