Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(269)

Unified Diff: client/logdog/butlerlib/streamclient/client_test.go

Issue 1429993002: LogDog: Add Butler stream server package. (Closed) Base URL: https://github.com/luci/luci-go@logdog-review-butlerproto
Patch Set: Fixed datagram check, now with unit tests! Created 5 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: client/logdog/butlerlib/streamclient/client_test.go
diff --git a/client/logdog/butlerlib/streamclient/client_test.go b/client/logdog/butlerlib/streamclient/client_test.go
new file mode 100644
index 0000000000000000000000000000000000000000..839b5a70428f47eae1ac83586b7b141e245a79ee
--- /dev/null
+++ b/client/logdog/butlerlib/streamclient/client_test.go
@@ -0,0 +1,109 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+package streamclient
+
+import (
+ "bytes"
+ "errors"
+ "io"
+ "testing"
+
+ "github.com/luci/luci-go/client/logdog/butlerlib/streamproto"
+ "github.com/luci/luci-go/common/clock/clockflag"
+ "github.com/luci/luci-go/common/clock/testclock"
+ "github.com/luci/luci-go/common/recordio"
+ . "github.com/smartystreets/goconvey/convey"
+)
+
+type testStreamWriteCloser struct {
+ bytes.Buffer
+ addr string
+
+ err error
+ closed bool
+}
+
+func (ts *testStreamWriteCloser) Write(d []byte) (int, error) {
+ if ts.err != nil {
+ return 0, ts.err
+ }
+ return ts.Buffer.Write(d)
+}
+
+func (ts *testStreamWriteCloser) Close() error {
+ ts.closed = true
+ return nil
+}
+
+func TestClient(t *testing.T) {
+ Convey(`A client registry with a test protocol`, t, func() {
+ tswcErr := error(nil)
+ tswc := (*testStreamWriteCloser)(nil)
+
+ reg := protocolRegistry{}
+ reg.register("test", func(addr string) (Client, error) {
+ return &clientImpl{
+ factory: func() (io.WriteCloser, error) {
+ tswc = &testStreamWriteCloser{
+ addr: addr,
+ err: tswcErr,
+ }
+ return tswc, nil
+ },
+ }, nil
+ })
+
+ flags := streamproto.Flags{
+ Name: "test",
+ Timestamp: clockflag.Time(testclock.TestTimeUTC),
+ }
+
+ Convey(`Will panic if the same protocol is registered twice.`, func() {
+ So(func() { reg.register("test", nil) }, ShouldPanic)
+ So(func() { reg.register("test2", nil) }, ShouldNotPanic)
+ })
+
+ Convey(`Will fail to instantiate a Client with an invalid protocol.`, func() {
+ _, err := reg.newClient("fake:foo")
+ So(err, ShouldNotBeNil)
+ })
+
+ Convey(`Can instantiate a new client.`, func() {
+ client, err := reg.newClient("test:foo")
+ So(err, ShouldBeNil)
+ So(client, ShouldHaveSameTypeAs, &clientImpl{})
+
+ Convey(`That can instantiate new Streams.`, func() {
+ stream, err := client.NewStream(flags)
+ So(err, ShouldBeNil)
+ So(stream, ShouldHaveSameTypeAs, &streamImpl{})
+
+ si := stream.(*streamImpl)
+ So(si.WriteCloser, ShouldHaveSameTypeAs, &testStreamWriteCloser{})
+
+ tswc := si.WriteCloser.(*testStreamWriteCloser)
+ So(tswc.addr, ShouldEqual, "foo")
+
+ Convey(`The stream should have the stream header written to it.`, func() {
+ So(tswc.Next(len(ProtocolFrameHeaderMagic)), ShouldResemble, ProtocolFrameHeaderMagic)
+
+ r := recordio.NewReader(tswc, -1)
+ f, err := r.ReadFrameAll()
+ So(err, ShouldBeNil)
+ So(string(f), ShouldResemble, `{"name":"test","timestamp":"0001-02-03T04:05:06.000000007Z"}`)
+ })
+ })
+
+ Convey(`If the stream fails to write the handshake, it will be closed.`, func() {
+ tswcErr = errors.New("test error")
+ _, err := client.NewStream(flags)
+ So(err, ShouldNotBeNil)
+
+ So(tswc, ShouldNotBeNil)
+ So(tswc.closed, ShouldBeTrue)
+ })
+ })
+ })
+}

Powered by Google App Engine
This is Rietveld 408576698