-
Notifications
You must be signed in to change notification settings - Fork 45
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
WIP: bundle #586
base: master
Are you sure you want to change the base?
WIP: bundle #586
Conversation
I would argue that the tarball download optimization is some welcome but unrelated optimization. I would move it to some separate PR that should probably be merged first. Reusing the URL SCM for the bundles is IMHO not the right approach. It should instead work like the From a more general angle: should this work for indeterministic checkouts too? I would argue against this and only bundle deterministic checkouts. But if there is a good reason to decide otherwise I'm open to it. It's just that my gut feeling is that it will get nasty to get all corner cases correct... |
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## master #586 +/- ##
==========================================
+ Coverage 88.86% 88.93% +0.06%
==========================================
Files 48 48
Lines 15474 15646 +172
==========================================
+ Hits 13751 13914 +163
- Misses 1723 1732 +9 ☔ View full report in Codecov by Sentry. |
I added a new implementation using the archive stuff. Since adding files to the final bundle using To get the blackbox test working #606 is required. As of today I haven't tested bundling / unbundling a larger, real world project. I'll do this in the next days. |
Separate the downloaded files from the extracted files by downloading them into a `download` directory next to the workspace. Also the canary is generated there. The Gzip and XZ-Extractor always extract the files into the directory of the compressed file. Therefor the compressed files is copied into the workspace-directory first. By removing `-k`the compressed files are no longer kept. To trigger a attic move of old workspaces a version information is added to the url-scm spec.
Delete the download directory if the scm-workspace is moved to attic.
'upload' and 'download' did not fit for all archives.
This special archive is used to bundle checkoutWorkspaces into a single tar-file.
And use the builder functions to enable and finish bundling.
Bundle the results of all checkoutSteps needed to build a package and provide a bundle-config file to be able to rebuild the package only with the bundle.
Such a bundle can be used to build on a air-gapped system or to archive all sources of a build. When building from the bundle only the bundle is extracted but no other
checkoutScripts
are run.There is one issue with the actual URL-Scm extraction. The source workspace contains both, the original downloaded file and the extracted sources. This unnecessarily doubles the size of the bundle and - since the bundle-extraction uses the UrlScm as well - produces a different workspace hash when the bundle is extracted. That's why I changed to download the original file into
workspace/../_download
where also the.extracted
file is placed. This change makes the unittest-failing ATM as the../_download
folder is always the same when using a tempDir.I'm not sure how to proceed here:
workspace/.bob-download/
) for the downloaded files and exclude this directory when hashing / bundling?