open-nomad/helper/gated-writer/writer_test.go

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

130 lines
2.1 KiB
Go
Raw Normal View History

// Copyright (c) HashiCorp, Inc.
// SPDX-License-Identifier: MPL-2.0
2015-08-23 23:57:54 +00:00
package gatedwriter
2015-08-16 20:54:49 +00:00
import (
"bytes"
"io"
"strings"
"sync"
2015-08-16 20:54:49 +00:00
"testing"
"time"
"github.com/stretchr/testify/require"
2015-08-16 20:54:49 +00:00
)
2015-08-23 23:57:54 +00:00
func TestWriter_impl(t *testing.T) {
var _ io.Writer = new(Writer)
2015-08-16 20:54:49 +00:00
}
type slowTestWriter struct {
buf *bytes.Buffer
called chan struct{}
callCount int
}
func (w *slowTestWriter) Write(p []byte) (int, error) {
if w.callCount == 0 {
defer close(w.called)
}
w.callCount++
time.Sleep(time.Millisecond)
return w.buf.Write(p)
}
func TestWriter_WithSlowWriter(t *testing.T) {
buf := new(bytes.Buffer)
called := make(chan struct{})
w := &slowTestWriter{
buf: buf,
called: called,
}
writer := &Writer{Writer: w}
writer.Write([]byte("foo\n"))
writer.Write([]byte("bar\n"))
writer.Write([]byte("baz\n"))
flushed := make(chan struct{})
go func() {
writer.Flush()
close(flushed)
}()
// wait for the flush to call Write on slowTestWriter
<-called
// write to the now-flushing writer, which is no longer buffering
writer.Write([]byte("quux\n"))
// wait for the flush to finish to assert
<-flushed
require.Equal(t, "foo\nbar\nbaz\nquux\n", buf.String())
}
2015-08-23 23:57:54 +00:00
func TestWriter(t *testing.T) {
2015-08-16 20:54:49 +00:00
buf := new(bytes.Buffer)
2015-08-23 23:57:54 +00:00
w := &Writer{Writer: buf}
2015-08-16 20:54:49 +00:00
w.Write([]byte("foo\n"))
w.Write([]byte("bar\n"))
if buf.String() != "" {
t.Fatalf("bad: %s", buf.String())
}
w.Flush()
if buf.String() != "foo\nbar\n" {
t.Fatalf("bad: %s", buf.String())
}
w.Write([]byte("baz\n"))
if buf.String() != "foo\nbar\nbaz\n" {
t.Fatalf("bad: %s", buf.String())
}
}
func TestWriter_WithMultipleWriters(t *testing.T) {
buf := new(bytes.Buffer)
writer := &Writer{Writer: buf}
strs := []string{
"foo\n",
"bar\n",
"baz\n",
"quux\n",
}
waitCh := make(chan struct{})
wg := &sync.WaitGroup{}
for _, str := range strs {
str := str
wg.Add(1)
go func() {
defer wg.Done()
<-waitCh
writer.Write([]byte(str))
}()
}
// synchronize calls to Write() as closely as possible
close(waitCh)
wg.Wait()
writer.Flush()
require.Equal(t, strings.Count(buf.String(), "\n"), len(strs))
}