aboutsummaryrefslogtreecommitdiffstats
path: root/modules/eventsource/event_test.go
blob: a80e062f0e5517a9d5680ae6b82b242e7464bb46 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
// Copyright 2020 The Gitea Authors. All rights reserved.
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.

package eventsource

import (
	"bytes"
	"testing"
)

func Test_wrapNewlines(t *testing.T) {
	tests := []struct {
		name   string
		prefix string
		value  string
		output string
	}{
		{
			"check no new lines",
			"prefix: ",
			"value",
			"prefix: value\n",
		},
		{
			"check simple newline",
			"prefix: ",
			"value1\nvalue2",
			"prefix: value1\nprefix: value2\n",
		},
		{
			"check pathological newlines",
			"p: ",
			"\n1\n\n2\n3\n",
			"p: \np: 1\np: \np: 2\np: 3\np: \n",
		},
	}
	for _, tt := range tests {
		t.Run(tt.name, func(t *testing.T) {
			w := &bytes.Buffer{}
			gotSum, err := wrapNewlines(w, []byte(tt.prefix), []byte(tt.value))
			if err != nil {
				t.Errorf("wrapNewlines() error = %v", err)
				return
			}
			if gotSum != int64(len(tt.output)) {
				t.Errorf("wrapNewlines() = %v, want %v", gotSum, int64(len(tt.output)))
			}
			if gotW := w.String(); gotW != tt.output {
				t.Errorf("wrapNewlines() = %v, want %v", gotW, tt.output)
			}
		})
	}
}