mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
Merge pull request #16316 from vbatts/vbatts-events
daemon/events: let Log be [slightly] blocking
This commit is contained in:
commit
b9a3660d1e
2 changed files with 51 additions and 36 deletions
|
@ -45,19 +45,17 @@ func (e *Events) Evict(l chan interface{}) {
|
||||||
// Log broadcasts event to listeners. Each listener has 100 millisecond for
|
// Log broadcasts event to listeners. Each listener has 100 millisecond for
|
||||||
// receiving event or it will be skipped.
|
// receiving event or it will be skipped.
|
||||||
func (e *Events) Log(action, id, from string) {
|
func (e *Events) Log(action, id, from string) {
|
||||||
go func() {
|
jm := &jsonmessage.JSONMessage{Status: action, ID: id, From: from, Time: time.Now().UTC().Unix()}
|
||||||
e.mu.Lock()
|
e.mu.Lock()
|
||||||
jm := &jsonmessage.JSONMessage{Status: action, ID: id, From: from, Time: time.Now().UTC().Unix()}
|
if len(e.events) == cap(e.events) {
|
||||||
if len(e.events) == cap(e.events) {
|
// discard oldest event
|
||||||
// discard oldest event
|
copy(e.events, e.events[1:])
|
||||||
copy(e.events, e.events[1:])
|
e.events[len(e.events)-1] = jm
|
||||||
e.events[len(e.events)-1] = jm
|
} else {
|
||||||
} else {
|
e.events = append(e.events, jm)
|
||||||
e.events = append(e.events, jm)
|
}
|
||||||
}
|
e.mu.Unlock()
|
||||||
e.mu.Unlock()
|
e.pub.Publish(jm)
|
||||||
e.pub.Publish(jm)
|
|
||||||
}()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// SubscribersCount returns number of event listeners
|
// SubscribersCount returns number of event listeners
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package events
|
package events
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
@ -80,39 +81,55 @@ func TestEventsLogTimeout(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestEventsCap(t *testing.T) {
|
func TestLogEvents(t *testing.T) {
|
||||||
e := New()
|
e := New()
|
||||||
for i := 0; i < eventsLimit+1; i++ {
|
|
||||||
e.Log("action", "id", "from")
|
|
||||||
}
|
|
||||||
// let all events go through
|
|
||||||
time.Sleep(1 * time.Second)
|
|
||||||
|
|
||||||
|
for i := 0; i < eventsLimit+16; i++ {
|
||||||
|
action := fmt.Sprintf("action_%d", i)
|
||||||
|
id := fmt.Sprintf("cont_%d", i)
|
||||||
|
from := fmt.Sprintf("image_%d", i)
|
||||||
|
e.Log(action, id, from)
|
||||||
|
}
|
||||||
|
time.Sleep(50 * time.Millisecond)
|
||||||
current, l := e.Subscribe()
|
current, l := e.Subscribe()
|
||||||
if len(current) != eventsLimit {
|
for i := 0; i < 10; i++ {
|
||||||
t.Fatalf("Must be %d events, got %d", eventsLimit, len(current))
|
num := i + eventsLimit + 16
|
||||||
|
action := fmt.Sprintf("action_%d", num)
|
||||||
|
id := fmt.Sprintf("cont_%d", num)
|
||||||
|
from := fmt.Sprintf("image_%d", num)
|
||||||
|
e.Log(action, id, from)
|
||||||
}
|
}
|
||||||
if len(e.events) != eventsLimit {
|
if len(e.events) != eventsLimit {
|
||||||
t.Fatalf("Must be %d events, got %d", eventsLimit, len(e.events))
|
t.Fatalf("Must be %d events, got %d", eventsLimit, len(e.events))
|
||||||
}
|
}
|
||||||
|
|
||||||
for i := 0; i < 10; i++ {
|
|
||||||
e.Log("action", "id", "from")
|
|
||||||
}
|
|
||||||
// let all events go through
|
|
||||||
time.Sleep(1 * time.Second)
|
|
||||||
|
|
||||||
var msgs []*jsonmessage.JSONMessage
|
var msgs []*jsonmessage.JSONMessage
|
||||||
for len(msgs) < 10 {
|
for len(msgs) < 10 {
|
||||||
select {
|
m := <-l
|
||||||
case m := <-l:
|
jm, ok := (m).(*jsonmessage.JSONMessage)
|
||||||
jm, ok := (m).(*jsonmessage.JSONMessage)
|
if !ok {
|
||||||
if !ok {
|
t.Fatalf("Unexpected type %T", m)
|
||||||
t.Fatalf("Unexpected type %T", m)
|
|
||||||
}
|
|
||||||
msgs = append(msgs, jm)
|
|
||||||
default:
|
|
||||||
t.Fatalf("There is no enough events in channel")
|
|
||||||
}
|
}
|
||||||
|
msgs = append(msgs, jm)
|
||||||
|
}
|
||||||
|
if len(current) != eventsLimit {
|
||||||
|
t.Fatalf("Must be %d events, got %d", eventsLimit, len(current))
|
||||||
|
}
|
||||||
|
first := current[0]
|
||||||
|
if first.Status != "action_16" {
|
||||||
|
t.Fatalf("First action is %s, must be action_16", first.Status)
|
||||||
|
}
|
||||||
|
last := current[len(current)-1]
|
||||||
|
if last.Status != "action_79" {
|
||||||
|
t.Fatalf("Last action is %s, must be action_79", last.Status)
|
||||||
|
}
|
||||||
|
|
||||||
|
firstC := msgs[0]
|
||||||
|
if firstC.Status != "action_80" {
|
||||||
|
t.Fatalf("First action is %s, must be action_80", firstC.Status)
|
||||||
|
}
|
||||||
|
lastC := msgs[len(msgs)-1]
|
||||||
|
if lastC.Status != "action_89" {
|
||||||
|
t.Fatalf("Last action is %s, must be action_89", lastC.Status)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue