vscodium/.github/workflows/insider-macos.yml

124 lines
3.9 KiB
YAML
Raw Normal View History

2022-08-29 16:13:25 +03:00
name: insider-macos
2020-09-18 15:41:04 +03:00
on:
workflow_dispatch:
branches: [ insider ]
2020-09-21 01:28:07 +03:00
schedule:
2022-08-29 16:13:25 +03:00
- cron: '0 1 * * *'
2020-09-18 15:41:04 +03:00
push:
2022-08-29 16:13:25 +03:00
branches: [ insider ]
2022-08-23 01:59:49 +03:00
paths-ignore:
- '**/*.md'
2020-09-18 15:41:04 +03:00
pull_request:
2022-08-29 16:13:25 +03:00
branches: [ insider ]
2022-08-23 01:59:49 +03:00
paths-ignore:
- '**/*.md'
2020-09-18 15:41:04 +03:00
jobs:
build:
2022-04-27 18:58:03 +03:00
runs-on: ${{ matrix.runner }}
2022-08-29 16:13:25 +03:00
env:
OS_NAME: 'osx'
VSCODE_ARCH: ${{ matrix.vscode_arch }}
VSCODE_QUALITY: 'insider'
2021-09-18 11:12:10 +03:00
strategy:
fail-fast: false
matrix:
include:
2022-04-27 18:58:03 +03:00
- runner: macOS-10.15
vscode_arch: x64
- runner: [self-hosted, macOS, ARM64]
vscode_arch: arm64
2021-09-18 11:12:10 +03:00
2020-09-18 15:41:04 +03:00
steps:
2022-04-11 15:37:54 +03:00
- uses: actions/checkout@v3
2021-10-01 19:47:10 +03:00
2020-09-18 15:41:04 +03:00
- name: Setup Node.js environment
2022-04-11 15:37:54 +03:00
uses: actions/setup-node@v3
2020-09-18 15:41:04 +03:00
with:
2022-04-19 23:55:02 +03:00
node-version: 16
2021-03-10 18:48:45 +03:00
2020-09-18 15:41:04 +03:00
- name: Clone VSCode repo
2021-10-01 19:47:10 +03:00
run: . get_repo.sh
- name: Check PR or cron
run: . check_cron_or_pr.sh
2020-09-18 15:41:04 +03:00
- name: Check existing VSCodium tags/releases
2020-09-18 16:01:29 +03:00
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NEW_RELEASE: ${{ github.event.inputs.new_release }}
2021-10-01 19:47:10 +03:00
run: . check_tags.sh
2021-03-10 18:48:45 +03:00
if: env.SHOULD_DEPLOY == 'yes'
2021-03-10 20:58:36 +03:00
- name: Compute cache key
id: yarnCacheKey
run: echo "::set-output name=value::$(node build/azure-pipelines/computeYarnCacheKey.js)"
2021-03-10 21:24:52 +03:00
if: env.SHOULD_BUILD == 'yes'
2021-03-10 20:58:36 +03:00
- name: Get yarn cache directory path
id: yarnCacheDirPath
run: echo "::set-output name=dir::$(yarn cache dir)"
2021-03-10 21:24:52 +03:00
if: env.SHOULD_BUILD == 'yes'
2021-03-10 20:58:36 +03:00
- name: Cache yarn directory
2022-04-11 15:37:54 +03:00
uses: actions/cache@v3
2021-03-10 20:58:36 +03:00
with:
path: ${{ steps.yarnCacheDirPath.outputs.dir }}
2021-03-10 21:38:28 +03:00
key: ${{ env.OS_NAME }}-${{ env.VSCODE_ARCH }}-yarnCacheDir-${{ steps.yarnCacheKey.outputs.value }}
restore-keys: ${{ env.OS_NAME }}-${{ env.VSCODE_ARCH }}-yarnCacheDir-
2021-03-10 20:58:36 +03:00
if: env.SHOULD_BUILD == 'yes'
2020-09-18 15:41:04 +03:00
- name: Build
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
2020-09-18 15:41:04 +03:00
run: ./build.sh
if: env.SHOULD_BUILD == 'yes'
2020-09-18 15:41:04 +03:00
- name: Sign binary
env:
CERTIFICATE_OSX_P12: ${{ secrets.CERTIFICATE_OSX_P12 }}
CERTIFICATE_OSX_PASSWORD: ${{ secrets.CERTIFICATE_OSX_PASSWORD }}
CERTIFICATE_OSX_ID: ${{ secrets.CERTIFICATE_OSX_ID }}
2021-03-10 18:48:45 +03:00
if: env.SHOULD_BUILD == 'yes' && env.SHOULD_DEPLOY == 'yes'
run: |
if [ -d "VSCode-darwin-${VSCODE_ARCH}" ]; then # just in case the build failed
2020-12-15 01:53:43 +03:00
cd "VSCode-darwin-${VSCODE_ARCH}"
export CERTIFICATE_P12=VSCodium.p12
echo $CERTIFICATE_OSX_P12 | base64 --decode > $CERTIFICATE_P12
export KEYCHAIN=$RUNNER_TEMP/build.keychain
security create-keychain -p mysecretpassword $KEYCHAIN
security default-keychain -s $KEYCHAIN
security unlock-keychain -p mysecretpassword $KEYCHAIN
security import $CERTIFICATE_P12 -k $KEYCHAIN -P $CERTIFICATE_OSX_PASSWORD -T /usr/bin/codesign
security set-key-partition-list -S apple-tool:,apple: -s -k mysecretpassword $KEYCHAIN
codesign --deep --force --verbose --sign "$CERTIFICATE_OSX_ID" VSCodium.app
fi
2021-10-01 19:47:10 +03:00
- name: Prepare artifacts
run: ./prepare_artifacts.sh
2021-03-10 18:48:45 +03:00
if: env.SHOULD_BUILD == 'yes' && env.SHOULD_DEPLOY == 'yes'
2020-09-19 00:54:45 +03:00
2020-09-18 15:41:04 +03:00
- name: Release
env:
2021-11-10 12:40:20 +03:00
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
2021-10-01 19:47:10 +03:00
run: ./release.sh
if: env.SHOULD_BUILD == 'yes' && env.SHOULD_DEPLOY == 'yes'
2020-09-18 15:41:04 +03:00
- name: Update versions repo
2021-03-10 18:48:45 +03:00
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 }}
2022-05-07 18:18:14 +03:00
- name: Clean up keychain
if: always()
2022-05-07 18:18:14 +03:00
run: |
KEYCHAIN=$RUNNER_TEMP/build.keychain
if [ -f "$KEYCHAIN" ];
then
security delete-keychain $KEYCHAIN
fi