Commit Graph

6474 Commits

Author SHA1 Message Date
Jonathan Lebon
76649127d1 lib/deploy: Rename variable for clarity
`size_to_remove` looks cryptic in contrast to
`new_new_bootcsum_dirs_total_size`. Rename it in the style of the latter
for easier reading.
2023-05-28 18:39:03 -04:00
Jonathan Lebon
a3c0d6a3fe lib/deploy: Log case when auto-pruning is hopeless
For easier diagnostics.
2023-05-28 18:38:53 -04:00
Jonathan Lebon
115d5cf073 lib/deploy: Drop unused variable
Noticed this diagnostic in my editor with clangd hooked up.
2023-05-28 18:38:38 -04:00
Jonathan Lebon
632ffa4302 lib/deploy: Initialize var to pacify gcc static analysis
Classic case of analysis getting confused by variables initialized by
a function.
2023-05-27 10:38:14 -04:00
Bartłomiej Piotrowski
99f6356b5b Use a value based on OSTREE_MAX_METADATA_SIZE 2023-05-26 12:09:13 +02:00
Bartłomiej Piotrowski
4bac96a8c8 Increase the metadata size limit to 128MB
Flathub has hit the 10MB limit in 2022, and we had to drop less popular
CPU architectures from the main summary to subsummaries, effectively
cutting off users running too old Flatpak version. Despite that, the
main summary containing only x86_64 is already at 7MB. As this is
eventually going to happen to subsummaries as well, preemptively bump
the limit 12 times.

It takes between 2 and 3 years for a change like this to roll out across
Linux distributions so the best time for this was yesterday.

fixes #2715
2023-05-25 11:49:54 +02:00
Colin Walters
c22576c41d prepare-root: Move sysroot.tmp creation earlier
Main motivation is prep for composefs in
https://github.com/ostreedev/ostree/pull/2640
In the interest of that, we add a `bool using_composefs` but
it's currently always `false`.

Co-authored-by: Alexander Larsson <alexl@redhat.com>
2023-05-24 15:50:38 -04:00
Colin Walters
50790b285e
Merge pull request #2860 from cgwalters/xshell2
tests: A bit more xshell porting
2023-05-22 13:37:10 -04:00
Joseph Marrero Corchado
b5b3ef78af
Merge pull request #2859 from jmarrero/release-2023.3
Release 2023.3
2023-05-18 17:09:04 -04:00
Colin Walters
88e8b671ce tests: A bit more xshell porting
Part of https://github.com/ostreedev/ostree/issues/2857
2023-05-18 08:14:50 -04:00
Joseph Marrero
88fe600ff8 configure: post-release version bump 2023-05-17 16:32:43 -04:00
Joseph Marrero
bf3495dbbf Release 2023.3 2023-05-17 16:29:04 -04:00
Colin Walters
16cb47489e
Merge pull request #2856 from cgwalters/port-to-xshell
tests/inst: Add xshell and use it in one place
2023-05-10 15:16:24 -04:00
Colin Walters
dc23b9389b tests/inst: Add xshell and use it in one place
I've deprecated sh-inline; in the end I think it is better
to minimize the amount of bash code we have.  xshell solves
the core convenience problem of taking local variables and mapping
them to command arguments.

