Skip to content

Commit

Permalink
Merge pull request #30 from kaessert/fix_manifest_ordering
Browse files Browse the repository at this point in the history
Fix ordering of input-manifests being scrambled, closes #29
  • Loading branch information
sergenyalcin authored Oct 8, 2024
2 parents ca0a50d + 937254d commit 7e8ad3e
Showing 1 changed file with 15 additions and 7 deletions.
22 changes: 15 additions & 7 deletions internal/prepare.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,11 @@ var (
caseDirectory = "case"
)

type injectedManifest struct {
Path string
Manifest string
}

type preparerOption func(*preparer)

func withDataSource(path string) preparerOption {
Expand Down Expand Up @@ -82,8 +87,8 @@ func (p *preparer) prepareManifests() ([]config.Manifest, error) {
}

manifests := make([]config.Manifest, 0, len(injectedFiles))
for path, data := range injectedFiles {
decoder := kyaml.NewYAMLOrJSONDecoder(bytes.NewBufferString(data), 1024)
for _, data := range injectedFiles {
decoder := kyaml.NewYAMLOrJSONDecoder(bytes.NewBufferString(data.Manifest), 1024)
for {
u := &unstructured.Unstructured{}
if err := decoder.Decode(&u); err != nil {
Expand All @@ -102,7 +107,7 @@ func (p *preparer) prepareManifests() ([]config.Manifest, error) {
return nil, errors.Wrapf(err, "cannot marshal manifest for \"%s/%s\"", u.GetObjectKind(), u.GetName())
}
manifests = append(manifests, config.Manifest{
FilePath: path,
FilePath: data.Path,
Object: u,
YAML: string(y),
})
Expand All @@ -112,7 +117,7 @@ func (p *preparer) prepareManifests() ([]config.Manifest, error) {
return manifests, nil
}

func (p *preparer) injectVariables() (map[string]string, error) {
func (p *preparer) injectVariables() ([]injectedManifest, error) {
dataSourceMap := make(map[string]string)
if p.dataSourcePath != "" {
dataSource, err := os.ReadFile(p.dataSourcePath)
Expand All @@ -124,13 +129,16 @@ func (p *preparer) injectVariables() (map[string]string, error) {
}
}

inputs := make(map[string]string, len(p.testFilePaths))
for _, f := range p.testFilePaths {
inputs := make([]injectedManifest, len(p.testFilePaths))
for i, f := range p.testFilePaths {
manifestData, err := os.ReadFile(filepath.Clean(f))
if err != nil {
return nil, errors.Wrapf(err, "cannot read %s", f)
}
inputs[f] = p.injectValues(string(manifestData), dataSourceMap)
inputs[i] = injectedManifest{
Path: f,
Manifest: p.injectValues(string(manifestData), dataSourceMap),
}
}
return inputs, nil
}
Expand Down

0 comments on commit 7e8ad3e

Please sign in to comment.