diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index ee9ca785..8039dee6 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -5,8 +5,7 @@ permissions: env: RUST_BACKTRACE: 1 jobs: - ci: - environment: pull_request_deployment + build: runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 @@ -51,21 +50,45 @@ jobs: echo "modified files detected" exit 1 fi + - id: get_output_dir + run: echo "output_dir=$(cargo run -- print-output-dir)" >> $GITHUB_OUTPUT + - uses: actions/upload-artifact@v3 + with: + name: build_output_dir + path: ${{ steps.get_output_dir.outputs.output_dir }} + outputs: + output_dir: ${{ steps.get_output_dir.outputs.output_dir }} + + deploy-preview: + if: github.event_name == 'pull_request_target' + needs: build + environment: pull_request_deployment + runs-on: ubuntu-latest + steps: + - uses: actions/download-artifact@v3 + with: + name: build_output_dir + path: ${{ needs.build.outputs.output_dir }} - id: deploy - if: github.event_name == 'pull_request_target' run: | npx vercel pull --yes --environment=preview --scope mobusoperandi --token=${{ secrets.VERCEL_TOKEN }} URL=$(npx vercel deploy --prebuilt --token=${{ secrets.VERCEL_TOKEN }}) echo "URL=$URL" >> $GITHUB_OUTPUT - - if: github.event_name == 'pull_request_target' - uses: thollander/actions-comment-pull-request@v2 + - uses: thollander/actions-comment-pull-request@v2 with: message: | Branch deployed for review at: ${{ steps.deploy.outputs.URL }} - - id: get_output_dir - run: echo "OUTPUT_DIR=$(cargo run -- print-output-dir)" >> $GITHUB_OUTPUT + + deploy-production: + if: github.ref == 'refs/heads/master' + needs: build + runs-on: ubuntu-latest + steps: + - uses: actions/download-artifact@v3 + with: + name: build_output_dir + path: ${{ needs.build.outputs.output_dir }} - uses: JamesIves/github-pages-deploy-action@v4 - if: github.ref == 'refs/heads/master' with: - folder: ${{ steps.get_output_dir.outputs.OUTPUT_DIR }} + folder: ${{ needs.build.outputs.output_dir }} diff --git a/builder/src/lib.rs b/builder/src/lib.rs index f4497d4f..00631b08 100644 --- a/builder/src/lib.rs +++ b/builder/src/lib.rs @@ -4,7 +4,8 @@ use camino::Utf8PathBuf; use once_cell::sync::Lazy; pub static OUTPUT_DIR: Lazy = Lazy::new(|| { - [env!("CARGO_MANIFEST_DIR"), "..", ".vercel/output/static"] - .iter() - .collect() + Utf8PathBuf::from(env!("CARGO_MANIFEST_DIR")) + .parent() + .unwrap() + .join(".vercel/output/static") });