123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184 |
- name: insider-windows
- on:
- workflow_dispatch:
- inputs:
- force_version:
- type: boolean
- description: Force update version
- generate_assets:
- type: boolean
- description: Generate assets
- checkout_pr:
- type: string
- description: Checkout PR
- repository_dispatch:
- types: [insider]
- push:
- branches: [ insider ]
- paths-ignore:
- - '**/*.md'
- pull_request:
- branches: [ insider ]
- paths-ignore:
- - '**/*.md'
- env:
- APP_NAME: VSCodium
- ASSETS_REPOSITORY: ${{ github.repository }}-insiders
- GITHUB_BRANCH: ${{ github.event_name == 'pull_request' && github.event.pull_request.head.sha || 'insider' }}
- OS_NAME: windows
- VERSIONS_REPOSITORY: ${{ github.repository_owner }}/versions
- VSCODE_QUALITY: insider
- jobs:
- build:
- runs-on: windows-2019
- defaults:
- run:
- shell: bash
- env:
- VSCODE_ARCH: ${{ matrix.vscode_arch }}
- strategy:
- fail-fast: false
- matrix:
- vscode_arch:
- - x64
- # - ia32
- - arm64
- outputs:
- RELEASE_VERSION: ${{ env.RELEASE_VERSION }}
- SHOULD_DEPLOY: ${{ env.SHOULD_DEPLOY }}
- steps:
- - uses: actions/checkout@v4
- with:
- ref: ${{ env.GITHUB_BRANCH }}
- - name: Switch to relevant branch
- env:
- PULL_REQUEST_ID: ${{ github.event.inputs.checkout_pr }}
- run: ./get_pr.sh
- - name: Setup Node.js environment
- uses: actions/setup-node@v4
- with:
- node-version: '20.12'
- - name: Install Yarn
- run: npm install -g yarn
- - name: Setup Python 3
- uses: actions/setup-python@v5
- with:
- python-version: '3.11'
- - name: Clone VSCode repo
- run: ./get_repo.sh
- - name: Check PR or cron
- env:
- GENERATE_ASSETS: ${{ github.event.inputs.generate_assets }}
- run: ./check_cron_or_pr.sh
- - name: Check existing VSCodium tags/releases
- env:
- DISABLE_MSI: ${{ vars.DISABLE_INSIDER_MSI }}
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- run: ./check_tags.sh
- if: env.SHOULD_DEPLOY == 'yes' || github.event.inputs.generate_assets == 'true'
- - name: Build
- env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- npm_config_arch: ${{ matrix.vscode_arch }}
- npm_config_target_arch: ${{ matrix.vscode_arch }}
- run: ./build.sh
- if: env.SHOULD_BUILD == 'yes'
- - name: Prepare assets
- run: ./prepare_assets.sh
- if: env.SHOULD_BUILD == 'yes' && (env.SHOULD_DEPLOY == 'yes' || github.event.inputs.generate_assets == 'true')
- - name: Upload unsigned artifacts
- id: upload-unsigned-artifacts
- uses: actions/upload-artifact@v4
- with:
- name: unsigned-${{ matrix.vscode_arch }}
- path: |
- assets/*.exe
- assets/*.msi
- retention-days: 1
- if: env.SHOULD_BUILD == 'yes' && (env.SHOULD_DEPLOY == 'yes' || github.event.inputs.generate_assets == 'true')
- - name: Signing
- uses: signpath/github-action-submit-signing-request@v1
- with:
- api-token: '${{ secrets.SIGNPATH_API_TOKEN }}'
- organization-id: '${{ secrets.SIGNPATH_ORGANIZATION_ID }}'
- project-slug: '${{ secrets.SIGNPATH_PROJECT_SLUG }}'
- signing-policy-slug: '${{ secrets.SIGNPATH_POLICY_SLUG }}'
- github-artifact-id: '${{ steps.upload-unsigned-artifacts.outputs.artifact-id }}'
- artifact-configuration-slug: '${{ matrix.vscode_arch }}'
- wait-for-completion: true
- output-artifact-directory: assets/
- if: env.SHOULD_BUILD == 'yes' && (env.SHOULD_DEPLOY == 'yes' || github.event.inputs.generate_assets == 'true')
- - name: Prepare checksums
- run: ./prepare_checksums.sh
- if: env.SHOULD_BUILD == 'yes' && (env.SHOULD_DEPLOY == 'yes' || github.event.inputs.generate_assets == 'true')
- - 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:
- FORCE_UPDATE: ${{ github.event.inputs.force_version }}
- GITHUB_TOKEN: ${{ secrets.STRONGER_GITHUB_TOKEN }}
- GITHUB_USERNAME: ${{ github.repository_owner }}
- run: ./update_version.sh
- if: env.SHOULD_BUILD == 'yes' && env.SHOULD_DEPLOY == 'yes'
- - name: Upload assets
- uses: actions/upload-artifact@v4
- with:
- name: bin-${{ matrix.vscode_arch }}
- path: assets/
- retention-days: 3
- if: env.SHOULD_BUILD == 'yes' && env.SHOULD_DEPLOY == 'no' && github.event.inputs.generate_assets == 'true'
- winget:
- needs: build
- runs-on: windows-latest
- defaults:
- run:
- shell: bash
- env:
- APP_IDENTIFIER: VSCodium.VSCodium.Insiders
- ASSETS_REPOSITORY: vscodium-insiders
- if: needs.build.outputs.SHOULD_DEPLOY == 'yes'
- steps:
- - uses: actions/checkout@v4
- with:
- ref: ${{ env.GITHUB_BRANCH }}
- - name: Check version
- run: ./stores/winget/check_version.sh
- env:
- RELEASE_VERSION: ${{ needs.build.outputs.RELEASE_VERSION }}
- - name: Release to WinGet
- uses: vedantmgoyal9/winget-releaser@main
- with:
- identifier: ${{ env.APP_IDENTIFIER }}
- version: ${{ env.RELEASE_VERSION }}
- release-repository: ${{ env.ASSETS_REPOSITORY }}
- release-tag: ${{ env.RELEASE_VERSION }}-insider
- installers-regex: '\.exe$' # only .exe files
- token: ${{ secrets.STRONGER_GITHUB_TOKEN }}
- if: env.SHOULD_DEPLOY == 'yes'
|