Files
fn-serverless/vendor/github.com/dghubble/go-twitter/twitter/stream_utils_test.go
Reed Allman 30f3c45dbc update vendor/ dir to latest w/o heroku, moby
had to lock a lot of things in place
2017-08-03 03:52:14 -07:00

112 lines
2.3 KiB
Go

package twitter
import (
"bufio"
"bytes"
"io"
"strings"
"testing"
"time"
"github.com/stretchr/testify/assert"
)
func TestStopped(t *testing.T) {
done := make(chan struct{})
assert.False(t, stopped(done))
close(done)
assert.True(t, stopped(done))
}
func TestSleepOrDone_Sleep(t *testing.T) {
wait := time.Nanosecond * 20
done := make(chan struct{})
completed := make(chan struct{})
go func() {
sleepOrDone(wait, done)
close(completed)
}()
// wait for goroutine SleepOrDone to sleep
assertDone(t, completed, defaultTestTimeout)
}
func TestSleepOrDone_Done(t *testing.T) {
wait := time.Second * 5
done := make(chan struct{})
completed := make(chan struct{})
go func() {
sleepOrDone(wait, done)
close(completed)
}()
// close done, interrupting SleepOrDone
close(done)
// assert that SleepOrDone exited, closing completed
assertDone(t, completed, defaultTestTimeout)
}
func TestStreamResponseBodyReader(t *testing.T) {
cases := []struct {
in []byte
want [][]byte
}{
{
in: []byte("foo\r\nbar\r\n"),
want: [][]byte{
[]byte("foo"),
[]byte("bar"),
},
},
{
in: []byte("foo\nbar\r\n"),
want: [][]byte{
[]byte("foo\nbar"),
},
},
{
in: []byte("foo\r\n\r\n"),
want: [][]byte{
[]byte("foo"),
[]byte(""),
},
},
{
in: []byte("foo\r\nbar"),
want: [][]byte{
[]byte("foo"),
[]byte("bar"),
},
},
{
// Message length is more than bufio.MaxScanTokenSize, which can't be
// parsed by bufio.Scanner with default buffer size.
in: []byte(strings.Repeat("X", bufio.MaxScanTokenSize+1) + "\r\n"),
want: [][]byte{
[]byte(strings.Repeat("X", bufio.MaxScanTokenSize+1)),
},
},
}
for _, c := range cases {
body := bytes.NewReader(c.in)
reader := newStreamResponseBodyReader(body)
for i, want := range c.want {
data, err := reader.readNext()
if err != nil {
t.Errorf("reader(%q).readNext() * %d: err == %q, want nil", c.in, i, err)
}
if !bytes.Equal(data, want) {
t.Errorf("reader(%q).readNext() * %d: data == %q, want %q", c.in, i, data, want)
}
}
data, err := reader.readNext()
if err != io.EOF {
t.Errorf("reader(%q).readNext() * %d: err == %q, want io.EOF", c.in, len(c.want), err)
}
if len(data) != 0 {
t.Errorf("reader(%q).readNext() * %d: data == %q, want \"\"", c.in, len(c.want), data)
}
}
}