Index: client/internal/logdog/butler/bundler/binaryParser_test.go |
diff --git a/client/internal/logdog/butler/bundler/binaryParser_test.go b/client/internal/logdog/butler/bundler/binaryParser_test.go |
new file mode 100644 |
index 0000000000000000000000000000000000000000..426bf3b87e06994212c5c13074dc0a1dfa43f716 |
--- /dev/null |
+++ b/client/internal/logdog/butler/bundler/binaryParser_test.go |
@@ -0,0 +1,105 @@ |
+// 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 bundler |
+ |
+import ( |
+ "testing" |
+ "time" |
+ |
+ "github.com/luci/luci-go/common/logdog/protocol" |
+ . "github.com/smartystreets/goconvey/convey" |
+) |
+ |
+func TestBinaryParser(t *testing.T) { |
+ Convey(`A binaryParser with a threshold of 2.`, t, func() { |
+ s := &parserTestStream{ |
+ now: time.Date(2015, 1, 1, 0, 0, 0, 0, time.UTC), |
+ prefixIndex: 1337, |
+ } |
+ p := &binaryParser{ |
+ baseParser: s.base(), |
+ threshold: 2, |
+ } |
+ c := &constraints{ |
+ limit: 32, |
+ } |
+ |
+ Convey(`Loaded with data below the threshold`, func() { |
+ p.Append(data(s.now, 1)) |
+ Convey(`Returns nil when reading data smaller than the thresold.`, func() { |
+ le, err := p.nextEntry(c) |
+ So(err, ShouldBeNil) |
+ So(le, ShouldBeNil) |
+ }) |
+ |
+ Convey(`Returns a LogEntry when truncating.`, func() { |
+ c.truncate = true |
+ le, err := p.nextEntry(c) |
+ So(err, ShouldBeNil) |
+ So(le, shouldMatchLogEntry, s.le(0, protocol.Binary{ |
+ Data: []byte{1}, |
+ })) |
+ |
+ le, err = p.nextEntry(c) |
+ So(err, ShouldBeNil) |
+ So(le, ShouldBeNil) |
+ }) |
+ }) |
+ |
+ Convey(`Loaded with 10 bytes of data`, func() { |
+ p.Append(data(s.now, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9)) |
+ |
+ Convey(`Should yield all data with a limit of 32.`, func() { |
+ le, err := p.nextEntry(c) |
+ So(err, ShouldBeNil) |
+ So(le, shouldMatchLogEntry, s.le(0, protocol.Binary{ |
+ Data: []byte{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}, |
+ })) |
+ |
+ le, err = p.nextEntry(c) |
+ So(err, ShouldBeNil) |
+ So(le, ShouldBeNil) |
+ }) |
+ |
+ Convey(`Should yield [0..5], [6..9] with a limit of 6.`, func() { |
+ c.limit = 6 |
+ le, err := p.nextEntry(c) |
+ So(err, ShouldBeNil) |
+ So(le, shouldMatchLogEntry, s.le(0, protocol.Binary{ |
+ Data: []byte{0, 1, 2, 3, 4, 5}, |
+ })) |
+ |
+ le, err = p.nextEntry(c) |
+ So(err, ShouldBeNil) |
+ So(le, shouldMatchLogEntry, s.le(6, protocol.Binary{ |
+ Offset: 6, |
+ Data: []byte{6, 7, 8, 9}, |
+ })) |
+ |
+ le, err = p.nextEntry(c) |
+ So(err, ShouldBeNil) |
+ So(le, ShouldBeNil) |
+ }) |
+ }) |
+ |
+ Convey(`Loaded with 8 bytes of data from different times.`, func() { |
+ for i := 0; i < 8; i++ { |
+ p.Append(data(s.now.Add(time.Duration(i)*time.Second), byte(i))) |
+ } |
+ |
+ Convey(`Ignores the time boundary and returns all 8 bytes.`, func() { |
+ le, err := p.nextEntry(c) |
+ So(err, ShouldBeNil) |
+ So(le, shouldMatchLogEntry, s.le(0, protocol.Binary{ |
+ Data: []byte{0, 1, 2, 3, 4, 5, 6, 7}, |
+ })) |
+ |
+ le, err = p.nextEntry(c) |
+ So(err, ShouldBeNil) |
+ So(le, ShouldBeNil) |
+ }) |
+ }) |
+ }) |
+} |