-
Notifications
You must be signed in to change notification settings - Fork 271
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[do not merge] JIT CI better cache invalidation #5236
base: trunk
Are you sure you want to change the base?
Conversation
@@ -372,7 +372,7 @@ jobs: | |||
id: cache-generated-source | |||
with: | |||
path: ${{ env.jit_generated_src_scheme }} | |||
key: jit_generated_src_scheme-jit_${{env.jit_version}}-${{env.jit_causalhash}} | |||
key: jit_generated_src_scheme-jit_${{env.jit_version}}-${{env.jit_causalhash}}-${{ hashFiles('**/ci.yaml') }} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
wondering if we should also hash env.ucm
here given we rely on a transcript to generate the jit sources?
Ah, is this why CI on my fork always fails in “generate jit source”? I had made a note to figure out what’s going on, but hadn’t gotten around to it. It has certainly caused me to overlook failures in my PRs, because I’m used to every push resulting in emails complaining about this. |
hmm looks very likely 😅 I've definitely seen that error message before. Looking at the "create transcript" step , you can see it uses the old-style empty project |
Yeah I think we've seen a few clues that this is broken, and I would like to fix it (I don't have it all paged in at the moment to evaluate this PR), but I also think including The main reason for the caching was to get CI times down, especially for when editing the .yaml files themselves. 20, 40 minutes per edit vs 4 or less is a big deal. |
Sounds good thanks, I've raised #5240 to only update the generation template and hopefully make CI happy. We can then circle back on this one and get a proper fix in 👍 |
Overview
From the following discussion: #5224 (comment)
Currently the CI cache for the JIT tests misses a few things which might change (and hence break the tests). At the very least they are:
ci.yaml
that's used to generate the JIT sourcesAs such, we use
hashFiles(..)
to ensure that when those dependencies change the source generation & tests are re-run.Interesting/controversial decisions
I'm not super familiar with what triggers a rebuild. Is it just the hashes? If so, it seems like we would always want to hash the
ucm
binary since we would always want to rerun the tests if our main binary changes?Also currently because we have the JIT source generation template in
ci.yaml
, any (unrelated) change in that file would cause a regeneration of the JIT sources. As such, ideally, we should move the JIT source generation into its own.yaml
file. I haven't looked into that since it would take a bit more time to get familiar with github actions.We could also remove caching all-together to be on the safe side, but I'm guessing caching was added for a reason. I'm thinking it would mean pulling from
@unison/internal
each time which might mean extra bandwidth costs?Test coverage
n/a - relying on CI
Loose ends
n/a see "interesting/controversial decisions" above