From 15df7a2ab73043f5852d576314ae090b2481dd67 Mon Sep 17 00:00:00 2001 From: Paul Meyer <49727155+katexochen@users.noreply.github.com> Date: Wed, 6 Mar 2024 09:47:04 +0100 Subject: [PATCH] e2e: read image replacements from file Signed-off-by: Paul Meyer <49727155+katexochen@users.noreply.github.com> --- e2e/internal/kuberesource/lookup.go | 46 +++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 e2e/internal/kuberesource/lookup.go diff --git a/e2e/internal/kuberesource/lookup.go b/e2e/internal/kuberesource/lookup.go new file mode 100644 index 0000000000..bd254c652b --- /dev/null +++ b/e2e/internal/kuberesource/lookup.go @@ -0,0 +1,46 @@ +package kuberesource + +import ( + "bufio" + "fmt" + "io" + "regexp" +) + +var replacementRE = regexp.MustCompile(`(?P[^\s=]+)\s*=\s*(?P\S+)`) + +// ImageReplacementsFromFile parses the containerlookup file into a map. +// +// The file is expected to contain newline-separated pairs of images and their intended +// replacement, separated by an = sign. Empty lines and lines starting with the pound character +// are ignored. This file is populated by container image build rules in the justfile. +func ImageReplacementsFromFile(file io.ReadCloser) (map[string]string, error) { + m := make(map[string]string) + + scanner := bufio.NewScanner(file) + for scanner.Scan() { + line := scanner.Text() + if len(line) == 0 || line[0] == '#' { + continue + } + + matches := replacementRE.FindStringSubmatch(line) + if matches == nil { + return nil, fmt.Errorf("invalid image line: %s", line) + } + + if replacementRE.SubexpIndex("image") == -1 { + return nil, fmt.Errorf("image not found for image line: %s", line) + } + image := matches[replacementRE.SubexpIndex("image")] + + if replacementRE.SubexpIndex("replacement") == -1 { + return nil, fmt.Errorf("replacement not found for image line: %s", line) + } + replacement := matches[replacementRE.SubexpIndex("replacement")] + + m[image] = replacement + } + + return m, nil +}