瀏覽代碼

Merge pull request #16316 from vbatts/vbatts-events

daemon/events: let Log be [slightly] blocking
David Calavera 10 年之前
父節點
當前提交
b9a3660d1e
共有 2 個文件被更改,包括 51 次插入36 次删除
  1. 11 13
      daemon/events/events.go
  2. 40 23
      daemon/events/events_test.go

+ 11 - 13
daemon/events/events.go

@@ -45,19 +45,17 @@ func (e *Events) Evict(l chan interface{}) {
 // Log broadcasts event to listeners. Each listener has 100 millisecond for
 // receiving event or it will be skipped.
 func (e *Events) Log(action, id, from string) {
-	go func() {
-		e.mu.Lock()
-		jm := &jsonmessage.JSONMessage{Status: action, ID: id, From: from, Time: time.Now().UTC().Unix()}
-		if len(e.events) == cap(e.events) {
-			// discard oldest event
-			copy(e.events, e.events[1:])
-			e.events[len(e.events)-1] = jm
-		} else {
-			e.events = append(e.events, jm)
-		}
-		e.mu.Unlock()
-		e.pub.Publish(jm)
-	}()
+	jm := &jsonmessage.JSONMessage{Status: action, ID: id, From: from, Time: time.Now().UTC().Unix()}
+	e.mu.Lock()
+	if len(e.events) == cap(e.events) {
+		// discard oldest event
+		copy(e.events, e.events[1:])
+		e.events[len(e.events)-1] = jm
+	} else {
+		e.events = append(e.events, jm)
+	}
+	e.mu.Unlock()
+	e.pub.Publish(jm)
 }
 
 // SubscribersCount returns number of event listeners

+ 40 - 23
daemon/events/events_test.go

@@ -1,6 +1,7 @@
 package events
 
 import (
+	"fmt"
 	"testing"
 	"time"
 
@@ -80,39 +81,55 @@ func TestEventsLogTimeout(t *testing.T) {
 	}
 }
 
-func TestEventsCap(t *testing.T) {
+func TestLogEvents(t *testing.T) {
 	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()
-	if len(current) != eventsLimit {
-		t.Fatalf("Must be %d events, got %d", eventsLimit, len(current))
+	for i := 0; i < 10; i++ {
+		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 {
 		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
 	for len(msgs) < 10 {
-		select {
-		case m := <-l:
-			jm, ok := (m).(*jsonmessage.JSONMessage)
-			if !ok {
-				t.Fatalf("Unexpected type %T", m)
-			}
-			msgs = append(msgs, jm)
-		default:
-			t.Fatalf("There is no enough events in channel")
+		m := <-l
+		jm, ok := (m).(*jsonmessage.JSONMessage)
+		if !ok {
+			t.Fatalf("Unexpected type %T", m)
 		}
+		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)
 	}
 }