Skip to content

Commit

Permalink
Revert "Fix digest format for Signify (#12033)" (#12425)
Browse files Browse the repository at this point in the history
* Revert "quick fix (#12033)"

This reverts commit ea6bb32.

* Revert "Revert image digest to manifest digest, Switch to use digest.Hex instead of digest.String() (#12040)"

This reverts commit 709bacb.

* Fix unit tests
  • Loading branch information
Sawthis authored Dec 12, 2024
1 parent 29ca62e commit cb92c2a
Show file tree
Hide file tree
Showing 3 changed files with 79 additions and 17 deletions.
38 changes: 31 additions & 7 deletions pkg/sign/notary.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,10 @@ type ReferenceInterface interface {
type ImageInterface interface {
// Manifest retrieves the manifest of the image.
Manifest() (ManifestInterface, error)
// GetDigest returns the digest of the image manifest.
GetDigest() (string, error)
// GetSize returns the size of the image.
GetSize() (int64, error)
}

// ManifestInterface abstracts the functionality of v1.Manifest.
Expand Down Expand Up @@ -119,6 +123,20 @@ type ImageWrapper struct {
img v1.Image
}

// GetDigest returns the digest of the image manifest.
func (iw *ImageWrapper) GetDigest() (string, error) {
digest, err := iw.img.Digest()
if err != nil {
return "", err
}
return digest.Hex, nil
}

// GetSize returns the size of the image.
func (iw *ImageWrapper) GetSize() (int64, error) {
return iw.img.Size()
}

// Manifest retrieves the manifest of the image.
func (iw *ImageWrapper) Manifest() (ManifestInterface, error) {
manifest, err := iw.img.Manifest()
Expand All @@ -138,9 +156,9 @@ func (mw *ManifestWrapper) GetConfigSize() int64 {
return mw.manifest.Config.Size
}

// GetConfigDigest returns the digest of the image config.
// GetConfigDigest returns the digest of the image config without the algorithm prefix.
func (mw *ManifestWrapper) GetConfigDigest() string {
return mw.manifest.Config.Digest.Hex
return mw.manifest.Config.Digest.String()
}

// PayloadBuilderInterface defines the method for constructing the signing payload.
Expand Down Expand Up @@ -177,17 +195,23 @@ func (pb *PayloadBuilder) BuildPayload(images []string) (SigningPayload, error)
return SigningPayload{}, fmt.Errorf("failed to fetch image: %w", err)
}

// Retrieve the image manifest.
manifest, err := img.Manifest()
// Retrieve the image manifest digest.
imageDigest, err := img.GetDigest()
if err != nil {
return SigningPayload{}, fmt.Errorf("failed to get image digest: %w", err)
}

// Retrieve the image size.
imageSize, err := img.GetSize()
if err != nil {
return SigningPayload{}, fmt.Errorf("failed to get image manifest: %w", err)
return SigningPayload{}, fmt.Errorf("failed to get image size: %w", err)
}

// Build the target information.
target := Target{
Name: tag,
ByteSize: manifest.GetConfigSize(),
Digest: manifest.GetConfigDigest(),
ByteSize: imageSize,
Digest: imageDigest,
}

// Build the GUN (Global Unique Name) targets.
Expand Down
16 changes: 8 additions & 8 deletions pkg/sign/notary_mocks.go
Original file line number Diff line number Diff line change
Expand Up @@ -113,13 +113,6 @@ type MockImage struct {
MockGetSize func() (int64, error)
}

func (mi *MockImage) Manifest() (ManifestInterface, error) {
if mi.MockManifest != nil {
return mi.MockManifest()
}
return nil, fmt.Errorf("MockManifest not implemented")
}

func (mi *MockImage) GetDigest() (string, error) {
if mi.MockGetDigest != nil {
return mi.MockGetDigest()
Expand All @@ -131,7 +124,14 @@ func (mi *MockImage) GetSize() (int64, error) {
if mi.MockGetSize != nil {
return mi.MockGetSize()
}
return 0, fmt.Errorf("MockGetSize not implemented")
return 0, fmt.Errorf("MockGetDigest not implemented")
}

func (mi *MockImage) Manifest() (ManifestInterface, error) {
if mi.MockManifest != nil {
return mi.MockManifest()
}
return nil, fmt.Errorf("MockManifest not implemented")
}

// MockManifest implements ManifestInterface
Expand Down
42 changes: 40 additions & 2 deletions pkg/sign/notary_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,12 @@ func TestImageService_GetImage_Valid(t *testing.T) {
},
}, nil
},
MockGetDigest: func() (string, error) {
return "dummy-digest", nil
},
MockGetSize: func() (int64, error) {
return 1024, nil
},
}, nil
},
}
Expand All @@ -153,6 +159,23 @@ func TestImageService_GetImage_Valid(t *testing.T) {
if manifest.GetConfigDigest() != "sha256:dummy-digest" {
t.Errorf("Expected config digest to be 'sha256:dummy-digest', got '%s'", manifest.GetConfigDigest())
}

// Additional checks for new methods
digest, err := img.GetDigest()
if err != nil {
t.Errorf("Expected no error getting digest, got %v", err)
}
if digest != "dummy-digest" {
t.Errorf("Expected digest to be 'dummy-digest', got '%s'", digest)
}

size, err := img.GetSize()
if err != nil {
t.Errorf("Expected no error getting size, got %v", err)
}
if size != 1024 {
t.Errorf("Expected size to be 1024, got %d", size)
}
}

// TestImageService_GetImage_Invalid checks fetching an invalid image.
Expand Down Expand Up @@ -195,14 +218,20 @@ func TestPayloadBuilder_BuildPayload_Valid(t *testing.T) {
return 1024
},
MockGetConfigDigest: func() string {
return "sha256:dummy-digest"
return "sha256:dummy-config-digest"
},
}

mockImage := &MockImage{
MockManifest: func() (ManifestInterface, error) {
return mockManifest, nil
},
MockGetDigest: func() (string, error) {
return "dummy-manifest-digest", nil
},
MockGetSize: func() (int64, error) {
return 2048, nil
},
}

mockImageRepository := &MockImageRepository{
Expand All @@ -225,6 +254,15 @@ func TestPayloadBuilder_BuildPayload_Valid(t *testing.T) {
if len(payload.GunTargets) == 0 {
t.Errorf("Expected GunTargets to be populated")
}

// Additional checks
target := payload.GunTargets[0].Targets[0]
if target.Digest != "dummy-manifest-digest" {
t.Errorf("Expected digest to be 'dummy-manifest-digest', got '%s'", target.Digest)
}
if target.ByteSize != 2048 {
t.Errorf("Expected byteSize to be 2048, got %d", target.ByteSize)
}
}

// TestPayloadBuilder_BuildPayload_Invalid checks building a payload for invalid images.
Expand Down Expand Up @@ -345,7 +383,7 @@ func TestNotarySigner_Sign_Valid(t *testing.T) {
{
Name: "latest",
ByteSize: 1024,
Digest: "sha256:dummy-digest",
Digest: "dummy-manifest-digest",
},
},
},
Expand Down

0 comments on commit cb92c2a

Please sign in to comment.