package main import ( "crypto/md5" "encoding/hex" "encoding/json" "fmt" "os" "testing" "time" "github.com/pkg/errors" "github.com/stretchr/testify/require" ) // This test tests that the output of generate tx and update tx is consistent func TestGenerateTxUpdateTxConsistentency(t *testing.T) { cases := []struct { connIndex int startingTxNumber int txSize int hostname string numTxsToTest int }{ {0, 0, 40, "localhost:26657", 1000}, {70, 300, 10000, "localhost:26657", 1000}, {0, 50, 100000, "localhost:26657", 1000}, } for tcIndex, tc := range cases { hostnameHash := md5.Sum([]byte(tc.hostname)) // Tx generated from update tx. This is defined outside of the loop, since we have // to a have something initially to update updatedTx := generateTx(tc.connIndex, tc.startingTxNumber, tc.txSize, hostnameHash) updatedHex := make([]byte, len(updatedTx)*2) hex.Encode(updatedHex, updatedTx) for i := 0; i < tc.numTxsToTest; i++ { expectedTx := generateTx(tc.connIndex, tc.startingTxNumber+i, tc.txSize, hostnameHash) expectedHex := make([]byte, len(expectedTx)*2) hex.Encode(expectedHex, expectedTx) updateTx(updatedTx, updatedHex, tc.startingTxNumber+i) // after first 32 bytes is 8 bytes of time, then purely random bytes require.Equal(t, expectedTx[:32], updatedTx[:32], "First 32 bytes of the txs differed. tc #%d, i #%d", tcIndex, i) require.Equal(t, expectedHex[:64], updatedHex[:64], "First 64 bytes of the hex differed. tc #%d, i #%d", tcIndex, i) // Test the lengths of the txs are as expected require.Equal(t, tc.txSize, len(expectedTx), "Length of expected Tx differed. tc #%d, i #%d", tcIndex, i) require.Equal(t, tc.txSize, len(updatedTx), "Length of expected Tx differed. tc #%d, i #%d", tcIndex, i) require.Equal(t, tc.txSize*2, len(expectedHex), "Length of expected hex differed. tc #%d, i #%d", tcIndex, i) require.Equal(t, tc.txSize*2, len(updatedHex), "Length of updated hex differed. tc #%d, i #%d", tcIndex, i) } } } func BenchmarkIterationOfSendLoop(b *testing.B) { var ( connIndex = 0 txSize = 25000 ) now := time.Now() // something too far away to matter endTime := now.Add(time.Hour) txNumber := 0 hostnameHash := md5.Sum([]byte{0}) tx := generateTx(connIndex, txNumber, txSize, hostnameHash) txHex := make([]byte, len(tx)*2) hex.Encode(txHex, tx) b.ResetTimer() for i := 0; i < b.N; i++ { updateTx(tx, txHex, txNumber) paramsJSON, err := json.Marshal(map[string]interface{}{"tx": txHex}) if err != nil { fmt.Printf("failed to encode params: %v\n", err) os.Exit(1) } _ = json.RawMessage(paramsJSON) _ = now.Add(sendTimeout) if err != nil { err = errors.Wrap(err, fmt.Sprintf("txs send failed on connection #%d", connIndex)) logger.Error(err.Error()) return } // Cache the now operations if i%5 == 0 { now = time.Now() if now.After(endTime) { break } } txNumber++ } }