contract addresses include hex prefix
- simplify resolver and tests - added missing test for KeyToUrl - fix notice error message and its test with !%x(MISSING) - natspec test: insertTx modified - does not prepend 0x to contract address - disable networking in e2e test
This commit is contained in:
		| @@ -195,7 +195,7 @@ func (self *NatSpec) Notice() (notice string, err error) { | |||||||
| 	meth := self.makeAbi2method(abiKey) | 	meth := self.makeAbi2method(abiKey) | ||||||
|  |  | ||||||
| 	if meth == nil { | 	if meth == nil { | ||||||
| 		err = fmt.Errorf("abi key %x does not match any method %v") | 		err = fmt.Errorf("abi key does not match any method") | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
| 	notice, err = self.noticeForMethod(self.tx, meth.name, meth.Notice) | 	notice, err = self.noticeForMethod(self.tx, meth.name, meth.Notice) | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| package natspec | package natspec | ||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"fmt" |  | ||||||
| 	"io/ioutil" | 	"io/ioutil" | ||||||
| 	"math/big" | 	"math/big" | ||||||
| 	"os" | 	"os" | ||||||
| @@ -40,7 +39,7 @@ const testFileName = "long_file_name_for_testing_registration_of_URLs_longer_tha | |||||||
|  |  | ||||||
| const testNotice = "Register key `utils.toHex(_key)` <- content `utils.toHex(_content)`" | const testNotice = "Register key `utils.toHex(_key)` <- content `utils.toHex(_content)`" | ||||||
| const testExpNotice = "Register key 0xadd1a7d961cff0242089674ec2ef6fca671ab15e1fe80e38859fc815b98d88ab <- content 0xc00d5bcc872e17813df6ec5c646bb281a6e2d3b454c2c400c78192adf3344af9" | const testExpNotice = "Register key 0xadd1a7d961cff0242089674ec2ef6fca671ab15e1fe80e38859fc815b98d88ab <- content 0xc00d5bcc872e17813df6ec5c646bb281a6e2d3b454c2c400c78192adf3344af9" | ||||||
| const testExpNotice2 = `About to submit transaction (NatSpec notice error "abi key %!x(MISSING) does not match any method %!v(MISSING)"): {"id":6,"jsonrpc":"2.0","method":"eth_transact","params":[{"from":"0xe273f01c99144c438695e10f24926dc1f9fbf62d","to":"0xb737b91f8e95cf756766fc7c62c9a8ff58470381","value":"100000000000","gas":"100000","gasPrice":"100000","data":"0x31e12c20"}]}` | const testExpNotice2 = `About to submit transaction (NatSpec notice error "abi key does not match any method"): {"id":6,"jsonrpc":"2.0","method":"eth_transact","params":[{"from":"0xe273f01c99144c438695e10f24926dc1f9fbf62d","to":"0xb737b91f8e95cf756766fc7c62c9a8ff58470381","value":"100000000000","gas":"100000","gasPrice":"100000","data":"0x31e12c20"}]}` | ||||||
| const testExpNotice3 = `About to submit transaction (no NatSpec info found for contract): {"id":6,"jsonrpc":"2.0","method":"eth_transact","params":[{"from":"0xe273f01c99144c438695e10f24926dc1f9fbf62d","to":"0x8b839ad85686967a4f418eccc81962eaee314ac3","value":"100000000000","gas":"100000","gasPrice":"100000","data":"0x300a3bbfc00d5bcc872e17813df6ec5c646bb281a6e2d3b454c2c400c78192adf3344af900000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000000"}]}` | const testExpNotice3 = `About to submit transaction (no NatSpec info found for contract): {"id":6,"jsonrpc":"2.0","method":"eth_transact","params":[{"from":"0xe273f01c99144c438695e10f24926dc1f9fbf62d","to":"0x8b839ad85686967a4f418eccc81962eaee314ac3","value":"100000000000","gas":"100000","gasPrice":"100000","data":"0x300a3bbfc00d5bcc872e17813df6ec5c646bb281a6e2d3b454c2c400c78192adf3344af900000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000000"}]}` | ||||||
|  |  | ||||||
| const testUserDoc = ` | const testUserDoc = ` | ||||||
| @@ -106,27 +105,25 @@ func (f *testFrontend) ConfirmTransaction(tx string) bool { | |||||||
| var port = 30300 | var port = 30300 | ||||||
|  |  | ||||||
| func testEth(t *testing.T) (ethereum *eth.Ethereum, err error) { | func testEth(t *testing.T) (ethereum *eth.Ethereum, err error) { | ||||||
| 	os.RemoveAll("/tmp/eth/") | 	os.RemoveAll("/tmp/eth-natspec/") | ||||||
| 	err = os.MkdirAll("/tmp/eth/keys/e273f01c99144c438695e10f24926dc1f9fbf62d/", os.ModePerm) | 	err = os.MkdirAll("/tmp/eth-natspec/keys/e273f01c99144c438695e10f24926dc1f9fbf62d/", os.ModePerm) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		t.Errorf("%v", err) | 		t.Errorf("%v", err) | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
| 	err = os.MkdirAll("/tmp/eth/data", os.ModePerm) | 	err = os.MkdirAll("/tmp/eth-natspec/data", os.ModePerm) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		t.Errorf("%v", err) | 		t.Errorf("%v", err) | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
| 	ks := crypto.NewKeyStorePlain("/tmp/eth/keys") | 	ks := crypto.NewKeyStorePlain("/tmp/eth-natspec/keys") | ||||||
| 	ioutil.WriteFile("/tmp/eth/keys/e273f01c99144c438695e10f24926dc1f9fbf62d/e273f01c99144c438695e10f24926dc1f9fbf62d", | 	ioutil.WriteFile("/tmp/eth-natspec/keys/e273f01c99144c438695e10f24926dc1f9fbf62d/e273f01c99144c438695e10f24926dc1f9fbf62d", | ||||||
| 		[]byte(`{"Id":"RhRXD+fNRKS4jx+7ZfEsNA==","Address":"4nPwHJkUTEOGleEPJJJtwfn79i0=","PrivateKey":"h4ACVpe74uIvi5Cg/2tX/Yrm2xdr3J7QoMbMtNX2CNc="}`), os.ModePerm) | 		[]byte(`{"Id":"RhRXD+fNRKS4jx+7ZfEsNA==","Address":"4nPwHJkUTEOGleEPJJJtwfn79i0=","PrivateKey":"h4ACVpe74uIvi5Cg/2tX/Yrm2xdr3J7QoMbMtNX2CNc="}`), os.ModePerm) | ||||||
|  |  | ||||||
| 	port++ | 	port++ | ||||||
| 	ethereum, err = eth.New(ð.Config{ | 	ethereum, err = eth.New(ð.Config{ | ||||||
| 		DataDir:        "/tmp/eth", | 		DataDir:        "/tmp/eth-natspec", | ||||||
| 		AccountManager: accounts.NewManager(ks), | 		AccountManager: accounts.NewManager(ks), | ||||||
| 		Port:           fmt.Sprintf("%d", port), |  | ||||||
| 		MaxPeers:       10, |  | ||||||
| 		Name:           "test", | 		Name:           "test", | ||||||
| 	}) | 	}) | ||||||
|  |  | ||||||
| @@ -146,7 +143,7 @@ func testInit(t *testing.T) (self *testFrontend) { | |||||||
|  |  | ||||||
| 	ethereum, err := testEth(t) | 	ethereum, err := testEth(t) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		t.Errorf("error creating jsre, got %v", err) | 		t.Errorf("error creating ethereum: %v", err) | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
| 	err = ethereum.Start() | 	err = ethereum.Start() | ||||||
| @@ -193,7 +190,7 @@ func (self *testFrontend) insertTx(addr, contract, fnsig string, args []string) | |||||||
| 	jsontx := ` | 	jsontx := ` | ||||||
| [{ | [{ | ||||||
| 	  "from": "` + addr + `", | 	  "from": "` + addr + `", | ||||||
|       "to": "0x` + contract + `", |       "to": "` + contract + `", | ||||||
| 	  "value": "100000000000", | 	  "value": "100000000000", | ||||||
| 	  "gas": "100000", | 	  "gas": "100000", | ||||||
| 	  "gasPrice": "100000", | 	  "gasPrice": "100000", | ||||||
|   | |||||||
| @@ -32,8 +32,6 @@ func CreateContracts(xeth *xe.XEth, addr string) { | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		panic(err) | 		panic(err) | ||||||
| 	} | 	} | ||||||
| 	URLHintContractAddress = URLHintContractAddress[2:] |  | ||||||
| 	HashRegContractAddress = HashRegContractAddress[2:] |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type Resolver struct { | type Resolver struct { | ||||||
| @@ -53,7 +51,7 @@ func New(eth Backend, uhca, nrca string) *Resolver { | |||||||
| func (self *Resolver) KeyToContentHash(khash common.Hash) (chash common.Hash, err error) { | func (self *Resolver) KeyToContentHash(khash common.Hash) (chash common.Hash, err error) { | ||||||
| 	// look up in hashReg | 	// look up in hashReg | ||||||
| 	key := storageAddress(storageMapping(storageIdx2Addr(1), khash[:])) | 	key := storageAddress(storageMapping(storageIdx2Addr(1), khash[:])) | ||||||
| 	hash := self.backend.StorageAt("0x"+self.hashRegContractAddress, key) | 	hash := self.backend.StorageAt(self.hashRegContractAddress, key) | ||||||
|  |  | ||||||
| 	if hash == "0x0" || len(hash) < 3 { | 	if hash == "0x0" || len(hash) < 3 { | ||||||
| 		err = fmt.Errorf("GetHashReg: content hash not found") | 		err = fmt.Errorf("GetHashReg: content hash not found") | ||||||
| @@ -71,7 +69,7 @@ func (self *Resolver) ContentHashToUrl(chash common.Hash) (uri string, err error | |||||||
| 	for len(str) > 0 { | 	for len(str) > 0 { | ||||||
| 		mapaddr := storageMapping(storageIdx2Addr(1), chash[:]) | 		mapaddr := storageMapping(storageIdx2Addr(1), chash[:]) | ||||||
| 		key := storageAddress(storageFixedArray(mapaddr, storageIdx2Addr(idx))) | 		key := storageAddress(storageFixedArray(mapaddr, storageIdx2Addr(idx))) | ||||||
| 		hex := self.backend.StorageAt("0x"+self.urlHintContractAddress, key) | 		hex := self.backend.StorageAt(self.urlHintContractAddress, key) | ||||||
| 		str = string(common.Hex2Bytes(hex[2:])) | 		str = string(common.Hex2Bytes(hex[2:])) | ||||||
| 		l := len(str) | 		l := len(str) | ||||||
| 		for (l > 0) && (str[l-1] == 0) { | 		for (l > 0) && (str[l-1] == 0) { | ||||||
| @@ -126,5 +124,5 @@ func storageFixedArray(addr, idx []byte) []byte { | |||||||
| } | } | ||||||
|  |  | ||||||
| func storageAddress(addr []byte) string { | func storageAddress(addr []byte) string { | ||||||
| 	return "0x" + common.Bytes2Hex(addr) | 	return common.ToHex(addr) | ||||||
| } | } | ||||||
|   | |||||||
| @@ -14,8 +14,8 @@ type testBackend struct { | |||||||
|  |  | ||||||
| var ( | var ( | ||||||
| 	text     = "test" | 	text     = "test" | ||||||
| 	codehash = "1234" //common.RightPadString("1234", 64) | 	codehash = common.StringToHash("1234") | ||||||
| 	hash     = common.Bytes2Hex(crypto.Sha3([]byte(text))) | 	hash     = common.BytesToHash(crypto.Sha3([]byte(text))) | ||||||
| 	url      = "bzz://bzzhash/my/path/contr.act" | 	url      = "bzz://bzzhash/my/path/contr.act" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| @@ -23,17 +23,17 @@ func NewTestBackend() *testBackend { | |||||||
| 	self := &testBackend{} | 	self := &testBackend{} | ||||||
| 	self.contracts = make(map[string](map[string]string)) | 	self.contracts = make(map[string](map[string]string)) | ||||||
|  |  | ||||||
| 	self.contracts["0x"+HashRegContractAddress] = make(map[string]string) | 	self.contracts[HashRegContractAddress] = make(map[string]string) | ||||||
| 	key := storageAddress(storageMapping(storageIdx2Addr(1), common.Hex2BytesFixed(codehash, 32))) | 	key := storageAddress(storageMapping(storageIdx2Addr(1), codehash[:])) | ||||||
| 	self.contracts["0x"+HashRegContractAddress][key] = "0x" + hash | 	self.contracts[HashRegContractAddress][key] = hash.Hex() | ||||||
|  |  | ||||||
| 	self.contracts["0x"+URLHintContractAddress] = make(map[string]string) | 	self.contracts[URLHintContractAddress] = make(map[string]string) | ||||||
| 	mapaddr := storageMapping(storageIdx2Addr(1), common.Hex2BytesFixed(hash, 32)) | 	mapaddr := storageMapping(storageIdx2Addr(1), hash[:]) | ||||||
|  |  | ||||||
| 	key = storageAddress(storageFixedArray(mapaddr, storageIdx2Addr(0))) | 	key = storageAddress(storageFixedArray(mapaddr, storageIdx2Addr(0))) | ||||||
| 	self.contracts["0x"+URLHintContractAddress][key] = "0x" + common.Bytes2Hex([]byte(url)) | 	self.contracts[URLHintContractAddress][key] = common.ToHex([]byte(url)) | ||||||
| 	key = storageAddress(storageFixedArray(mapaddr, storageIdx2Addr(1))) | 	key = storageAddress(storageFixedArray(mapaddr, storageIdx2Addr(1))) | ||||||
| 	self.contracts["0x"+URLHintContractAddress][key] = "0x00" | 	self.contracts[URLHintContractAddress][key] = "0x00" | ||||||
|  |  | ||||||
| 	return self | 	return self | ||||||
| } | } | ||||||
| @@ -50,15 +50,13 @@ func (self *testBackend) StorageAt(ca, sa string) (res string) { | |||||||
| func TestKeyToContentHash(t *testing.T) { | func TestKeyToContentHash(t *testing.T) { | ||||||
| 	b := NewTestBackend() | 	b := NewTestBackend() | ||||||
| 	res := New(b, URLHintContractAddress, HashRegContractAddress) | 	res := New(b, URLHintContractAddress, HashRegContractAddress) | ||||||
| 	chash := common.Hash{} |  | ||||||
| 	copy(chash[:], common.Hex2BytesFixed(codehash, 32)) |  | ||||||
|  |  | ||||||
| 	got, err := res.KeyToContentHash(chash) | 	got, err := res.KeyToContentHash(codehash) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		t.Errorf("expected no error, got %v", err) | 		t.Errorf("expected no error, got %v", err) | ||||||
| 	} else { | 	} else { | ||||||
| 		if common.Bytes2Hex(got[:]) != hash { | 		if got != hash { | ||||||
| 			t.Errorf("incorrect result, expected %x, got %x: ", hash, common.Bytes2Hex(got[:])) | 			t.Errorf("incorrect result, expected %x, got %x: ", hash.Hex(), got.Hex()) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| @@ -66,17 +64,25 @@ func TestKeyToContentHash(t *testing.T) { | |||||||
| func TestContentHashToUrl(t *testing.T) { | func TestContentHashToUrl(t *testing.T) { | ||||||
| 	b := NewTestBackend() | 	b := NewTestBackend() | ||||||
| 	res := New(b, URLHintContractAddress, HashRegContractAddress) | 	res := New(b, URLHintContractAddress, HashRegContractAddress) | ||||||
| 	chash := common.Hash{} | 	got, err := res.ContentHashToUrl(hash) | ||||||
| 	copy(chash[:], common.Hex2BytesFixed(hash, 32)) |  | ||||||
| 	got, err := res.ContentHashToUrl(chash) |  | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		t.Errorf("expected no error, got %v", err) | 		t.Errorf("expected no error, got %v", err) | ||||||
| 	} else { | 	} else { | ||||||
| 		if string(got[:]) != url { | 		if string(got) != url { | ||||||
| 			t.Errorf("incorrect result, expected %v, got %s: ", url, string(got[:])) | 			t.Errorf("incorrect result, expected %v, got %s: ", url, string(got)) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| func TestKeyToUrl(t *testing.T) { | func TestKeyToUrl(t *testing.T) { | ||||||
|  | 	b := NewTestBackend() | ||||||
|  | 	res := New(b, URLHintContractAddress, HashRegContractAddress) | ||||||
|  | 	got, _, err := res.KeyToUrl(codehash) | ||||||
|  | 	if err != nil { | ||||||
|  | 		t.Errorf("expected no error, got %v", err) | ||||||
|  | 	} else { | ||||||
|  | 		if string(got) != url { | ||||||
|  | 			t.Errorf("incorrect result, expected %v, got %s: ", url, string(got)) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user