author | Alberto Bertogli
<albertito@blitiri.com.ar> 2018-02-19 22:33:06 UTC |
committer | Alberto Bertogli
<albertito@blitiri.com.ar> 2018-03-02 19:37:28 UTC |
parent | 0ae5798d20ec26719379ccd672ecba3cb231009c |
internal/envelope/envelope.go | +6 | -4 |
internal/envelope/envelope_test.go | +26 | -0 |
diff --git a/internal/envelope/envelope.go b/internal/envelope/envelope.go index d0eb1d2..c504ad0 100644 --- a/internal/envelope/envelope.go +++ b/internal/envelope/envelope.go @@ -39,11 +39,13 @@ func DomainIn(addr string, locals *set.String) bool { } func AddHeader(data []byte, k, v string) []byte { - // If the value contains newlines, indent them properly. - if v[len(v)-1] == '\n' { - v = v[:len(v)-1] + if len(v) > 0 { + // If the value contains newlines, indent them properly. + if v[len(v)-1] == '\n' { + v = v[:len(v)-1] + } + v = strings.Replace(v, "\n", "\n\t", -1) } - v = strings.Replace(v, "\n", "\n\t", -1) header := []byte(fmt.Sprintf("%s: %s\n", k, v)) return append(header, data...) diff --git a/internal/envelope/envelope_test.go b/internal/envelope/envelope_test.go index e8746a7..661548d 100644 --- a/internal/envelope/envelope_test.go +++ b/internal/envelope/envelope_test.go @@ -41,3 +41,29 @@ func TestDomainIn(t *testing.T) { } } } + +func TestAddHeader(t *testing.T) { + cases := []struct { + data, k, v, expected string + }{ + {"", "Key", "Value", "Key: Value\n"}, + {"data", "Key", "Value", "Key: Value\ndata"}, + {"data", "Key", "Value\n", "Key: Value\ndata"}, + {"data", "Key", "L1\nL2", "Key: L1\n\tL2\ndata"}, + {"data", "Key", "L1\nL2\n", "Key: L1\n\tL2\ndata"}, + + // Degenerate cases: we don't expect to ever produce these, and the + // output is admittedly not nice, but they should at least not cause + // chasquid to crash. + {"data", "Key", "", "Key: \ndata"}, + {"data", "", "", ": \ndata"}, + {"", "", "", ": \n"}, + } + for i, c := range cases { + got := string(AddHeader([]byte(c.data), c.k, c.v)) + if got != c.expected { + t.Errorf("%d (%q -> %q): expected %q, got %q", + i, c.k, c.v, c.expected, got) + } + } +}