2022-01-27 04:09:41 +00:00
|
|
|
package services_test
|
2021-12-06 14:58:53 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
2022-01-27 04:09:41 +00:00
|
|
|
"context"
|
2021-12-06 14:58:53 +00:00
|
|
|
"encoding/hex"
|
2022-01-27 04:09:41 +00:00
|
|
|
"github.com/ledgerwatch/erigon-lib/kv/memdb"
|
|
|
|
"github.com/ledgerwatch/erigon/cmd/starknet/services"
|
2021-12-06 14:58:53 +00:00
|
|
|
"testing"
|
|
|
|
"testing/fstest"
|
2022-01-18 10:20:35 +00:00
|
|
|
|
|
|
|
"github.com/ledgerwatch/erigon/crypto"
|
2021-12-06 14:58:53 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestCreate(t *testing.T) {
|
|
|
|
privateKey := "26e86e45f6fc45ec6e2ecd128cec80fa1d1505e5507dcd2ae58c3130a7a97b48"
|
|
|
|
|
|
|
|
var cases = []struct {
|
|
|
|
name string
|
|
|
|
privateKey string
|
2022-01-27 04:09:41 +00:00
|
|
|
config *services.Config
|
2021-12-06 14:58:53 +00:00
|
|
|
want string
|
2022-01-17 13:35:24 +00:00
|
|
|
error error
|
2021-12-06 14:58:53 +00:00
|
|
|
}{
|
2022-01-27 04:09:41 +00:00
|
|
|
{name: "invalid private key", privateKey: "abc", config: &services.Config{
|
|
|
|
ContractFileName: "not_exist.json",
|
|
|
|
}, error: services.ErrInvalidPrivateKey},
|
|
|
|
{name: "contract file not found", privateKey: generatePrivateKey(t), config: &services.Config{
|
|
|
|
ContractFileName: "not_exist.json",
|
|
|
|
}, error: services.ErrReadContract},
|
|
|
|
{name: "success", privateKey: privateKey, config: &services.Config{
|
|
|
|
ContractFileName: "contract_test.json",
|
|
|
|
Salt: []byte("contract_address_salt"),
|
|
|
|
Gas: 1,
|
|
|
|
Nonce: 0,
|
|
|
|
}, want: "0xb88503f88283127ed801830186a084342770c0018001963762323236313632363932323361323035623564376495636f6e74726163745f616464726573735f73616c74c080a08b88467d0a9a6cba87ec6c2ad9e7399d12a1b6f7f5b951bdd2c5c2ea08b76134a0472e1b37ca5f87c9c38690718c6b2b9db1a3d5398dc664fc4e158ab60d02d64b"},
|
2021-12-06 14:58:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
fs := fstest.MapFS{
|
|
|
|
"contract_test.json": {Data: []byte("{\"abi\": []}")},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range cases {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
2022-01-27 04:09:41 +00:00
|
|
|
rawTxGenerator := services.NewRawTxGenerator(tt.privateKey)
|
2021-12-06 14:58:53 +00:00
|
|
|
|
2022-01-27 04:09:41 +00:00
|
|
|
ctx := context.Background()
|
2021-12-06 14:58:53 +00:00
|
|
|
buf := bytes.NewBuffer(nil)
|
2022-01-27 04:09:41 +00:00
|
|
|
db := memdb.NewTestDB(t)
|
|
|
|
|
|
|
|
err := rawTxGenerator.CreateFromFS(ctx, fs, db, tt.config, buf)
|
2021-12-06 14:58:53 +00:00
|
|
|
|
2022-01-17 13:35:24 +00:00
|
|
|
if tt.error == nil {
|
|
|
|
assertNoError(t, err)
|
2021-12-06 14:58:53 +00:00
|
|
|
|
2022-01-27 04:09:41 +00:00
|
|
|
got := buf.String()
|
2021-12-06 14:58:53 +00:00
|
|
|
|
2022-01-17 13:35:24 +00:00
|
|
|
if got != tt.want {
|
|
|
|
t.Errorf("got %q not equals want %q", got, tt.want)
|
|
|
|
}
|
|
|
|
} else {
|
2021-12-06 14:58:53 +00:00
|
|
|
assertError(t, err, tt.error)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func generatePrivateKey(t testing.TB) string {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
privateKey, err := crypto.GenerateKey()
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return hex.EncodeToString(crypto.FromECDSA(privateKey))
|
|
|
|
}
|
|
|
|
|
|
|
|
func assertNoError(t testing.TB, got error) {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
if got != nil {
|
|
|
|
t.Fatal("got an error but didn't want one")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func assertError(t testing.TB, got error, want error) {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
if got == nil {
|
|
|
|
t.Fatal("didn't get an error but wanted one")
|
|
|
|
}
|
|
|
|
|
|
|
|
if got != want {
|
|
|
|
t.Errorf("got %q, want %q", got, want)
|
|
|
|
}
|
|
|
|
}
|