Skip to content

Commit

Permalink
fix: unable to close, unable to unref last: unable to cleanup compone…
Browse files Browse the repository at this point in the history
…nt version, while unref last: closing component version (#1243)

#### What this PR does / why we need it

When calling ocm-cli with oci-tag-version like
`0.0.1-20250108132333.build-af79499` e.g.

```bash
ocm get cv ocm-oci-test.int.repositories.cloud.sap//docker.io/recmo/docker-hello-tiny:0.0.1-20250108132333.build-af79499
```

It fails during the [finalize
step](https://github.com/open-component-model/ocm/blob/releases/v0.19/api/utils/refmgmt/refcloser.go#L196),
when [doing an
update](https://github.com/open-component-model/ocm/blob/releases/v0.19/api/ocm/extensions/repositories/genericocireg/componentversion.go#L171),
where [another round of version
comparison](https://github.com/open-component-model/ocm/blob/releases/v0.19/api/ocm/extensions/repositories/genericocireg/componentversion.go#L99)
happens.

#### Which issue(s) this PR fixes

Fixes: #1235

Related: #355
  • Loading branch information
hilmarf authored Jan 14, 2025
1 parent 2b764a2 commit f0103a8
Show file tree
Hide file tree
Showing 2 changed files with 91 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,12 @@ func (c *ComponentVersionContainer) SetReadOnly() {

func (c *ComponentVersionContainer) Check() error {
if c.version != c.GetDescriptor().Version {
// check if version contained '+' which has been replaced by META_SEPARATOR to create OCI compliant tag
if replaced, _ := toTag(c.GetDescriptor().Version); replaced != c.GetDescriptor().Version && replaced == c.version {
Logger(c.GetContext()).Warn(fmt.Sprintf(
"checked version %q contains %q, this is discouraged and you should prefer the original component version %q", c.version, META_SEPARATOR, c.GetDescriptor().Version))
return nil
}
return errors.ErrInvalid("component version", c.GetDescriptor().Version)
}
if c.comp.name != c.GetDescriptor().Name {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,85 @@
package genericocireg

import (
"testing"

"github.com/stretchr/testify/assert"

"ocm.software/ocm/api/ocm/internal"
"ocm.software/ocm/api/utils/accessobj"
)

func TestComponentVersionContainer_Check(t *testing.T) {
// Setup
state, err := accessobj.NewBlobStateForBlob(accessobj.ACC_READONLY, nil, NewStateHandler("mock.test.com/state_handler", "1.0.0"))
assert.NoError(t, err)
repo := &RepositoryImpl{ctx: internal.DefaultContext}
comp := &componentAccessImpl{repo: repo}
cvc := &ComponentVersionContainer{state: state, comp: comp}

// Test cases
tests := []struct {
name string
setup func()
expectErr bool
}{
{
name: "valid version and name",
setup: func() {
cvc.version = "1.0.0"
cvc.GetDescriptor().Version = "1.0.0"
cvc.comp.name = "test-component"
cvc.GetDescriptor().Name = "test-component"
},
expectErr: false,
},
{
name: "half valid version - containing META_SEPARATOR = " + META_SEPARATOR,
setup: func() {
cvc.version = "0.0.1-20250108132333.build-af79499"
cvc.GetDescriptor().Version = "0.0.1-20250108132333+af79499"
cvc.comp.name = "test-component"
cvc.GetDescriptor().Name = "test-component"
},
expectErr: false,
},
{
name: "valid version - containing '+'",
setup: func() {
cvc.version = "0.0.1-20250108132333+af79499"
cvc.GetDescriptor().Version = "0.0.1-20250108132333+af79499"
cvc.comp.name = "test-component"
cvc.GetDescriptor().Name = "test-component"
},
expectErr: false,
},
{
name: "invalid version",
setup: func() {
cvc.version = "1.0.0"
cvc.GetDescriptor().Version = "2.0.0"
},
expectErr: true,
},
{
name: "invalid name",
setup: func() {
cvc.comp.name = "test-component"
cvc.GetDescriptor().Name = "invalid-component"
},
expectErr: true,
},
}

for _, test := range tests {
t.Run(test.name, func(t *testing.T) {
test.setup()
err := cvc.Check()
if test.expectErr {
assert.Error(t, err)
} else {
assert.NoError(t, err)
}
})
}
}

0 comments on commit f0103a8

Please sign in to comment.