A full port would be nontrivial; this just starts the ball
rolling.
2023-05-10 14:02:09 -04:00
Colin Walters
8a2993a9d0
Merge pull request #2565 from cgwalters/clang-format
Add .clang-format file + tree-wide: Run `clang-format`
2023-05-03 08:24:21 -04:00
Colin Walters
c1044a02b2 ci: Validate clang-format 2023-05-02 10:39:04 -04:00
Colin Walters
453aed97f6 tree-wide: Run clang-format
This is a one-time tree wide reformatting to ensure consistency
going forward.
2023-05-02 08:42:19 -04:00
Colin Walters
a917813bb8 clang-format: Don't align backslashes
This increases compatibility between clang-15 and clang-16.
Also, I don't care about the aesthetics here.
2023-05-02 08:42:19 -04:00
Colin Walters
1574f3f739 lib: Fix one include
We need all the ostree bits here.
2023-05-01 17:22:38 -04:00
Jonathan Lebon
dd70c9b78c
Merge pull request #2854 from cgwalters/clang-format-prep 2023-05-01 16:48:26 -04:00
Colin Walters
0e4768094c tree-wide: Fix various include ordering issues
This fixes the build with `clang-format`.
2023-05-01 15:37:57 -04:00
Colin Walters
abd5427c3b lib: clang-format ostree.h
In order to make this work, we need to move the autocleanup
definitions after the other headers.
2023-05-01 15:37:57 -04:00
Colin Walters
f56131976e Add clang formatting infrastructure
Prep for reformatting the codebase.
2023-05-01 15:37:56 -04:00
Colin Walters
d333f20b4a build-sys: Squash automake conditional warning re .PHONY 2023-05-01 14:21:37 -04:00
Colin Walters
919212d73b
Merge pull request #2847 from jlebon/pr/calculate-and-cleanup
lib/sysroot-deploy: Add experimental support for automatic early prune
2023-05-01 13:25:25 -04:00
Jonathan Lebon
c561e6179e lib/sysroot-deploy: Add experimental support for automatic early prune
During the early design of FCOS and RHCOS, we chose a value of 384M
for the boot partition. This turned out to be too small: some arches
other than x86_64 have larger initrds, kernel binaries, or additional
artifacts (like device tree blobs). We'll likely bump the boot partition
size in the future, but we don't want to abandon all the nodes deployed
with the current size.[[1]]

Because stale entries in `/boot` are cleaned up after new entries are
written, there is a window in the update process during which the bootfs
temporarily must host all the `(kernel, initrd)` pairs for the union of
current and new deployments.

This patch determines if the bootfs is capable of holding all the
pairs. If it can't but it could hold all the pairs from just the new
deployments, the outgoing deployments (e.g. rollbacks) are deleted
*before* new deployments are written. This is done by updating the
bootloader in two steps to maintain atomicity.

Since this is a lot of new logic in an important section of the
code, this feature is gated for now behind an environment variable
(`OSTREE_ENABLE_AUTO_EARLY_PRUNE`). Once we gain more experience with
it, we can consider turning it on by default.

This strategy increases the fallibility of the update system since one
would no longer be able to rollback to the previous deployment if a bug
is present in the bootloader update logic after auto-pruning (see [[2]]
and following). This is however mitigated by the fact that the heuristic
is opportunistic: the rollback is pruned *only if* it's the only way for
the system to update.

[1]: https://github.com/coreos/fedora-coreos-tracker/issues/1247
[2]: https://github.com/ostreedev/ostree/issues/2670#issuecomment-1179341883

Closes: #2670
2023-05-01 12:12:03 -04:00
Joseph Marrero Corchado
8b2ba4f401
Merge pull request #2853 from cgwalters/bump-msrv
rust: Bump MSRV to 1.64
2023-04-30 13:42:43 -04:00
Colin Walters
1b43b39574 rust: Bump MSRV to 1.64
Since a dependency `winnow` bumped to this in a recent update.
2023-04-29 17:11:58 -04:00
Colin Walters
b4dcfd7ede
Merge pull request #2849 from pwithnall/request-debugging
lib/fetcher: Add some debugging messages to the libsoup request path
2023-04-26 16:46:43 -04:00
Philip Withnall
77e334e5b4 lib/fetcher: Add some debugging messages to the libsoup request path
This will help with debugging stalled requests in future, such as
issue #605.

Signed-off-by: Philip Withnall <pwithnall@endlessos.org>

Helps: #605
2023-04-26 15:44:03 -04:00
Joseph Marrero Corchado
9c548d832c
Merge pull request #2850 from cgwalters/ci-no-error-deprecated-declarations
ci: Turn off errors for deprecated-declarations
2023-04-26 10:50:50 -04:00
Colin Walters
64aa5af236 ci: Drop workaround for fedora-release-container
I think this isn't necessary anymore, and is now actively broken
with f38.
2023-04-26 09:46:57 -04:00
Colin Walters
3391d8f3f0 ci: Turn off errors for deprecated-declarations
Having `-Werror` on in CI only by default has generally worked OK,
but I don't think it's worth trying to immediately scramble to port
when they deprecate APIs.

