aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarek Kotewicz <marek.kotewicz@gmail.com>2014-10-27 17:31:49 +0800
committerMarek Kotewicz <marek.kotewicz@gmail.com>2014-10-27 17:31:49 +0800
commit7ca5c65731fa1e8d51b3e5a374c487d496b351e0 (patch)
tree989d28f2ceb38ff372b666eec3b127fbc5fce2e5
parente262ebf49631710a5905816cbf047b3c03921234 (diff)
downloaddexon-solidity-7ca5c65731fa1e8d51b3e5a374c487d496b351e0.tar.gz
dexon-solidity-7ca5c65731fa1e8d51b3e5a374c487d496b351e0.tar.zst
dexon-solidity-7ca5c65731fa1e8d51b3e5a374c487d496b351e0.zip
common changes in tests
-rw-r--r--jsonrpc.cpp78
-rw-r--r--webthreestubclient.h6
2 files changed, 37 insertions, 47 deletions
diff --git a/jsonrpc.cpp b/jsonrpc.cpp
index ec55a5fc..1751b6c5 100644
--- a/jsonrpc.cpp
+++ b/jsonrpc.cpp
@@ -50,8 +50,8 @@ auto s = set<string>{"eth", "shh"};
dev::p2p::NetworkPreferences np(30303, std::string(), false);
dev::WebThreeDirect web3(name, dbPath, true, s, np);
-auto_ptr<WebThreeStubServer> jsonrpcServer;
-auto_ptr<WebThreeStubClient> jsonrpcClient;
+unique_ptr<WebThreeStubServer> jsonrpcServer;
+unique_ptr<WebThreeStubClient> jsonrpcClient;
struct JsonrpcFixture {
JsonrpcFixture()
@@ -60,10 +60,10 @@ struct JsonrpcFixture {
web3.setIdealPeerCount(5);
web3.ethereum()->setForceMining(true);
- jsonrpcServer = auto_ptr<WebThreeStubServer>(new WebThreeStubServer(new jsonrpc::CorsHttpServer(8080), web3, {}));
+ jsonrpcServer = unique_ptr<WebThreeStubServer>(new WebThreeStubServer(new jsonrpc::CorsHttpServer(8080), web3, {}));
jsonrpcServer->StartListening();
- jsonrpcClient = auto_ptr<WebThreeStubClient>(new WebThreeStubClient(new jsonrpc::HttpClient("http://localhost:8080")));
+ jsonrpcClient = unique_ptr<WebThreeStubClient>(new WebThreeStubClient(new jsonrpc::HttpClient("http://localhost:8080")));
}
~JsonrpcFixture()
{
@@ -73,35 +73,6 @@ struct JsonrpcFixture {
BOOST_GLOBAL_FIXTURE(JsonrpcFixture)
-BOOST_AUTO_TEST_CASE(jsonrpc_balanceAt)
-{
- cnote << "Testing jsonrpc balanceAt...";
- dev::KeyPair key = KeyPair::create();
- auto address = key.address();
- string balance = jsonrpcClient->balanceAt(toJS(address));
- BOOST_CHECK_EQUAL(toJS(web3.ethereum()->balanceAt(address)), balance);
-}
-
-BOOST_AUTO_TEST_CASE(jsonrpc_call)
-{
-}
-
-BOOST_AUTO_TEST_CASE(jsonrpc_coinbase)
-{
- cnote << "Testing jsonrpc coinbase...";
- string coinbase = jsonrpcClient->coinbase();
- BOOST_CHECK_EQUAL(jsToAddress(coinbase), web3.ethereum()->address());
-}
-
-BOOST_AUTO_TEST_CASE(jsonrpc_countAt)
-{
- cnote << "Testing jsonrpc countAt...";
- dev::KeyPair key = KeyPair::create();
- auto address = key.address();
- double countAt = jsonrpcClient->countAt(toJS(address));
- BOOST_CHECK_EQUAL(countAt, (double)(uint64_t)web3.ethereum()->countAt(address, 0));
-}
-
BOOST_AUTO_TEST_CASE(jsonrpc_defaultBlock)
{
cnote << "Testing jsonrpc defaultBlock...";
@@ -162,13 +133,6 @@ BOOST_AUTO_TEST_CASE(jsonrpc_accounts)
BOOST_AUTO_TEST_CASE(jsonrpc_number)
{
- cnote << "Testing jsonrpc number...";
- int number = jsonrpcClient->number();
- BOOST_CHECK_EQUAL(number, web3.ethereum()->number() + 1);
-}
-
-BOOST_AUTO_TEST_CASE(jsonrpc_number2)
-{
cnote << "Testing jsonrpc number2...";
int number = jsonrpcClient->number();
BOOST_CHECK_EQUAL(number, web3.ethereum()->number() + 1);
@@ -219,15 +183,35 @@ BOOST_AUTO_TEST_CASE(jsonrpc_stateAt)
BOOST_AUTO_TEST_CASE(jsonrpc_transact)
{
cnote << "Testing jsonrpc transact...";
+ string coinbase = jsonrpcClient->coinbase();
+ BOOST_CHECK_EQUAL(jsToAddress(coinbase), web3.ethereum()->address());
+
dev::KeyPair key = KeyPair::create();
auto address = key.address();
auto receiver = KeyPair::create();
-
web3.ethereum()->setAddress(address);
+
+ coinbase = jsonrpcClient->coinbase();
+ BOOST_CHECK_EQUAL(jsToAddress(coinbase), web3.ethereum()->address());
+ BOOST_CHECK_EQUAL(jsToAddress(coinbase), address);
+
jsonrpcServer->setAccounts({key});
- dev::eth::mine(*(web3.ethereum()), 1);
auto balance = web3.ethereum()->balanceAt(address, 0);
- BOOST_REQUIRE(balance > 0);
+ string balanceString = jsonrpcClient->balanceAt(toJS(address));
+ double countAt = jsonrpcClient->countAt(toJS(address));
+
+ BOOST_CHECK_EQUAL(countAt, (double)(uint64_t)web3.ethereum()->countAt(address));
+ BOOST_CHECK_EQUAL(countAt, 0);
+ BOOST_CHECK_EQUAL(toJS(balance), balanceString);
+ BOOST_CHECK_EQUAL(jsToDecimal(balanceString), "0");
+
+ dev::eth::mine(*(web3.ethereum()), 1);
+ balance = web3.ethereum()->balanceAt(address, 0);
+ balanceString = jsonrpcClient->balanceAt(toJS(address));
+
+ BOOST_CHECK_EQUAL(toJS(balance), balanceString);
+ BOOST_CHECK_EQUAL(jsToDecimal(balanceString), "1500000000000000000");
+
auto txAmount = balance / 2u;
auto gasPrice = 10 * dev::eth::szabo;
auto gas = dev::eth::c_txGas;
@@ -243,9 +227,15 @@ BOOST_AUTO_TEST_CASE(jsonrpc_transact)
jsonrpcClient->transact(t);
jsonrpcServer->setAccounts({});
dev::eth::mine(*(web3.ethereum()), 1);
+
+ countAt = jsonrpcClient->countAt(toJS(address));
auto balance2 = web3.ethereum()->balanceAt(receiver.address());
+ string balanceString2 = jsonrpcClient->balanceAt(toJS(receiver.address()));
- BOOST_REQUIRE(balance2 > 0);
+ BOOST_CHECK_EQUAL(countAt, (double)(uint64_t)web3.ethereum()->countAt(address));
+ BOOST_CHECK_EQUAL(countAt, 1);
+ BOOST_CHECK_EQUAL(toJS(balance2), balanceString2);
+ BOOST_CHECK_EQUAL(jsToDecimal(balanceString2), "750000000000000000");
BOOST_CHECK_EQUAL(txAmount, balance2);
}
diff --git a/webthreestubclient.h b/webthreestubclient.h
index 4bd8afda..c3a392f5 100644
--- a/webthreestubclient.h
+++ b/webthreestubclient.h
@@ -311,14 +311,14 @@ p.append(param2);
}
- Json::Value transact(const Json::Value& param1) throw (jsonrpc::JsonRpcException)
+ std::string transact(const Json::Value& param1) throw (jsonrpc::JsonRpcException)
{
Json::Value p;
p.append(param1);
Json::Value result = this->client->CallMethod("transact",p);
- if (result.isArray())
- return result;
+ if (result.isString())
+ return result.asString();
else
throw jsonrpc::JsonRpcException(jsonrpc::Errors::ERROR_CLIENT_INVALID_RESPONSE, result.toStyledString());