Set up continuous integration in Forgejo #75

Merged
glen merged 23 commits from Vectornaut/dyna3:forgejo-ci into main 2025-04-02 20:31:42 +00:00
3 changed files with 21 additions and 14 deletions
Showing only changes of commit 992fb76419 - Show all commits

View file

@ -3,22 +3,11 @@ on:
push:
branches: [main]
jobs:
# build the application, reporting success if there are no errors or warnings
build:
runs-on: docker
container:
image: cimg/rust:1.85-node
defaults:
run:
working-directory: app-proto
steps:
- uses: https://code.forgejo.org/actions/checkout@v4
- uses: ./.forgejo/setup-trunk
- run: RUSTFLAGS='-D warnings' trunk build
# run the automated tests, reporting success if the tests pass and were built
# without warnings. the examples are run as tests, because we've configured
# each example target with `test = true` and `harness = false` in Cargo.toml
# each example target with `test = true` and `harness = false` in Cargo.toml.
# Trunk build failures caused by problems outside the Rust source code, like
# missing assets, should be caught by `trunk_build_test`
test:
runs-on: docker
container:
@ -28,4 +17,5 @@ jobs:
working-directory: app-proto
steps:
- uses: https://code.forgejo.org/actions/checkout@v4
- uses: ./.forgejo/setup-trunk
- run: RUSTFLAGS='-D warnings' cargo test
glen marked this conversation as resolved Outdated
Outdated
Review

Why isn't this path ../.forgejo/setup-trunk? That would seem to be the relative path from the working-directory to the action. I mean, I am not suggesting the file is incorrect; I am just saying the notation is unclear, and my particular concern is that when we (presumably sometime soon) remove the app-proto layer of the hierarchy, that this workflow file be reasonably resilient to that.

Why isn't this path `../.forgejo/setup-trunk`? That would seem to be the relative path from the working-directory to the action. I mean, I am not suggesting the file is incorrect; I am just saying the notation is unclear, and my particular concern is that when we (presumably sometime soon) remove the app-proto layer of the hierarchy, that this workflow file be reasonably resilient to that.

I think the label defaults.run.working-directory sets the default only for run steps, like in GitHub Actions.

