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

Adds CI jobs for SPI to cover the combinations of digest_strategy and encoding_format #965

Open
wants to merge 21 commits into
base: main
Choose a base branch
from

Conversation

dcookspi
Copy link
Collaborator

This adds CI jobs for SPI to cover the combinations of digest_strategy and encoding_format settings so we have better testing coverage.

jrray and others added 21 commits January 26, 2024 12:17
This is needed to construct a test around empty platforms, but the flag
is hidden since it is not expected to be used in normal usage.

Note that the act of creating an empty runtime via `spfs run - -- bash`
causes an empty platform to be committed to storage. So it is possible,
but it wasn't possible via `spfs commit`.

Signed-off-by: J Robert Ray <jrray@jrray.org>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
An empty platform, something that will get created in storage when
starting an empty runtime, happens to have the same digest as a blob
containing 8 null bytes.

A file with 8 null bytes is something cargo will write in the target
directory under some circumstances.

Therefore, creating an spfs layer out of the target directory of a Rust
project can corrupt the spfs storage, as the blob object does not get
written since the file already exists, and that file is a platform
object.

This test serves to demonstrate the collision and then eventually verify
the collision problem has been fixed.

Signed-off-by: J Robert Ray <jrray@jrray.org>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
If the blob is written first and an object with that digest didn't
actually exist yet, then the blob "wins" control of that digest, and
then creating the platform doesn't replace the digest file on disk,
keeping it a blob. In that case, the test passes even though a collision
problem still exists.

Signed-off-by: J Robert Ray <jrray@jrray.org>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
The original header used a u64 for the kind of each object, this is now
split into pieces with two components and reserved space. Instead of 8
bytes for the uint we now have:

[ epoch, !, !, !, !, !, !, kind ], where each '!' is reserved space

Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
These two types look exactly the same, expect that the generated one
makes the internal bytes public. This is not particulary problematic,
and has the benefit of not needing to cast or convert any deserialized
digests in the future.

Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
Move `Object::kind` out of `impl Object` into its own trait so the
different object types can implement this trait and know their own kind.

Signed-off-by: J Robert Ray <jrray@imageworks.com>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
All top-level objects (that are constructed and stored on their own) are
now a specific variantion on an underlying generic type FlatObject.
These objects all contain the same AnyObject flatbuffer, with the more
specific types having validated the contained data as a specific
variant.

The main side effects of this are that:
 - a new Variant enum is created to enable the existing match-based
   disambiguation pattern
 - the spfs Repository trait can now have a generic write_object
   function that no longer requires wrapping the data in an emum before
   calling
 - objects must be constructed using the flatbuffer api, and types that
   are not top-level (tree, entry) cannot be created individually - only
   seen as references to data within the Manifest object

The removal of Tree and Entry as owned types also allows for removing
their references in other areas. They can no longer be encoded and saved
on their own, which was technically possible before but never done.

Signed-off-by: Ryan Bottriell <ryan@bottriell.ca>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
Signed-off-by: Ryan Bottriell <ryan@bottriell.ca>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
Signed-off-by: Ryan Bottriell <ryan@bottriell.ca>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
Signed-off-by: Ryan Bottriell <ryan@bottriell.ca>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
Signed-off-by: Ryan Bottriell <ryan@bottriell.ca>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
Signed-off-by: Ryan Bottriell <rbottriell@ilm.com>
Signed-off-by: Ryan Bottriell <ryan@bottriell.ca>
…_format

Signed-off-by: David Gilligan-Cook <dcook@imageworks.com>
@dcookspi dcookspi added SPI AOI Area of interest for SPI SPI-0.41 pr-chain This PR doesn't target the main branch, don't merge! labels Jan 31, 2024
@dcookspi dcookspi requested a review from jrray January 31, 2024 00:24
@dcookspi dcookspi self-assigned this Jan 31, 2024
@rydrman rydrman force-pushed the flatbuffer-objects branch from 8979b35 to 2190b10 Compare February 1, 2024 02:17
@rydrman rydrman force-pushed the flatbuffer-objects branch 2 times, most recently from 89a849a to 3725036 Compare March 7, 2024 03:37
@rydrman rydrman force-pushed the flatbuffer-objects branch 3 times, most recently from ed18c8d to 93d4c55 Compare March 13, 2024 23:29
Base automatically changed from flatbuffer-objects to main March 13, 2024 23:44
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
pr-chain This PR doesn't target the main branch, don't merge! SPI AOI Area of interest for SPI SPI-0.41
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants