add debug buffer time based access

This commit is contained in:
Asim Aslam 2019-11-27 13:57:19 +00:00
parent 5932dd753c
commit 266b6dbc64
2 changed files with 70 additions and 6 deletions

View File

@ -3,12 +3,18 @@ package buffer
import ( import (
"sync" "sync"
"time"
) )
type Buffer struct { type Buffer struct {
size int size int
sync.RWMutex sync.RWMutex
vals []interface{} vals []*Entry
}
type Entry struct {
Value interface{}
Timestamp time.Time
} }
func (b *Buffer) Put(v interface{}) { func (b *Buffer) Put(v interface{}) {
@ -16,7 +22,10 @@ func (b *Buffer) Put(v interface{}) {
defer b.Unlock() defer b.Unlock()
// append to values // append to values
b.vals = append(b.vals, v) b.vals = append(b.vals, &Entry{
Value: v,
Timestamp: time.Now(),
})
// trim if bigger than size required // trim if bigger than size required
if len(b.vals) > b.size { if len(b.vals) > b.size {
@ -25,7 +34,7 @@ func (b *Buffer) Put(v interface{}) {
} }
// Get returns the last n entries // Get returns the last n entries
func (b *Buffer) Get(n int) []interface{} { func (b *Buffer) Get(n int) []*Entry {
// reset any invalid values // reset any invalid values
if n > b.size || n < 0 { if n > b.size || n < 0 {
n = b.size n = b.size
@ -46,6 +55,34 @@ func (b *Buffer) Get(n int) []interface{} {
return b.vals[delta:] return b.vals[delta:]
} }
// Return the entries since a specific time
func (b *Buffer) Since(t time.Time) []*Entry {
b.RLock()
defer b.RUnlock()
// return all the values
if t.IsZero() {
return b.vals
}
// if its in the future return nothing
if time.Since(t).Seconds() < 0.0 {
return nil
}
for i, v := range b.vals {
// find the starting point
d := v.Timestamp.Sub(t)
// return the values
if d.Seconds() > 0.0 {
return b.vals[i:]
}
}
return nil
}
func (b *Buffer) Size() int { func (b *Buffer) Size() int {
return b.size return b.size
} }

View File

@ -2,6 +2,7 @@ package buffer
import ( import (
"testing" "testing"
"time"
) )
func TestBuffer(t *testing.T) { func TestBuffer(t *testing.T) {
@ -11,7 +12,7 @@ func TestBuffer(t *testing.T) {
b.Put("foo") b.Put("foo")
v := b.Get(1) v := b.Get(1)
if val := v[0].(string); val != "foo" { if val := v[0].Value.(string); val != "foo" {
t.Fatalf("expected foo got %v", val) t.Fatalf("expected foo got %v", val)
} }
@ -22,10 +23,11 @@ func TestBuffer(t *testing.T) {
b.Put(i) b.Put(i)
} }
d := time.Now()
v = b.Get(10) v = b.Get(10)
for i := 0; i < 10; i++ { for i := 0; i < 10; i++ {
val := v[i].(int) val := v[i].Value.(int)
if val != i { if val != i {
t.Fatalf("expected %d got %d", i, val) t.Fatalf("expected %d got %d", i, val)
@ -42,11 +44,36 @@ func TestBuffer(t *testing.T) {
v = b.Get(10) v = b.Get(10)
for i := 0; i < 10; i++ { for i := 0; i < 10; i++ {
val := v[i].(int) val := v[i].Value.(int)
expect := i * 2 expect := i * 2
if val != expect { if val != expect {
t.Fatalf("expected %d got %d", expect, val) t.Fatalf("expected %d got %d", expect, val)
} }
} }
// sleep 100 ms
time.Sleep(time.Millisecond * 100)
// assume we'll get everything
v = b.Since(d)
if len(v) != 10 {
t.Fatalf("expected 10 entries but got %d", len(v))
}
// write 1 more entry
d = time.Now()
b.Put(100)
// sleep 100 ms
time.Sleep(time.Millisecond * 100)
v = b.Since(d)
if len(v) != 1 {
t.Fatalf("expected 1 entries but got %d", len(v))
}
if v[0].Value.(int) != 100 {
t.Fatalf("expected value 100 got %v", v[0])
}
} }