From a2dac4507b4292bbcfa6afb6713e7b1cfb161b9a Mon Sep 17 00:00:00 2001 From: Vsevolod Brekelov Date: Thu, 12 Dec 2019 16:01:22 +0300 Subject: [PATCH 1/3] performance: add performance test In order to run it use: go test -bench=. -benchmem --- integration/README.md | 20 +++++++++ integration/performance_test.go | 76 +++++++++++++++++++++++++++++++++ 2 files changed, 96 insertions(+) create mode 100644 integration/README.md create mode 100644 integration/performance_test.go diff --git a/integration/README.md b/integration/README.md new file mode 100644 index 000000000..4903a78ff --- /dev/null +++ b/integration/README.md @@ -0,0 +1,20 @@ +# Integration package +The main goal is to have integration tests here. + +### Performance test +Right now we have `performance_test.go` to measure number of processed TX per second. +In order to run it: +``` +$ cd integration +$ go test -bench=. -benchmem +``` + +Result: +``` +10000 402421 ns/op 177370 B/op 90 allocs/op +PASS +ok github.com/CityOfZion/neo-go/integration 4.360s + +``` + +Which means that in 4.360 seconds neo-go processes 10 000 transactions. \ No newline at end of file diff --git a/integration/performance_test.go b/integration/performance_test.go new file mode 100644 index 000000000..f794e1502 --- /dev/null +++ b/integration/performance_test.go @@ -0,0 +1,76 @@ +package integration + +import ( + "math/rand" + "testing" + + "github.com/CityOfZion/neo-go/config" + "github.com/CityOfZion/neo-go/pkg/core" + "github.com/CityOfZion/neo-go/pkg/core/storage" + "github.com/CityOfZion/neo-go/pkg/core/transaction" + "github.com/CityOfZion/neo-go/pkg/network" + "github.com/stretchr/testify/require" +) + +// Benchmark test to measure number of processed TX. +// Same benchmark made on reference C# node https://github.com/neo-project/neo/issues/1321. +func BenchmarkTXPerformanceTest(t *testing.B) { + net := config.ModeUnitTestNet + configPath := "../config" + cfg, err := config.Load(configPath, net) + require.NoError(t, err, "could not load config") + + memoryStore := storage.NewMemoryStore() + chain, err := core.NewBlockchain(memoryStore, cfg.ProtocolConfiguration) + require.NoError(t, err, "could not create chain") + + go chain.Run() + + serverConfig := network.NewServerConfig(cfg) + server := network.NewServer(serverConfig, chain) + for n := 0; n < t.N; n++ { + tx := getTX() + require.Equal(t, server.RelayTxn(tx), network.RelaySucceed) + require.Equal(t, server.RelayTxn(tx), network.RelayAlreadyExists) + } + chain.Close() +} + +// getTX returns Invocation transaction with some random attributes in order to have different hashes. +func getTX() *transaction.Transaction { + tx := &transaction.Transaction{ + Type: transaction.InvocationType, + Version: 0, + Data: &transaction.InvocationTX{ + Script: []byte{0x51}, + Gas: 1, + Version: 1, + }, + Attributes: []transaction.Attribute{}, + Inputs: []transaction.Input{}, + Outputs: []transaction.Output{}, + Scripts: []transaction.Witness{}, + Trimmed: false, + } + tx.Attributes = append(tx.Attributes, + transaction.Attribute{ + Usage: transaction.Description, + Data: []byte(randString(10)), + }) + return tx +} + +// String returns a random string with the n as its length. +func randString(n int) string { + b := make([]byte, n) + for i := range b { + b[i] = byte(Int(65, 90)) + } + + return string(b) +} + +// Int returns a random integer in [min,max). +func Int(min, max int) int { + return min + rand.Intn(max-min) +} From eeb2fb700436b1cc01f08f1738422c985e1e2659 Mon Sep 17 00:00:00 2001 From: Vsevolod Brekelov Date: Thu, 12 Dec 2019 21:13:54 +0300 Subject: [PATCH 2/3] integration: add signing tx --- integration/performance_test.go | 46 ++++++++++++++++++++++++++++++--- 1 file changed, 42 insertions(+), 4 deletions(-) diff --git a/integration/performance_test.go b/integration/performance_test.go index f794e1502..2a3b8789d 100644 --- a/integration/performance_test.go +++ b/integration/performance_test.go @@ -8,7 +8,10 @@ import ( "github.com/CityOfZion/neo-go/pkg/core" "github.com/CityOfZion/neo-go/pkg/core/storage" "github.com/CityOfZion/neo-go/pkg/core/transaction" + "github.com/CityOfZion/neo-go/pkg/crypto" + "github.com/CityOfZion/neo-go/pkg/crypto/keys" "github.com/CityOfZion/neo-go/pkg/network" + "github.com/CityOfZion/neo-go/pkg/rpc" "github.com/stretchr/testify/require" ) @@ -28,16 +31,46 @@ func BenchmarkTXPerformanceTest(t *testing.B) { serverConfig := network.NewServerConfig(cfg) server := network.NewServer(serverConfig, chain) + data := prepareData(t) + t.ResetTimer() + for n := 0; n < t.N; n++ { - tx := getTX() - require.Equal(t, server.RelayTxn(tx), network.RelaySucceed) - require.Equal(t, server.RelayTxn(tx), network.RelayAlreadyExists) + require.Equal(t, server.RelayTxn(data[n]), network.RelaySucceed) + require.Equal(t, server.RelayTxn(data[n]), network.RelayAlreadyExists) } chain.Close() } +func prepareData(t *testing.B) []*transaction.Transaction { + var data []*transaction.Transaction + + wif := getWif(t) + + for n := 0; n < t.N; n++ { + tx := getTX(t, wif) + require.NoError(t, rpc.SignTx(tx, wif)) + data = append(data, tx) + } + return data +} + +// getWif returns Wif. +func getWif(t *testing.B) *keys.WIF { + var ( + wifEncoded = "KxhEDBQyyEFymvfJD96q8stMbJMbZUb6D1PmXqBWZDU2WvbvVs9o" + version = byte(0x00) + ) + wif, err := keys.WIFDecode(wifEncoded, version) + require.NoError(t, err) + return wif +} + // getTX returns Invocation transaction with some random attributes in order to have different hashes. -func getTX() *transaction.Transaction { +func getTX(t *testing.B, wif *keys.WIF) *transaction.Transaction { + fromAddress := wif.PrivateKey.Address() + fromAddressHash, err := crypto.Uint160DecodeAddress(fromAddress) + require.NoError(t, err) + tx := &transaction.Transaction{ Type: transaction.InvocationType, Version: 0, @@ -57,6 +90,11 @@ func getTX() *transaction.Transaction { Usage: transaction.Description, Data: []byte(randString(10)), }) + tx.Attributes = append(tx.Attributes, + transaction.Attribute{ + Usage: transaction.Script, + Data: fromAddressHash.BytesBE(), + }) return tx } From 6ef78376142f4ac549b187bebd4128d14961d6a7 Mon Sep 17 00:00:00 2001 From: Vsevolod Brekelov Date: Fri, 13 Dec 2019 16:13:01 +0300 Subject: [PATCH 3/3] performance: removed require call from benchmark test --- integration/performance_test.go | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/integration/performance_test.go b/integration/performance_test.go index 2a3b8789d..19e8b5c9b 100644 --- a/integration/performance_test.go +++ b/integration/performance_test.go @@ -35,8 +35,12 @@ func BenchmarkTXPerformanceTest(t *testing.B) { t.ResetTimer() for n := 0; n < t.N; n++ { - require.Equal(t, server.RelayTxn(data[n]), network.RelaySucceed) - require.Equal(t, server.RelayTxn(data[n]), network.RelayAlreadyExists) + if server.RelayTxn(data[n]) != network.RelaySucceed { + t.Fail() + } + if server.RelayTxn(data[n]) != network.RelayAlreadyExists { + t.Fail() + } } chain.Close() }