Motivated in this case by
```
 src/libostree/ostree-fetcher-curl.c: In function 'initiate_next_curl_request':
src/libostree/ostree-fetcher-curl.c:876:3: error: 'CURLOPT_PROTOCOLS' is deprecated: since 7.85.0. Use CURLOPT_PROTOCOLS_STR [-Werror=deprecated-declarations]
  876 |   rc = curl_easy_setopt (req->easy, CURLOPT_PROTOCOLS, (long)(CURLPROTO_HTTP | CURLPROTO_HTTPS | CURLPROTO_FILE));
      |   ^~
```
2023-04-26 09:37:22 -04:00
Jonathan Lebon
fd3304e987 tests/kolainst: Add make localinstall
When hacking and testing locally with `cosa build-fast` and `kola run`,
I prefer to leave testing framework stuff within the work directory
rather than installed in my pet container. Add a `localinstall` target
for this which puts the tests in `tests/kola`. Then a simple `kola run`
will pick it up.
2023-04-14 15:19:17 -04:00
Jonathan Lebon
771deb55d1 tests/kola: delete unused .gitignore
AFAICT, I don't see how `runkola.sh` or the Makefile in `tests/kolainst`
can create files in `tests/kola` since it's geared towards installing
under `/usr`.
2023-04-14 15:19:17 -04:00
Jonathan Lebon
45772ede3e lib/sysroot-deploy: Nuke finalize-failure.stamp on successful finalization
In the unusual case where one is manually finalizing staged deployments,
as can happen in testing, we expect a successful finalization to remove
the failure stamp file.
2023-04-14 15:19:17 -04:00
Colin Walters
90f7c7bd9f
Merge pull request #2848 from jlebon/pr/calculate-and-cleanup-prep
Prep patches for automatic early prune
2023-04-14 14:44:38 -04:00
Jonathan Lebon
462d413d2e libotutil: add utility functions for calculating directory size
Prep for future patch.
2023-04-14 09:57:16 -04:00
Jonathan Lebon
a0681cd201 lib/sysroot-cleanup: Make bootfs cleanup function global
Prep for future patch.
2023-04-14 09:57:16 -04:00
Jonathan Lebon
bf974e32fc lib/sysroot-cleanup: Factor out bootfs cleanup
Crawling through the bootfs and the deployment dirs was already mostly
separate. The only inefficiency here is that we now iterate over the
array of active deployments twice when building the hash tables. No
functional change otherwise.

Prep for future patch.
2023-04-14 09:57:16 -04:00
Jonathan Lebon
49eb8c04d5 lib/sysroot-cleanup: Drop dead code
We weren't actually using this `stbuf` anywhere.
2023-04-14 09:57:16 -04:00
Jonathan Lebon
898b1fdc70 lib/sysroot-cleanup: Make some static utility functions global
Prep for future patch.
2023-04-14 09:57:16 -04:00
Jonathan Lebon
91b6e5ded6 lib/sysroot-cleanup: Convert bootdir listing to dfd-relative
No functional change.
2023-04-14 09:55:38 -04:00
Dan Nicholson
e509b24a01
Merge pull request #2547 from q66/soup3
port to libsoup3
2023-04-13 10:05:01 -06:00
Dan Nicholson
a0407225f1 fetcher/soup3: Rewrite without threads
soup3 works best using only the async API from a single thread[1].
Rework the fetcher to stop using worker threads. In order to maximize
session usage across requests, sessions will be reused for each main
context.

1. https://libsoup.org/libsoup-3.0/client-thread-safety.html
2023-04-13 09:00:23 -06:00
Dan Nicholson
945f0a8602 ci: Add test configuration with soup3
This needs to be on Debian testing for now since bullseye doesn't have
soup3.
2023-04-12 22:34:23 -06:00
Daniel Kolesa
d0ea2db430 fetcher: add libsoup3 backend
The default is still soup2, you can use --with-soup3 to enable
the soup3 backend instead.
2023-04-12 22:33:08 -06:00
Dan Nicholson
3ec7b5db18 tests: Ensure real GIO backends aren't used
Set a few environment variables during tests to ensure fake GIO backends
are used. This is particularly important with the soup fetcher backend
as it can cause strange test errors in containerized test environments.
Upstream soup has been setting these 3 environment variables for their
tests since 2015.
2023-04-12 21:42:33 -06:00
Colin Walters
c9271423b1
Merge pull request #2839 from cgwalters/treegen-race
treegen: Require at least one mutation
2023-03-23 17:55:36 -04:00
Colin Walters
cafe12cf1f treegen: Require at least one mutation
Since a later assertion would otherwise trigger.  We saw
this happen in CI.
2023-03-23 16:48:55 -04:00