name: CI on: push: branches: - main pull_request: paths-ignore: - '.vscode/**' # Automatically cancel in-progress actions on the same branch concurrency: group: ${{ github.workflow }}-${{ github.event_name == 'pull_request_target' && github.head_ref || github.ref }} cancel-in-progress: true defaults: run: shell: bash jobs: # Lint can run in parallel with Build. lint: name: Lint runs-on: ubuntu-latest steps: - name: Check out repository uses: actions/checkout@v3 - name: Setup PNPM uses: pnpm/action-setup@v2.2.1 - name: Setup Node uses: actions/setup-node@v3 with: node-version: 16 cache: 'pnpm' - name: Install dependencies run: pnpm install - name: Status run: git status # Lint autofix cannot run on forks, so just skip those! See https://github.com/wearerequired/lint-action/issues/13 - name: Lint (External) if: ${{ github.event_name == 'pull_request' && github.event.pull_request.head.repo.owner.login != github.repository_owner }} run: pnpm run lint # Otherwise, run lint autofixer - name: Lint if: ${{ github.event_name != 'pull_request' || github.event.pull_request.head.repo.owner.login == github.repository_owner }} uses: wearerequired/lint-action@v1.11.1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} with: eslint: true prettier: false auto_fix: true git_name: github-actions[bot] git_email: github-actions[bot]@users.noreply.github.com commit_message: 'chore(lint): ${linter} fix' github_token: ${{ secrets.GITHUB_TOKEN }} neutral_check_on_warning: true # Checks that the formatter runs successfully on all files # In the future, we may have this fail PRs on unformatted code - name: Format Check run: yarn format --list # Build installs all devDependencies and runs our full build pipeline. # We upload all `dist/` artifacts to GitHub, which can be shared by all dependent jobs. build: name: Build Packages runs-on: ubuntu-latest steps: - name: Checkout uses: actions/checkout@v3 - name: Setup PNPM uses: pnpm/action-setup@v2.2.1 - name: Setup Node uses: actions/setup-node@v3 with: node-version: 16 cache: 'pnpm' - name: Install dependencies run: pnpm install - name: Build Packages run: pnpm run build - name: Upload Package Artifacts uses: actions/upload-artifact@v3 with: name: artifacts path: | packages/*/dist/** packages/*/*/dist/** packages/webapi/mod.js packages/webapi/mod.js.map if-no-files-found: error # Test depends on Build's output, which allows us to skip any build process! test: name: 'Test: ${{ matrix.os }} (node@${{ matrix.node_version }})' runs-on: ${{ matrix.os }} env: ASTRO_TELEMETRY_DISABLED: true strategy: matrix: os: [ubuntu-latest] node_version: [14, 16] include: - os: windows-latest node_version: 16 - os: macos-latest node_version: 16 fail-fast: false needs: - build steps: - name: Checkout uses: actions/checkout@v3 - name: Setup PNPM uses: pnpm/action-setup@v2.2.1 - name: Setup node@${{ matrix.node_version }} uses: actions/setup-node@v3 with: node-version: ${{ matrix.node_version }} cache: 'pnpm' - name: Use Deno uses: denoland/setup-deno@v1 with: deno-version: v1.19.3 - name: Download Build Artifacts uses: actions/download-artifact@v3 - name: Extract Artifacts run: ./.github/extract-artifacts.sh - name: Install dependencies run: pnpm install - name: Test run: pnpm run test e2e: name: 'E2E: ${{ matrix.os }} (node@${{ matrix.node_version }})' runs-on: ${{ matrix.os }} env: ASTRO_TELEMETRY_DISABLED: true strategy: matrix: os: [ubuntu-latest] node_version: [14, 16] include: - os: windows-latest node_version: 16 - os: macos-latest node_version: 16 fail-fast: false needs: - build steps: - name: Checkout uses: actions/checkout@v3 - name: Setup PNPM uses: pnpm/action-setup@v2.2.1 - name: Setup node@${{ matrix.node_version }} uses: actions/setup-node@v3 with: node-version: ${{ matrix.node_version }} cache: 'pnpm' - name: Download Build Artifacts uses: actions/download-artifact@v3 - name: Extract Artifacts run: ./.github/extract-artifacts.sh - name: Install dependencies run: pnpm install - name: Test run: pnpm run test:e2e smoke: name: 'Test (Smoke) ${{ matrix.os }}' runs-on: ${{ matrix.os }} strategy: matrix: os: [windows-latest, ubuntu-latest] needs: - build steps: - name: Checkout uses: actions/checkout@v3 with: submodules: 'recursive' - name: Update submodules run: git submodule update --remote - name: Setup PNPM uses: pnpm/action-setup@v2.2.1 - name: Setup Node uses: actions/setup-node@v3 with: node-version: 14 cache: 'pnpm' - name: Download Build Artifacts uses: actions/download-artifact@v3 - name: Extract Artifacts run: ./.github/extract-artifacts.sh - name: Install dependencies run: pnpm install --no-frozen-lockfile - name: Test run: pnpm run test:smoke - name: Memory Leak Test run: | node ./scripts/memory/mk.js node --expose-gc ./scripts/memory/index.js --ci # Changelog can only run _after_ build. # We download all `dist/` artifacts from GitHub to skip the build process. changelog: name: Changelog PR or Release if: ${{ (github.ref_name == 'main' || github.head_ref == 'next') && github.repository_owner == 'withastro' }} needs: [build] runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 - name: Setup PNPM uses: pnpm/action-setup@v2.2.1 - name: Setup Node uses: actions/setup-node@v3 with: node-version: 16 cache: 'pnpm' - name: Download Build Artifacts uses: actions/download-artifact@v3 - name: Extract Artifacts run: ./.github/extract-artifacts.sh - name: Install dependencies run: pnpm install - name: Create Release Pull Request or Publish id: changesets uses: changesets/action@v1 with: # Note: pnpm install after versioning is necessary to refresh lockfile version: pnpm run version publish: pnpm exec changeset publish commit: '[ci] release' title: '[ci] release' env: # Needs access to push to main GITHUB_TOKEN: ${{ secrets.FREDKBOT_GITHUB_TOKEN }} # Needs access to publish to npm NPM_TOKEN: ${{ secrets.NPM_TOKEN }} - name: Generate Notification id: notification if: steps.changesets.outputs.published == 'true' run: message=$(node scripts/notify/index.js '${{ steps.changesets.outputs.publishedPackages }}') && echo ::set-output name=message::${message//$'\n'/'%0A'} - name: Discord Notification if: steps.changesets.outputs.published == 'true' id: discord-notification env: DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }} uses: Ilshidur/action-discord@0.3.2 with: args: ${{ steps.notification.outputs.message }}