2017-08-11 13:17:54 -07:00
|
|
|
// Copyright (c) 2017 The btcsuite developers
|
|
|
|
// Use of this source code is governed by an ISC
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
2017-08-19 19:21:36 -05:00
|
|
|
package blockchain
|
2017-08-11 13:17:54 -07:00
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2018-05-14 20:44:11 -07:00
|
|
|
"github.com/btcsuite/btcd/chaincfg"
|
2017-08-11 13:17:54 -07:00
|
|
|
)
|
|
|
|
|
2017-08-14 21:48:23 -05:00
|
|
|
// TestNotifications ensures that notification callbacks are fired on events.
|
2017-08-11 13:17:54 -07:00
|
|
|
func TestNotifications(t *testing.T) {
|
|
|
|
blocks, err := loadBlocks("blk_0_to_4.dat.bz2")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Error loading file: %v\n", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Create a new database and chain instance to run tests against.
|
2017-08-14 21:48:23 -05:00
|
|
|
chain, teardownFunc, err := chainSetup("notifications",
|
|
|
|
&chaincfg.MainNetParams)
|
2017-08-11 13:17:54 -07:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Failed to setup chain instance: %v", err)
|
|
|
|
}
|
|
|
|
defer teardownFunc()
|
|
|
|
|
2017-08-14 20:48:32 -07:00
|
|
|
notificationCount := 0
|
2017-08-19 19:21:36 -05:00
|
|
|
callback := func(notification *Notification) {
|
|
|
|
if notification.Type == NTBlockAccepted {
|
2017-08-14 20:48:32 -07:00
|
|
|
notificationCount++
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-14 21:48:23 -05:00
|
|
|
// Register callback multiple times then assert it is called that many
|
|
|
|
// times.
|
|
|
|
const numSubscribers = 3
|
|
|
|
for i := 0; i < numSubscribers; i++ {
|
|
|
|
chain.Subscribe(callback)
|
|
|
|
}
|
2017-08-11 13:17:54 -07:00
|
|
|
|
2017-08-19 19:21:36 -05:00
|
|
|
_, _, err = chain.ProcessBlock(blocks[1], BFNone)
|
2017-08-11 13:17:54 -07:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("ProcessBlock fail on block 1: %v\n", err)
|
|
|
|
}
|
|
|
|
|
2017-08-14 21:48:23 -05:00
|
|
|
if notificationCount != numSubscribers {
|
|
|
|
t.Fatalf("Expected notification callback to be executed %d "+
|
|
|
|
"times, found %d", numSubscribers, notificationCount)
|
2017-08-11 13:17:54 -07:00
|
|
|
}
|
|
|
|
}
|