Commit 7f4d3f5
test(e2e): replace MinIO with RustFS in the object storage test harness (cloudnative-pg#10865)
The MinIO and mc images used by the e2e suite are pinned to the last
Apache-2.0 releases and no longer receive updates. This PR replaces the
whole stack: the in-cluster object storage server becomes RustFS, and
the client pod used to inspect the store becomes the AWS CLI.
The server keeps the existing TLS setup, with the certificates generated
by the test suite projected under the names RustFS expects. Since the
RustFS image runs as a non-root user, the pod sets an fsGroup so the
data volume and the certificates stay accessible. The query helpers keep
their signatures: listing and counting enumerate every bucket through
the S3 API and filter the results with a regular expression derived from
the previous glob semantics, tags are read with get-object-tagging, and
the forged-WAL helper uses a server-side copy. A failure enumerating the
buckets aborts the listing, so an unreachable endpoint surfaces as an
error instead of an empty result, and the per-bucket listings run in
parallel so the cost of a poll does not grow linearly with the number of
buckets accumulated during a run. Checksum calculation is pinned to
when_required because the CRC-based defaults introduced in AWS CLI 2.23
are not supported by every S3-compatible object store.
With MinIO gone, the harness is also renamed to provider-neutral terms:
the minio Go packages become objectstore, the in-cluster resources move
to the object-store namespace and service with matching secret names,
the fixtures and their file names are renamed accordingly, the timeout
keys become walsInObjectStore and objectStoreInstallation, and the spec
texts stop mentioning MinIO. Note that the spec renames are a one-time
discontinuity for anything tracking test names across runs, and any
out-of-tree TEST_TIMEOUTS override needs the new keys. The user-facing
documentation, where MinIO is presented as one of the supported object
stores, is intentionally unchanged.
Verified on kind by running the backup and restore, backup tags, and
parallel WAL restore specs against the new harness: barman-cloud bucket
auto-creation, TLS, object tagging, and server-side copy all work
against RustFS with both the old and the new client.
Closes cloudnative-pg#6572
Closes cloudnative-pg#8967
Signed-off-by: Armando Ruocco <armando.ruocco@enterprisedb.com>
Signed-off-by: Niccolò Fei <niccolo.fei@enterprisedb.com>
Signed-off-by: Marco Nenciarini <marco.nenciarini@enterprisedb.com>
Co-authored-by: Niccolò Fei <niccolo.fei@enterprisedb.com>
Co-authored-by: Marco Nenciarini <marco.nenciarini@enterprisedb.com>
(cherry picked from commit e7419df)1 parent b90bd79 commit 7f4d3f5
70 files changed
Lines changed: 1445 additions & 1596 deletions
File tree
- .github
- hack/testing-tools
- common
- k8s-engines
- tests
- e2e
- fixtures
- backup
- backup_restore_safety
- object_store
- recovery_external_clusters
- scheduled_backup_immediate
- scheduled_backup_suspend
- replica_mode_cluster
- tablespaces
- upgrade
- volume_snapshot
- internal/asserts/objectstore
- utils
- backups
- logs
- minio
- objectstore
- timeouts
Some content is hidden
Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
13 | | - | |
14 | | - | |
| 13 | + | |
| 14 | + | |
15 | 15 | | |
16 | 16 | | |
17 | 17 | | |
| |||
27 | 27 | | |
28 | 28 | | |
29 | 29 | | |
30 | | - | |
31 | | - | |
| 30 | + | |
| 31 | + | |
32 | 32 | | |
33 | 33 | | |
34 | 34 | | |
| |||
44 | 44 | | |
45 | 45 | | |
46 | 46 | | |
47 | | - | |
48 | | - | |
| 47 | + | |
| 48 | + | |
49 | 49 | | |
50 | 50 | | |
51 | 51 | | |
| |||
61 | 61 | | |
62 | 62 | | |
63 | 63 | | |
64 | | - | |
65 | | - | |
| 64 | + | |
| 65 | + | |
66 | 66 | | |
67 | 67 | | |
68 | 68 | | |
| |||
78 | 78 | | |
79 | 79 | | |
80 | 80 | | |
81 | | - | |
82 | | - | |
| 81 | + | |
| 82 | + | |
83 | 83 | | |
84 | 84 | | |
85 | 85 | | |
| |||
95 | 95 | | |
96 | 96 | | |
97 | 97 | | |
98 | | - | |
99 | | - | |
| 98 | + | |
| 99 | + | |
100 | 100 | | |
101 | 101 | | |
102 | 102 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
98 | 98 | | |
99 | 99 | | |
100 | 100 | | |
101 | | - | |
| 101 | + | |
102 | 102 | | |
103 | 103 | | |
104 | | - | |
105 | | - | |
| 104 | + | |
| 105 | + | |
106 | 106 | | |
107 | 107 | | |
108 | | - | |
| 108 | + | |
109 | 109 | | |
110 | 110 | | |
111 | 111 | | |
| |||
227 | 227 | | |
228 | 228 | | |
229 | 229 | | |
230 | | - | |
| 230 | + | |
| 231 | + | |
231 | 232 | | |
232 | 233 | | |
233 | 234 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
39 | 39 | | |
40 | 40 | | |
41 | 41 | | |
42 | | - | |
43 | | - | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
44 | 47 | | |
45 | 48 | | |
46 | 49 | | |
| |||
61 | 64 | | |
62 | 65 | | |
63 | 66 | | |
64 | | - | |
65 | | - | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
66 | 73 | | |
67 | 74 | | |
68 | 75 | | |
69 | 76 | | |
70 | | - | |
| 77 | + | |
71 | 78 | | |
72 | 79 | | |
73 | 80 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
222 | 222 | | |
223 | 223 | | |
224 | 224 | | |
225 | | - | |
| 225 | + | |
| 226 | + | |
226 | 227 | | |
227 | 228 | | |
228 | 229 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
26 | 26 | | |
27 | 27 | | |
28 | 28 | | |
29 | | - | |
| 29 | + | |
30 | 30 | | |
31 | 31 | | |
32 | 32 | | |
| |||
468 | 468 | | |
469 | 469 | | |
470 | 470 | | |
471 | | - | |
| 471 | + | |
472 | 472 | | |
473 | 473 | | |
474 | 474 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
26 | 26 | | |
27 | 27 | | |
28 | 28 | | |
29 | | - | |
| 29 | + | |
30 | 30 | | |
31 | 31 | | |
32 | 32 | | |
| |||
397 | 397 | | |
398 | 398 | | |
399 | 399 | | |
400 | | - | |
| 400 | + | |
401 | 401 | | |
402 | 402 | | |
403 | 403 | | |
| |||
0 commit comments