diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index ea2c7787b400e4..948195f050c6b0 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -48,7 +48,7 @@ jobs: - name: Get changed files id: changed-files - uses: tj-actions/changed-files@4edd678ac3f81e2dc578756871e4d00c19191daf # v45.0.4 + uses: tj-actions/changed-files@d6e91a2266cdb9d62096cebf1e8546899c6aa18f # v45.0.6 with: files: | docs/** diff --git a/.github/workflows/ecosystem-ci-trigger.yml b/.github/workflows/ecosystem-ci-trigger.yml index c2c50da948b0be..1099ea1fc520c9 100644 --- a/.github/workflows/ecosystem-ci-trigger.yml +++ b/.github/workflows/ecosystem-ci-trigger.yml @@ -9,12 +9,16 @@ jobs: runs-on: ubuntu-latest if: github.repository == 'vitejs/vite' && github.event.issue.pull_request && startsWith(github.event.comment.body, '/ecosystem-ci run') steps: - - uses: actions/github-script@v7 + - name: Check User Permissions + uses: actions/github-script@v7 + id: check-permissions with: script: | const user = context.payload.sender.login console.log(`Validate user: ${user}`) + const additionalAllowedUsers = ['lukastaegert'] + let hasTriagePermission = false try { const { data } = await github.rest.repos.getCollaboratorPermissionLevel({ @@ -27,8 +31,8 @@ jobs: console.warn(e) } - if (hasTriagePermission) { - console.log('Allowed') + if (hasTriagePermission || additionalAllowedUsers.includes(user)) { + console.log('User is allowed. Adding +1 reaction.') await github.rest.reactions.createForIssueComment({ owner: context.repo.owner, repo: context.repo.repo, @@ -36,16 +40,18 @@ jobs: content: '+1', }) } else { - console.log('Not allowed') + console.log('User is not allowed. Adding -1 reaction.') await github.rest.reactions.createForIssueComment({ owner: context.repo.owner, repo: context.repo.repo, comment_id: context.payload.comment.id, content: '-1', }) - throw new Error('not allowed') + throw new Error('User does not have the necessary permissions.') } - - uses: actions/github-script@v7 + + - name: Get PR Data + uses: actions/github-script@v7 id: get-pr-data with: script: | @@ -55,25 +61,158 @@ jobs: repo: context.repo.repo, pull_number: context.issue.number }) + core.setOutput('head_sha', pr.head.sha) return { num: context.issue.number, branchName: pr.head.ref, - repo: pr.head.repo.full_name, - commit: pr.head.sha + commit: pr.head.sha, + repo: pr.head.repo.full_name + } + + - name: Check Package Existence + uses: actions/github-script@v7 + id: check-package + with: + script: | + const prData = ${{ steps.get-pr-data.outputs.result }} + const url = `https://pkg.pr.new/vite@${prData.commit}` + const response = await fetch(url) + console.log(`Package check URL: ${url}, Status: ${response.status}`) + + // Add 'rocket' reaction to the issue comment + if (response.status === 404) { + const { data: reaction } = await github.rest.reactions.createForIssueComment({ + owner: context.repo.owner, + repo: context.repo.repo, + comment_id: context.payload.comment.id, + content: 'rocket', + }) + return { exists: false, reaction: reaction.id } } - - id: generate-token + + return { exists: true, reaction: null } + + - name: Generate Token + id: generate-token uses: tibdex/github-app-token@v2 with: app_id: ${{ secrets.ECOSYSTEM_CI_GITHUB_APP_ID }} installation_retrieval_payload: "${{ github.repository_owner }}/vite-ecosystem-ci" private_key: ${{ secrets.ECOSYSTEM_CI_GITHUB_APP_PRIVATE_KEY }} - - uses: actions/github-script@v7 + + - name: Trigger Preview Release (if Package Not Found) + if: fromJSON(steps.check-package.outputs.result).exists == false + uses: actions/github-script@v7 + id: trigger-preview-release + with: + github-token: ${{ steps.generate-token.outputs.token }} + script: | + const prData = ${{ steps.get-pr-data.outputs.result }} + console.log('Package not found, triggering preview release...') + + // Add label "trigger: preview" to the PR + await github.rest.issues.addLabels({ + owner: context.repo.owner, + repo: context.repo.repo, + issue_number: prData.num, + labels: ['trigger: preview'] + }) + console.log('Added "trigger: preview" label.') + + - name: Wait for Preview Release Completion (if Package Not Found) + if: fromJSON(steps.check-package.outputs.result).exists == false + uses: actions/github-script@v7 + id: wait-preview-release + with: + script: | + const prData = ${{ steps.get-pr-data.outputs.result }} + const reaction = ${{ fromJSON(steps.check-package.outputs.result).reaction }} + const workflowFileName = 'preview-release.yml' + const workflow = await github.rest.actions.getWorkflow({ + owner: context.repo.owner, + repo: context.repo.repo, + workflow_id: workflowFileName, + }) + const workflowId = workflow.data.id + console.log(`Waiting for workflow ID ${workflowId} to complete...`) + + const maxRetries = 60 // Wait up to 10 minutes + const delay = 10000 // 10 seconds + let completed = false + + for (let i = 0; i < maxRetries; i++) { + const runsData = await github.rest.actions.listWorkflowRuns({ + owner: context.repo.owner, + repo: context.repo.repo, + workflow_id: workflowId, + head_sha: prData.commit, + per_page: 100, + page: 1, + }) + + const runs = runsData.data.workflow_runs + + if (runs.length > 0) { + const latestRun = runs[0] + console.log(`Latest run status: ${latestRun.status}, conclusion: ${latestRun.conclusion}`) + if (latestRun.status === 'completed') { + if (latestRun.conclusion === 'success') { + console.log('Preview release workflow completed successfully.') + completed = true + break + } else if (latestRun.conclusion === 'skipped') { + // noop + } else { + throw new Error('Preview Release workflow failed.') + } + } + } + + console.log(`Retrying... (${i + 1}/${maxRetries})`) + await new Promise(resolve => setTimeout(resolve, delay)) + } + + if (!completed) { + throw new Error('Preview Release workflow did not complete in time.') + } + + // Remove the 'rocket' reaction + if (reaction) { + await github.rest.reactions.deleteForIssueComment({ + owner: context.repo.owner, + repo: context.repo.repo, + comment_id: context.payload.comment.id, + reaction_id: reaction, + }) + console.log('Removed "rocket" reaction.') + } + + - name: Checkout + uses: actions/checkout@v4 + with: + ref: refs/pull/${{ fromJSON(steps.get-pr-data.outputs.result).num }}/head + fetch-depth: 0 + + # This step can be removed on May 26 2025 + - name: Check Commit Hash Ambiguity + id: check_ambiguity + run: | + HEAD_SHA=${{ steps.get-pr-data.outputs.head_sha }} + COMMIT_SHORT=${HEAD_SHA:0:7} + + if git show "$COMMIT_SHORT"; then + echo "COLLISION=false" >> $GITHUB_ENV + else + echo "COLLISION=true" >> $GITHUB_ENV + fi + + - name: Trigger Downstream Workflow + uses: actions/github-script@v7 id: trigger env: COMMENT: ${{ github.event.comment.body }} with: github-token: ${{ steps.generate-token.outputs.token }} - result-encoding: string script: | const comment = process.env.COMMENT.trim() const prData = ${{ steps.get-pr-data.outputs.result }} @@ -89,7 +228,7 @@ jobs: prNumber: '' + prData.num, branchName: prData.branchName, repo: prData.repo, - commit: prData.commit, + commit: process.env.COLLISION === 'false' ? prData.commit : '', suite: suite === '' ? '-' : suite } }) diff --git a/.prettierignore b/.prettierignore index d5283c0ed86f17..859618cf7ac1b3 100644 --- a/.prettierignore +++ b/.prettierignore @@ -13,3 +13,4 @@ playground/html/valid.html playground/external/public/slash@3.0.0.js playground/ssr-html/public/slash@3.0.0.js playground/worker/classic-worker.js +playground/css/weapp.wxss diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 4428e2ab41a841..5a049fa4909eed 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -76,7 +76,7 @@ You may wish to test your locally modified copy of Vite against another package ```json { "dependencies": { - "vite": "^5.0.0" + "vite": "^6.0.0" }, "pnpm": { "overrides": { diff --git a/docs/.vitepress/config.ts b/docs/.vitepress/config.ts index 39f4068fcd9ac7..83b2c7500bbc62 100644 --- a/docs/.vitepress/config.ts +++ b/docs/.vitepress/config.ts @@ -337,7 +337,7 @@ export default defineConfig({ link: '/guide/api-environment', }, { - text: 'Environment instances', + text: 'Environment Instances', link: '/guide/api-environment-instances', }, { @@ -442,7 +442,7 @@ export default defineConfig({ transformPageData(pageData) { const canonicalUrl = `${ogUrl}/${pageData.relativePath}` .replace(/\/index\.md$/, '/') - .replace(/\.md$/, '/') + .replace(/\.md$/, '') pageData.frontmatter.head ??= [] pageData.frontmatter.head.unshift( ['link', { rel: 'canonical', href: canonicalUrl }], diff --git a/docs/.vitepress/theme/components/landing/1. hero-section/HeroDiagram.vue b/docs/.vitepress/theme/components/landing/1. hero-section/HeroDiagram.vue index 10bd32fa4d0fb9..f76e7092220094 100644 --- a/docs/.vitepress/theme/components/landing/1. hero-section/HeroDiagram.vue +++ b/docs/.vitepress/theme/components/landing/1. hero-section/HeroDiagram.vue @@ -437,6 +437,12 @@ const isChromiumBrowser = ref(false) onMounted(() => { isChromiumBrowser.value = 'chrome' in window }) + +// Check for uwu query +const isUwu = ref(false) +onMounted(() => { + isUwu.value = location.search.includes('?uwu') +})