Skip to content

Commit

Permalink
fix: properly handle variable and constant merging (#2129)
Browse files Browse the repository at this point in the history
## Description

This fixes variable and constant merging within component composability.

## Related Issue

Fixes #2125

## Type of change

- [X] Bug fix (non-breaking change which fixes an issue)
- [ ] New feature (non-breaking change which adds functionality)
- [ ] Other (security config, docs update, etc)

## Checklist before merging

- [X] Test, docs, adr added or updated as needed
- [X] [Contributor Guide
Steps](https://github.com/defenseunicorns/zarf/blob/main/CONTRIBUTING.md#developer-workflow)
followed
  • Loading branch information
Racer159 authored Nov 4, 2023
1 parent e255baa commit 6c2157a
Show file tree
Hide file tree
Showing 2 changed files with 188 additions and 6 deletions.
14 changes: 8 additions & 6 deletions src/pkg/packager/composer/list.go
Original file line number Diff line number Diff line change
Expand Up @@ -256,13 +256,14 @@ func (ic *ImportChain) MergeVariables(existing []types.ZarfPackageVariable) (mer
return v1.Name == v2.Name
}

merged = helpers.MergeSlices(existing, merged, exists)
node := ic.head
node := ic.tail
for node != nil {
// merge the vars
merged = helpers.MergeSlices(node.vars, merged, exists)
node = node.next
node = node.prev
}
merged = helpers.MergeSlices(existing, merged, exists)

return merged
}

Expand All @@ -272,13 +273,14 @@ func (ic *ImportChain) MergeConstants(existing []types.ZarfPackageConstant) (mer
return c1.Name == c2.Name
}

merged = helpers.MergeSlices(existing, merged, exists)
node := ic.head
node := ic.tail
for node != nil {
// merge the consts
merged = helpers.MergeSlices(node.consts, merged, exists)
node = node.next
node = node.prev
}
merged = helpers.MergeSlices(existing, merged, exists)

return merged
}

Expand Down
180 changes: 180 additions & 0 deletions src/pkg/packager/composer/list_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -259,6 +259,186 @@ func TestCompose(t *testing.T) {
}
}

func TestMerging(t *testing.T) {
t.Parallel()

type testCase struct {
name string
ic *ImportChain
existingVars []types.ZarfPackageVariable
existingConsts []types.ZarfPackageConstant
expectedVars []types.ZarfPackageVariable
expectedConsts []types.ZarfPackageConstant
}

head := Node{
vars: []types.ZarfPackageVariable{
{
Name: "TEST",
Default: "head",
},
{
Name: "HEAD",
},
},
consts: []types.ZarfPackageConstant{
{
Name: "TEST",
Value: "head",
},
{
Name: "HEAD",
},
},
}
tail := Node{
vars: []types.ZarfPackageVariable{
{
Name: "TEST",
Default: "tail",
},
{
Name: "TAIL",
},
},
consts: []types.ZarfPackageConstant{
{
Name: "TEST",
Value: "tail",
},
{
Name: "TAIL",
},
},
}
head.next = &tail
tail.prev = &head
testIC := &ImportChain{head: &head, tail: &tail}

testCases := []testCase{
{
name: "empty-ic",
ic: &ImportChain{},
existingVars: []types.ZarfPackageVariable{
{
Name: "TEST",
},
},
existingConsts: []types.ZarfPackageConstant{
{
Name: "TEST",
},
},
expectedVars: []types.ZarfPackageVariable{
{
Name: "TEST",
},
},
expectedConsts: []types.ZarfPackageConstant{
{
Name: "TEST",
},
},
},
{
name: "no-existing",
ic: testIC,
existingVars: []types.ZarfPackageVariable{},
existingConsts: []types.ZarfPackageConstant{},
expectedVars: []types.ZarfPackageVariable{
{
Name: "TEST",
Default: "head",
},
{
Name: "HEAD",
},
{
Name: "TAIL",
},
},
expectedConsts: []types.ZarfPackageConstant{
{
Name: "TEST",
Value: "head",
},
{
Name: "HEAD",
},
{
Name: "TAIL",
},
},
},
{
name: "with-existing",
ic: testIC,
existingVars: []types.ZarfPackageVariable{
{
Name: "TEST",
Default: "existing",
},
{
Name: "EXISTING",
},
},
existingConsts: []types.ZarfPackageConstant{
{
Name: "TEST",
Value: "existing",
},
{
Name: "EXISTING",
},
},
expectedVars: []types.ZarfPackageVariable{
{
Name: "TEST",
Default: "existing",
},
{
Name: "EXISTING",
},
{
Name: "HEAD",
},
{
Name: "TAIL",
},
},
expectedConsts: []types.ZarfPackageConstant{
{
Name: "TEST",
Value: "existing",
},
{
Name: "EXISTING",
},
{
Name: "HEAD",
},
{
Name: "TAIL",
},
},
},
}

for _, testCase := range testCases {
testCase := testCase

t.Run(testCase.name, func(t *testing.T) {
t.Parallel()

mergedVars := testCase.ic.MergeVariables(testCase.existingVars)
require.EqualValues(t, testCase.expectedVars, mergedVars)

mergedConsts := testCase.ic.MergeConstants(testCase.existingConsts)
require.EqualValues(t, testCase.expectedConsts, mergedConsts)
})
}
}

func createChainFromSlice(components []types.ZarfComponent) (ic *ImportChain) {
ic = &ImportChain{}

Expand Down

0 comments on commit 6c2157a

Please sign in to comment.