123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195 |
- name: insider-linux
- on:
- workflow_dispatch:
- inputs:
- release_version:
- type: string
- description: Forced release version
- schedule:
- - cron: '0 8 * * *'
- push:
- branches: [ insider ]
- paths-ignore:
- - '**/*.md'
- pull_request:
- branches: [ insider ]
- paths-ignore:
- - '**/*.md'
- jobs:
- build:
- runs-on: ubuntu-latest
- container:
- image: ${{ matrix.image }}
- env:
- OS_NAME: 'linux'
- VSCODE_ARCH: ${{ matrix.vscode_arch }}
- VSCODE_QUALITY: 'insider'
- strategy:
- fail-fast: false
- matrix:
- include:
- - vscode_arch: x64
- npm_arch: x64
- image: vscodium/vscodium-linux-build-agent:bionic-x64
- - vscode_arch: arm64
- npm_arch: arm64
- image: vscodium/vscodium-linux-build-agent:stretch-arm64
- - vscode_arch: armhf
- npm_arch: armv7l
- image: vscodium/vscodium-linux-build-agent:stretch-armhf
- outputs:
- RELEASE_VERSION: ${{ env.RELEASE_VERSION }}
- SHOULD_DEPLOY: ${{ env.SHOULD_DEPLOY }}
- steps:
- - uses: actions/checkout@v3
- with:
- ref: insider
- - name: Install GH
- run: ./install_gh.sh
- - name: Setup Node.js environment
- uses: actions/setup-node@v3
- with:
- node-version: 16
- - name: Install Yarn
- run: npm install -g yarn
- - 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: linux-${{ matrix.npm_arch }}-yarnCacheDir-${{ steps.yarnCacheKey.outputs.value }}
- restore-keys: linux-${{ matrix.npm_arch }}-yarnCacheDir-
- if: env.SHOULD_BUILD == 'yes'
- - name: Build
- env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- npm_config_arch: ${{ matrix.npm_arch }}
- run: ./build.sh
- if: env.SHOULD_BUILD == 'yes'
- - name: Prepare artifacts
- run: ./prepare_artifacts.sh
- if: env.SHOULD_BUILD == 'yes' && env.SHOULD_DEPLOY == 'yes'
- - name: Release
- env:
- GITHUB_TOKEN: ${{ secrets.STRONGER_GITHUB_TOKEN }}
- GITHUB_USERNAME: ${{ github.repository_owner }}
- run: ./release.sh
- if: env.SHOULD_BUILD == 'yes' && env.SHOULD_DEPLOY == 'yes'
- - name: Update versions repo
- env:
- GITHUB_TOKEN: ${{ secrets.STRONGER_GITHUB_TOKEN }}
- GITHUB_USERNAME: ${{ github.repository_owner }}
- run: ./update_version.sh
- if: env.SHOULD_BUILD == 'yes' && env.SHOULD_DEPLOY == 'yes'
- aur:
- needs: build
- runs-on: ubuntu-latest
- if: needs.build.outputs.SHOULD_DEPLOY == 'yes'
- steps:
- - name: Get version
- env:
- RELEASE_VERSION: ${{ needs.build.outputs.RELEASE_VERSION }}
- run: echo "PACKAGE_VERSION=${RELEASE_VERSION/-*/}" >> $GITHUB_ENV
- - name: Publish vscodium-insiders-bin
- uses: zokugun/github-actions-aur-releaser@v1
- with:
- package_name: vscodium-insiders-bin
- package_version: ${{ env.PACKAGE_VERSION }}
- aur_private_key: ${{ secrets.AUR_PRIVATE_KEY }}
- aur_username: ${{ secrets.AUR_USERNAME }}
- aur_email: ${{ secrets.AUR_EMAIL }}
- - name: Publish vscodium-insiders
- uses: zokugun/github-actions-aur-releaser@v1
- with:
- package_name: vscodium-insiders
- package_version: ${{ env.PACKAGE_VERSION }}
- aur_private_key: ${{ secrets.AUR_PRIVATE_KEY }}
- aur_username: ${{ secrets.AUR_USERNAME }}
- aur_email: ${{ secrets.AUR_EMAIL }}
- snap:
- needs: build
- runs-on: ubuntu-latest
- env:
- VSCODE_QUALITY: 'insider'
- strategy:
- fail-fast: false
- matrix:
- platform:
- - amd64
- - arm64
- # if: needs.build.outputs.SHOULD_DEPLOY == 'yes'
- if: ${{ false }}
- steps:
- - uses: actions/checkout@v3
- with:
- ref: insider
- - name: Check version
- run: ./stores/snapcraft/check_version.sh
- env:
- ARCHITECTURE: ${{ matrix.platform }}
- SNAPCRAFT_STORE_CREDENTIALS: ${{ secrets.SNAP_STORE_LOGIN }}
- - uses: docker/setup-qemu-action@v1
- if: env.SHOULD_DEPLOY == 'yes'
- - uses: diddlesnaps/snapcraft-multiarch-action@v1
- with:
- path: stores/snapcraft/insider
- architecture: ${{ matrix.platform }}
- id: build
- if: env.SHOULD_DEPLOY == 'yes'
- - uses: diddlesnaps/snapcraft-review-action@v1
- with:
- snap: ${{ steps.build.outputs.snap }}
- isClassic: 'true'
- if: env.SHOULD_DEPLOY == 'yes'
- - uses: snapcore/action-publish@master
- env:
- SNAPCRAFT_STORE_CREDENTIALS: ${{ secrets.SNAP_STORE_LOGIN }}
- with:
- snap: ${{ steps.build.outputs.snap }}
- release: edge
- if: env.SHOULD_DEPLOY == 'yes'
|