mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-05 02:24:29 +00:00
57bcbaa21f
* Correct naming of hash func in Eth2 * Customizable mode of operation for Caplin
56 lines
1.6 KiB
Go
56 lines
1.6 KiB
Go
package utils_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/ledgerwatch/erigon/cl/utils"
|
|
)
|
|
|
|
func TestKeccak256(t *testing.T) {
|
|
data := []byte("test data")
|
|
extras := [][]byte{
|
|
[]byte("extra1"),
|
|
[]byte("extra2"),
|
|
}
|
|
|
|
expectedHash := utils.Sha256(data, extras...)
|
|
hashFunc := utils.OptimizedSha256NotThreadSafe()
|
|
expectedOptimizedHash := hashFunc(data, extras...)
|
|
|
|
// Test Keccak256 function
|
|
hash := utils.Sha256(data, extras...)
|
|
if hash != expectedHash {
|
|
t.Errorf("Keccak256 returned an incorrect hash. Expected: %x, Got: %x", expectedHash, hash)
|
|
}
|
|
|
|
// Test OptimizedKeccak256 function
|
|
optimizedHash := hashFunc(data, extras...)
|
|
if optimizedHash != expectedOptimizedHash {
|
|
t.Errorf("OptimizedKeccak256 returned an incorrect hash. Expected: %x, Got: %x", expectedOptimizedHash, optimizedHash)
|
|
}
|
|
}
|
|
|
|
func TestOptimizedKeccak256NotThreadSafe(t *testing.T) {
|
|
data := []byte("test data")
|
|
extras := [][]byte{
|
|
[]byte("extra1"),
|
|
[]byte("extra2"),
|
|
}
|
|
|
|
expectedHash := utils.Sha256(data, extras...)
|
|
hashFunc := utils.OptimizedSha256NotThreadSafe()
|
|
expectedOptimizedHash := hashFunc(data, extras...)
|
|
|
|
// Test OptimizedKeccak256NotThreadSafe function
|
|
hash := utils.Sha256(data, extras...)
|
|
if hash != expectedHash {
|
|
t.Errorf("Keccak256 returned an incorrect hash. Expected: %x, Got: %x", expectedHash, hash)
|
|
}
|
|
|
|
// Test OptimizedKeccak256NotThreadSafe function
|
|
optimizedHash := hashFunc(data, extras...)
|
|
if optimizedHash != expectedOptimizedHash {
|
|
t.Errorf("OptimizedKeccak256NotThreadSafe returned an incorrect hash. Expected: %x, Got: %x", expectedOptimizedHash, optimizedHash)
|
|
}
|
|
}
|