Skip to content
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

Introduce Turbo cache in CI #1753

Closed
danielbate opened this issue Feb 15, 2024 · 3 comments
Closed

Introduce Turbo cache in CI #1753

danielbate opened this issue Feb 15, 2024 · 3 comments
Assignees
Labels
chore Issue is a chore

Comments

@danielbate
Copy link
Member

In #1649 we introduced a Turbo cache in CI, however it was prone to flakiness. As the docs build is dependent on an autogenerated file from providers, if providers hits the cache but docs misses, the job will fail.

Adding a build cache would improve the time of the second job in our test CI, so we should look to introduce it. However something that is more robust than what was added in #1649, #1694 and #1721.

@danielbate danielbate added the chore Issue is a chore label Feb 15, 2024
@arboleya
Copy link
Member

FWIW, it seems that the error happens when re-running a failed workflow.

We should stress test this case if we re-add the work reverted by #1752.


The failing workflow is something like this:

Job 1

perform env specific tests in parallel

  1. Looks for a cache entry using the commit SHA - does not find one
  2. Performs install / build
  3. providers.prebuild generates the operations file
  4. docs.build generates docs, referencing the providers.operations file
  5. Performs an environment specific test and uploads results

Job 2

  1. Looks for a cache entry using the SHA - finds one and fills dist directories, as well as any autogenerated files (providers.operations, docs/api).
  2. Performs install and build - hits cache on build
  3. providers.prebuild and docs.build not executed
  4. Downloads test results, merges and uploads.

So if we have inconsistencies between cache hits/misses with the GH cache, and the turbo package caches - it will fail.

Most commonly it seems to be providers hitting the cache but docs missing it.

@danielbate
Copy link
Member Author

FWIW, it seems that the error happens when re-running a failed workflow.

Ah okay this is good information. A similar implementation to work reverted in #1752 may suffice then, as long as it accounts for the failed stage. Unsure why at the moment though, I'd expect the cache entries to still be present and it would still run using the same SHA.

@danielbate
Copy link
Member Author

Closing this for now. This has been investigated by the above PRs and someone is welcome to have another go however the real value for our CI and better use of time will come from #2493 and #1755.

@danielbate danielbate closed this as not planned Won't fix, can't repro, duplicate, stale Jul 12, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
chore Issue is a chore
Projects
None yet
Development

No branches or pull requests

2 participants