9b4aa7629c
Add mock builder backend Add tests for ARG in FROM Signed-off-by: Daniel Nephin <dnephin@docker.com>
151 lines
3.3 KiB
Go
151 lines
3.3 KiB
Go
package dockerfile
|
|
|
|
import (
|
|
"bufio"
|
|
"os"
|
|
"runtime"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/docker/docker/pkg/testutil/assert"
|
|
)
|
|
|
|
func TestShellParser4EnvVars(t *testing.T) {
|
|
fn := "envVarTest"
|
|
lineCount := 0
|
|
|
|
file, err := os.Open(fn)
|
|
assert.NilError(t, err)
|
|
defer file.Close()
|
|
|
|
scanner := bufio.NewScanner(file)
|
|
envs := []string{"PWD=/home", "SHELL=bash", "KOREAN=한국어"}
|
|
for scanner.Scan() {
|
|
line := scanner.Text()
|
|
lineCount++
|
|
|
|
// Trim comments and blank lines
|
|
i := strings.Index(line, "#")
|
|
if i >= 0 {
|
|
line = line[:i]
|
|
}
|
|
line = strings.TrimSpace(line)
|
|
|
|
if line == "" {
|
|
continue
|
|
}
|
|
|
|
words := strings.Split(line, "|")
|
|
assert.Equal(t, len(words), 3)
|
|
|
|
platform := strings.TrimSpace(words[0])
|
|
source := strings.TrimSpace(words[1])
|
|
expected := strings.TrimSpace(words[2])
|
|
|
|
// Key W=Windows; A=All; U=Unix
|
|
if platform != "W" && platform != "A" && platform != "U" {
|
|
t.Fatalf("Invalid tag %s at line %d of %s. Must be W, A or U", platform, lineCount, fn)
|
|
}
|
|
|
|
if ((platform == "W" || platform == "A") && runtime.GOOS == "windows") ||
|
|
((platform == "U" || platform == "A") && runtime.GOOS != "windows") {
|
|
newWord, err := ProcessWord(source, envs, '\\')
|
|
if expected == "error" {
|
|
assert.Error(t, err, "")
|
|
} else {
|
|
assert.NilError(t, err)
|
|
assert.Equal(t, newWord, expected)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestShellParser4Words(t *testing.T) {
|
|
fn := "wordsTest"
|
|
|
|
file, err := os.Open(fn)
|
|
if err != nil {
|
|
t.Fatalf("Can't open '%s': %s", err, fn)
|
|
}
|
|
defer file.Close()
|
|
|
|
envs := []string{}
|
|
scanner := bufio.NewScanner(file)
|
|
for scanner.Scan() {
|
|
line := scanner.Text()
|
|
|
|
if strings.HasPrefix(line, "#") {
|
|
continue
|
|
}
|
|
|
|
if strings.HasPrefix(line, "ENV ") {
|
|
line = strings.TrimLeft(line[3:], " ")
|
|
envs = append(envs, line)
|
|
continue
|
|
}
|
|
|
|
words := strings.Split(line, "|")
|
|
if len(words) != 2 {
|
|
t.Fatalf("Error in '%s' - should be exactly one | in: %q", fn, line)
|
|
}
|
|
test := strings.TrimSpace(words[0])
|
|
expected := strings.Split(strings.TrimLeft(words[1], " "), ",")
|
|
|
|
result, err := ProcessWords(test, envs, '\\')
|
|
|
|
if err != nil {
|
|
result = []string{"error"}
|
|
}
|
|
|
|
if len(result) != len(expected) {
|
|
t.Fatalf("Error. %q was suppose to result in %q, but got %q instead", test, expected, result)
|
|
}
|
|
for i, w := range expected {
|
|
if w != result[i] {
|
|
t.Fatalf("Error. %q was suppose to result in %q, but got %q instead", test, expected, result)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestGetEnv(t *testing.T) {
|
|
sw := &shellWord{
|
|
word: "",
|
|
envs: nil,
|
|
pos: 0,
|
|
}
|
|
|
|
sw.envs = []string{}
|
|
if sw.getEnv("foo") != "" {
|
|
t.Fatal("2 - 'foo' should map to ''")
|
|
}
|
|
|
|
sw.envs = []string{"foo"}
|
|
if sw.getEnv("foo") != "" {
|
|
t.Fatal("3 - 'foo' should map to ''")
|
|
}
|
|
|
|
sw.envs = []string{"foo="}
|
|
if sw.getEnv("foo") != "" {
|
|
t.Fatal("4 - 'foo' should map to ''")
|
|
}
|
|
|
|
sw.envs = []string{"foo=bar"}
|
|
if sw.getEnv("foo") != "bar" {
|
|
t.Fatal("5 - 'foo' should map to 'bar'")
|
|
}
|
|
|
|
sw.envs = []string{"foo=bar", "car=hat"}
|
|
if sw.getEnv("foo") != "bar" {
|
|
t.Fatal("6 - 'foo' should map to 'bar'")
|
|
}
|
|
if sw.getEnv("car") != "hat" {
|
|
t.Fatal("7 - 'car' should map to 'hat'")
|
|
}
|
|
|
|
// Make sure we grab the first 'car' in the list
|
|
sw.envs = []string{"foo=bar", "car=hat", "car=bike"}
|
|
if sw.getEnv("car") != "hat" {
|
|
t.Fatal("8 - 'car' should map to 'hat'")
|
|
}
|
|
}
|