mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-03-30 15:08:33 +00:00

* Use a channel from within consensus in order to raise change events in order -- note that this is only a draft commit for discussion * Fix compilation * Check for nil * Allow nil virtualChangeChan * Remove redundant comments * Call notifyVirtualChange instead of notifyUTXOsChanged * Remove redundant comment * Add a separate function for initVirtualChangeHandler * Remove redundant type * Check for nil in the right place * Fix integration test * Add data to virtual changeset and cleanup block added event logic * Renames * Comment Co-authored-by: Ori Newman <orinewman1@gmail.com>
37 lines
860 B
Go
37 lines
860 B
Go
package consensus
|
|
|
|
import (
|
|
"github.com/kaspanet/kaspad/domain/consensus/model/externalapi"
|
|
"github.com/kaspanet/kaspad/domain/prefixmanager/prefix"
|
|
"io/ioutil"
|
|
"testing"
|
|
|
|
"github.com/kaspanet/kaspad/domain/dagconfig"
|
|
"github.com/kaspanet/kaspad/infrastructure/db/database/ldb"
|
|
)
|
|
|
|
func TestNewConsensus(t *testing.T) {
|
|
f := NewFactory()
|
|
|
|
config := &Config{Params: dagconfig.DevnetParams}
|
|
|
|
tmpDir, err := ioutil.TempDir("", "TestNewConsensus")
|
|
if err != nil {
|
|
return
|
|
}
|
|
|
|
db, err := ldb.NewLevelDB(tmpDir, 8)
|
|
if err != nil {
|
|
t.Fatalf("error in NewLevelDB: %s", err)
|
|
}
|
|
|
|
_, shouldMigrate, err := f.NewConsensus(config, db, &prefix.Prefix{}, make(chan *externalapi.VirtualChangeSet))
|
|
if err != nil {
|
|
t.Fatalf("error in NewConsensus: %+v", err)
|
|
}
|
|
|
|
if shouldMigrate {
|
|
t.Fatalf("A fresh consensus should never return shouldMigrate=true")
|
|
}
|
|
}
|