Deploy to github.io #16
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| name: Deploy to github.io | |
| on: | |
| push: | |
| branches: [dev, main] # 设置源码主分支 | |
| paths: | |
| - 'next-sdk/docs/**' | |
| - 'tiny-robot/docs/**' | |
| - 'tiny-vue/examples/sites/demos/pc/webdoc/**' | |
| - 'tiny-engine/docs/**' | |
| - '.vitepress/**' | |
| workflow_dispatch: {} # 支持手动触发 | |
| repository_dispatch: | |
| types: [submodule-updated] # 当子模块仓库有推送时触发 | |
| permissions: | |
| contents: read | |
| pages: write | |
| id-token: write | |
| concurrency: | |
| group: pages | |
| cancel-in-progress: true | |
| jobs: | |
| build: | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: webfactory/ssh-agent@v0.8.0 | |
| with: | |
| ssh-private-key: ${{ secrets.SUBMODULE_SSH_KEY }} | |
| - name: Checkout repository (with submodules) | |
| uses: actions/checkout@v4 | |
| with: | |
| fetch-depth: 0 # 推荐完整历史以支持 lastUpdated 等 | |
| submodules: false # 检出子模块(递归) | |
| - name: Configure Git identity | |
| run: | | |
| git config --global user.name "GitHub Actions" | |
| git config --global user.email "actions@github.com" | |
| - name: Ensure submodules are up-to-date (pull latest from their remote) | |
| # 这一步会把子模块更新到各自远端的最新分支(通常是子模块配置的上游) | |
| run: | | |
| git submodule sync --recursive | |
| git submodule update --init --recursive | |
| # 拉取子模块的远端最新提交(合并到当前子模块工作树) | |
| # 注意:这不会把变化提交回主仓库;仅用于构建时使用最新子模块内容 | |
| git submodule update --remote --merge --recursive | |
| # 打印状态便于调试 | |
| git submodule status --recursive | |
| - name: Setup pnpm | |
| uses: pnpm/action-setup@v3 | |
| with: | |
| version: 9 | |
| - name: Install deps | |
| run: pnpm i | |
| - name: Build @opentiny/tiny-robot | |
| run: pnpm -F robot-root build | |
| - name: Build site | |
| run: pnpm build | |
| env: | |
| VITEPRESS_BASE: /docs/ | |
| - name: Setup Pages | |
| uses: actions/configure-pages@v2 | |
| - name: Build with Jekyll | |
| uses: actions/jekyll-build-pages@v1 | |
| with: | |
| source: ./dist | |
| destination: ./_site | |
| - name: Upload artifact | |
| uses: actions/upload-pages-artifact@v3 | |
| # Deployment job | |
| deploy: | |
| environment: | |
| name: github-pages | |
| url: ${{ steps.deployment.outputs.page_url }} | |
| runs-on: ubuntu-latest | |
| needs: build | |
| steps: | |
| - name: Deploy to GitHub Pages | |
| id: deployment | |
| uses: actions/deploy-pages@v4 |