mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-22 08:36:27 +01:00
v1: Allow empty files to be imported (#3421)
* add tests for an empty file * return nil from lexer.load when the file is empty
This commit is contained in:
parent
3b4f7a3c81
commit
240de5a5dd
2 changed files with 42 additions and 13 deletions
|
@ -48,6 +48,9 @@ func (l *lexer) load(input io.Reader) error {
|
|||
// discard byte order mark, if present
|
||||
firstCh, _, err := l.reader.ReadRune()
|
||||
if err != nil {
|
||||
if err == io.EOF {
|
||||
return nil
|
||||
}
|
||||
return err
|
||||
}
|
||||
if firstCh != 0xFEFF {
|
||||
|
|
|
@ -23,21 +23,47 @@ import (
|
|||
)
|
||||
|
||||
func TestAllTokens(t *testing.T) {
|
||||
input := strings.NewReader("a b c\nd e")
|
||||
expected := []string{"a", "b", "c", "d", "e"}
|
||||
tokens, err := allTokens(input)
|
||||
|
||||
if err != nil {
|
||||
t.Fatalf("Expected no error, got %v", err)
|
||||
}
|
||||
if len(tokens) != len(expected) {
|
||||
t.Fatalf("Expected %d tokens, got %d", len(expected), len(tokens))
|
||||
tests := []struct {
|
||||
name string
|
||||
input string
|
||||
expected []string
|
||||
}{
|
||||
{
|
||||
name: "not-empty",
|
||||
input: "a b c\nd e",
|
||||
expected: []string{"a", "b", "c", "d", "e"},
|
||||
}, {
|
||||
name: "empty",
|
||||
input: "",
|
||||
}, {
|
||||
name: "newline",
|
||||
input: "\n",
|
||||
}, {
|
||||
name: "space",
|
||||
input: " ",
|
||||
}, {
|
||||
name: "tab and newline",
|
||||
input: "\t\n",
|
||||
},
|
||||
}
|
||||
|
||||
for i, val := range expected {
|
||||
if tokens[i].Text != val {
|
||||
t.Errorf("Token %d should be '%s' but was '%s'", i, val, tokens[i].Text)
|
||||
}
|
||||
for _, tt := range tests {
|
||||
t.Run(tt.name, func(t *testing.T) {
|
||||
tokens, err := allTokens(strings.NewReader(tt.input))
|
||||
|
||||
if err != nil {
|
||||
t.Fatalf("Expected no error, got %v", err)
|
||||
}
|
||||
if len(tokens) != len(tt.expected) {
|
||||
t.Fatalf("Expected %d tokens, got %d", len(tt.expected), len(tokens))
|
||||
}
|
||||
|
||||
for i, val := range tt.expected {
|
||||
if tokens[i].Text != val {
|
||||
t.Errorf("Token %d should be '%s' but was '%s'", i, val, tokens[i].Text)
|
||||
}
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue