2020-09-18 00:34:03 +00:00
|
|
|
package logutil
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bufio"
|
|
|
|
"bytes"
|
|
|
|
"io"
|
|
|
|
"io/ioutil"
|
|
|
|
"net"
|
|
|
|
"net/http"
|
|
|
|
"net/http/httptest"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/testutil/require"
|
2020-10-06 13:32:48 +00:00
|
|
|
logTest "github.com/sirupsen/logrus/hooks/test"
|
2020-09-18 00:34:03 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type fakeAddr int
|
|
|
|
|
|
|
|
var (
|
|
|
|
localAddr = fakeAddr(1)
|
|
|
|
remoteAddr = fakeAddr(2)
|
|
|
|
)
|
|
|
|
|
|
|
|
func (a fakeAddr) Network() string {
|
|
|
|
return "net"
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a fakeAddr) String() string {
|
|
|
|
return "str"
|
|
|
|
}
|
|
|
|
|
|
|
|
type fakeNetConn struct {
|
|
|
|
io.Reader
|
|
|
|
io.Writer
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c fakeNetConn) Close() error { return nil }
|
|
|
|
func (c fakeNetConn) LocalAddr() net.Addr { return localAddr }
|
|
|
|
func (c fakeNetConn) RemoteAddr() net.Addr { return remoteAddr }
|
2020-10-12 08:11:05 +00:00
|
|
|
func (c fakeNetConn) SetDeadline(_ time.Time) error { return nil }
|
|
|
|
func (c fakeNetConn) SetReadDeadline(_ time.Time) error { return nil }
|
|
|
|
func (c fakeNetConn) SetWriteDeadline(_ time.Time) error { return nil }
|
2020-09-18 00:34:03 +00:00
|
|
|
|
|
|
|
type testResponseWriter struct {
|
|
|
|
brw *bufio.ReadWriter
|
|
|
|
http.ResponseWriter
|
|
|
|
}
|
|
|
|
|
|
|
|
func (resp *testResponseWriter) Hijack() (net.Conn, *bufio.ReadWriter, error) {
|
|
|
|
rw := bufio.NewReadWriter(bufio.NewReader(strings.NewReader("")), bufio.NewWriter(&bytes.Buffer{}))
|
|
|
|
return fakeNetConn{strings.NewReader(""), resp.brw}, rw, nil
|
|
|
|
}
|
|
|
|
|
2020-10-06 13:32:48 +00:00
|
|
|
func TestLogStreamServer_DisallowsNonLocalhostOrigin(t *testing.T) {
|
|
|
|
hook := logTest.NewGlobal()
|
|
|
|
ss := NewLogStreamServer()
|
|
|
|
br := bufio.NewReader(strings.NewReader(""))
|
|
|
|
buf := new(bytes.Buffer)
|
|
|
|
bw := bufio.NewWriter(buf)
|
|
|
|
rw := httptest.NewRecorder()
|
|
|
|
resp := &testResponseWriter{
|
|
|
|
brw: bufio.NewReadWriter(br, bw),
|
|
|
|
ResponseWriter: rw,
|
|
|
|
}
|
|
|
|
req := &http.Request{
|
|
|
|
Method: "GET",
|
|
|
|
Host: "externalsource",
|
|
|
|
Header: http.Header{
|
|
|
|
"Upgrade": []string{"websocket"},
|
|
|
|
"Connection": []string{"upgrade"},
|
|
|
|
"Sec-Websocket-Key": []string{"dGhlIHNhbXBsZSBub25jZQ=="},
|
|
|
|
"Sec-Websocket-Version": []string{"13"},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
ss.Handler(resp, req)
|
|
|
|
require.NoError(t, resp.brw.Flush())
|
|
|
|
require.LogsContain(t, hook, "origin not allowed")
|
|
|
|
}
|
|
|
|
|
2020-09-18 00:34:03 +00:00
|
|
|
func TestLogStreamServer_BackfillsMessages(t *testing.T) {
|
|
|
|
ss := NewLogStreamServer()
|
|
|
|
msgs := [][]byte{
|
|
|
|
[]byte("foo"),
|
|
|
|
[]byte("bar"),
|
|
|
|
[]byte("buzz"),
|
|
|
|
}
|
|
|
|
for _, msg := range msgs {
|
|
|
|
_, err := ss.Write(msg)
|
|
|
|
require.NoError(t, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
br := bufio.NewReader(strings.NewReader(""))
|
|
|
|
buf := new(bytes.Buffer)
|
|
|
|
bw := bufio.NewWriter(buf)
|
|
|
|
rw := httptest.NewRecorder()
|
|
|
|
resp := &testResponseWriter{
|
|
|
|
brw: bufio.NewReadWriter(br, bw),
|
|
|
|
ResponseWriter: rw,
|
|
|
|
}
|
|
|
|
req := &http.Request{
|
|
|
|
Method: "GET",
|
2020-10-06 13:32:48 +00:00
|
|
|
Host: "localhost",
|
2020-09-18 00:34:03 +00:00
|
|
|
Header: http.Header{
|
|
|
|
"Upgrade": []string{"websocket"},
|
|
|
|
"Connection": []string{"upgrade"},
|
|
|
|
"Sec-Websocket-Key": []string{"dGhlIHNhbXBsZSBub25jZQ=="},
|
|
|
|
"Sec-Websocket-Version": []string{"13"},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2020-10-06 13:32:48 +00:00
|
|
|
ss.Handler(resp, req)
|
|
|
|
go ss.sendLogsToClients()
|
2020-09-18 00:34:03 +00:00
|
|
|
require.NoError(t, resp.brw.Flush())
|
|
|
|
dst, err := ioutil.ReadAll(buf)
|
|
|
|
require.NoError(t, err)
|
|
|
|
for _, msg := range msgs {
|
|
|
|
if !strings.Contains(string(dst), string(msg)) {
|
|
|
|
t.Errorf("Stream does contain message %s", msg)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|