Skip to content
Snippets Groups Projects
events_test.g_ 1.58 KiB
Newer Older
// TODO: test has been disabled and needs to be re-enabled; tracked in issue
// https://github.com/eris-ltd/eris-db/issues/238

package event

import (
	"testing"

	"sync"
	"time"

	"github.com/stretchr/testify/assert"
	evts "github.com/tendermint/go-events"
)

func TestMultiplexedEvents(t *testing.T) {
	emitter1 := newMockEventEmitter()
	emitter2 := newMockEventEmitter()
	emitter12 := Multiplex(emitter1, emitter2)

	eventData1 := make(map[txs.EventData]int)
	eventData2 := make(map[txs.EventData]int)
	eventData12 := make(map[txs.EventData]int)

	mutex1 := &sync.Mutex{}
	mutex2 := &sync.Mutex{}
	mutex12 := &sync.Mutex{}

	emitter12.Subscribe("Sub12", "Event12", func(eventData txs.EventData) {
		mutex12.Lock()
		eventData12[eventData] = 1
		mutex12.Unlock()
	})
	emitter1.Subscribe("Sub1", "Event1", func(eventData txs.EventData) {
		mutex1.Lock()
		eventData1[eventData] = 1
		mutex1.Unlock()
	})
	emitter2.Subscribe("Sub2", "Event2", func(eventData txs.EventData) {
		mutex2.Lock()
		eventData2[eventData] = 1
		mutex2.Unlock()
	})

	time.Sleep(mockInterval)

	allEventData := make(map[txs.EventData]int)
	for k, v := range eventData1 {
		allEventData[k] = v
	}
	for k, v := range eventData2 {
		allEventData[k] = v
	}

	assert.Equal(t, map[txs.EventData]int{mockEventData{"Sub1", "Event1"}: 1},
	assert.Equal(t, map[txs.EventData]int{mockEventData{"Sub2", "Event2"}: 1},
	assert.Equal(t, map[txs.EventData]int{mockEventData{"Sub12", "Event12"}: 1},
		eventData12)

	assert.NotEmpty(t, allEventData, "Some events should have been published")
}