I think the label `defaults.run.working-directory` sets the default only for `run` steps, [like in GitHub Actions](https://docs.github.com/en/actions/writing-workflows/workflow-syntax-for-github-actions#jobsjob_iddefaultsrun).
Outdated
Review

How is the working directory for a uses step determined then? Should that be made explicit in this file somehow?

How is the working directory for a uses step determined then? Should that be made explicit in this file somehow?
Outdated
Review

In meeting, we concluded that Aaron will push a commit that adds some mild commentary he is comfortable with elucidating how the current directory state is evolving during this workflow.

In meeting, we concluded that Aaron will push a commit that adds some mild commentary he is comfortable with elucidating how the current directory state is evolving during this workflow.

In the setup-trunk action, you added the comment: "Assume we remain in the top-level directory of the checkout." It seems to me, though, that it doesn't really matter where setup-trunk runs: Trunk will be added to the path regardless. What were you thinking might go wrong if setup-trunk ran somewhere else? Or was this comment just meant to indicate that, for the sake of organization, setup-trunk should be run from the top-level directory of the checkout?

In the `setup-trunk` action, you added the [comment](https://code.studioinfinity.org/StudioInfinity/dyna3/src/commit/0e38a38b5780e3e9368bb1f1a41467dabf66494b/.forgejo/setup-trunk/action.yaml#L13): "Assume we remain in the top-level directory of the checkout." It seems to me, though, that it doesn't really matter where `setup-trunk` runs: Trunk will be added to the path regardless. What were you thinking might go wrong if `setup-trunk` ran somewhere else? Or was this comment just meant to indicate that, for the sake of organization, `setup-trunk` *should* be run from the top-level directory of the checkout?

The GitHub Actions documentation is clearer about how the path to a local action is specified. This is consistent with the behavior I've seen in Forgejo Actions.

The path is relative (./) to the default working directory (github.workspace, $GITHUB_WORKSPACE). If the action checks out the repository to a location different than the workflow, the relative path used for local actions must be updated.

The GitHub Actions documentation is clearer about [how the path to a local action is specified](https://docs.github.com/en/actions/writing-workflows/workflow-syntax-for-github-actions#example-using-an-action-in-the-same-repository-as-the-workflow). This is consistent with the behavior I've seen in Forgejo Actions. > The path is relative (`./`) to the default working directory (`github.workspace`, `$GITHUB_WORKSPACE`). If the action checks out the repository to a location different than the workflow, the relative path used for local actions must be updated.
Outdated
Review

What I meant was: it was our intention that trunk be installed in a directory ci-bin created at the top level of the project hierarchy. The script as written only accomplishes that intention if it in fact is the case that post the run: rustup... action it remains that case that the current directory is the top-level directory. [Sorry about the delay in posting this, apparently I forgot to hit the Reply button last night when I wrote it, and only discovered that omission today when I started closing all of my numerous open browser windows.]

What I meant was: it was our intention that trunk be installed in a directory ci-bin created at the top level of the project hierarchy. The script as written only accomplishes that intention if it in fact is the case that post the `run: rustup...` action it remains that case that the current directory is the top-level directory. [Sorry about the delay in posting this, apparently I forgot to hit the Reply button last night when I wrote it, and only discovered that omission today when I started closing all of my numerous open browser windows.]
Outdated
Review

Ah, and now we have crossed to some extent. When you push clarifying comments as you see fit for the location of the uses action and/or what the checkout does to the current directory (I think those are the points we discussed, feel free to adjust the comment I put in to the setup-trunk action so that my intended meaning is clearer. Thanks!

Ah, and now we have crossed to some extent. When you push clarifying comments as you see fit for the location of the uses action and/or what the checkout does to the current directory (I think those are the points we discussed, feel free to adjust the comment I put in to the setup-trunk action so that my intended meaning is clearer. Thanks!

What I meant was: it was our intention that trunk be installed in a directory ci-bin created at the top level of the project hierarchy.

Got it! It turns out that the setup-trunk action doesn't actually do that, because I was wrong during the meeting about how location control works in actions. The workflow comes with a workspace directory, which is the default place to run commands and place files that are shared between steps. This is mentioned in the Forgejo Actions glossary:

workspace: the directory where the files of the job are stored and shared between all steps.

As of commit efb2d39, the setup-trunk action creates ci-bin within the workspace directory, even if we tell the checkout action to check the repository out to somewhere else.

I think those are the points we discussed, feel free to adjust the comment I put in to the setup-trunk action so that my intended meaning is clearer.

I've made a second commit (440b1df) that adjusts your comment and makes the location used in setup-trunk more explicit. Feel free to revert or modify it if you'd like.

> What I meant was: it was our intention that trunk be installed in a directory ci-bin created at the top level of the project hierarchy. Got it! It turns out that the `setup-trunk` action doesn't actually do that, because I was wrong during the meeting about how location control works in actions. The workflow comes with a *workspace directory*, which is the default place to run commands and place files that are shared between steps. This is mentioned in the Forgejo Actions [glossary](https://forgejo.org/docs/next/user/actions/#glossary): > **workspace:** the directory where the files of the **job** are stored and shared between all **step**s. As of commit efb2d39, the `setup-trunk` action creates `ci-bin` within the workspace directory, even if we tell the `checkout` action to check the repository out to somewhere else. > I think those are the points we discussed, feel free to adjust the comment I put in to the setup-trunk action so that my intended meaning is clearer. I've made a second commit (440b1df) that adjusts your comment and makes the location used in `setup-trunk` more explicit. Feel free to revert or modify it if you'd like.
Outdated
Review

@Vectornaut wrote in #75 (comment):

It turns out that the setup-trunk action doesn't actually do that

Agreed, but because it installs ci-bin as as a subdirectory of the workspace, and it checks out the repository so that its top-level directory is exactly the workspace, the ci-bin directory does end up at the top level of the checkout (as verified by an explicit ls step I temporarily put in the workflow). As a consequence, I clarified the comments on checkout to note exactly where the top-level directory of the repo ends up, and I left ci-bin in .gitignore because in CI, that's where it ends up, so if somehow ever (A) the CI steps ran directly in the host [hard to imagine] or (B) we had a CI action that created a commit [slightly more plausible, even if unlikely], the ci-bin directory would be ignored. With those changes, I am resolving this conversation, and merging the PR. Thanks for all of your efforts on this!

@Vectornaut wrote in https://code.studioinfinity.org/StudioInfinity/dyna3/pulls/75#issuecomment-2550: > It turns out that the `setup-trunk` action doesn't actually do that Agreed, but because it installs ci-bin as as a subdirectory of the workspace, and it checks out the repository so that its top-level directory is exactly the workspace, the ci-bin directory does end up at the top level of the checkout (as verified by an explicit `ls` step I temporarily put in the workflow). As a consequence, I clarified the comments on checkout to note exactly where the top-level directory of the repo ends up, and I left `ci-bin` in `.gitignore` because in CI, that's where it ends up, so if somehow ever (A) the CI steps ran directly in the host [hard to imagine] or (B) we had a CI action that created a commit [slightly more plausible, even if unlikely], the ci-bin directory would be ignored. With those changes, I am resolving this conversation, and merging the PR. Thanks for all of your efforts on this!

View file

@ -5,6 +5,9 @@ mod engine;
mod outline;
mod specified;
#[cfg(test)]
mod tests;
use rustc_hash::FxHashSet;
use sycamore::prelude::*;

14
app-proto/src/tests.rs Normal file
View file

@ -0,0 +1,14 @@
use std::process::Command;
// build and bundle the application, reporting success if there are no errors or
// warnings. to see this test fail while others succeed, try moving `index.html`
// or one of the assets that it links to
#[test]
fn trunk_build_test() {
let build_status = Command::new("trunk")
.arg("build")
.env("RUSTFLAGS", "-D warnings")
.status()
.expect("Call to Trunk failed");
assert!(build_status.success());
}