Split off rpc_wallet_tests
Split wallet tests from other RPC tests. Now no #ifdef ENABLE_WALLET are needed anymore in either file.
This commit is contained in:
parent
829c920387
commit
5094f8d46f
@ -38,7 +38,7 @@ test_bitcoin_SOURCES = alert_tests.cpp \
|
|||||||
sighash_tests.cpp $(JSON_TEST_FILES) $(RAW_TEST_FILES)
|
sighash_tests.cpp $(JSON_TEST_FILES) $(RAW_TEST_FILES)
|
||||||
|
|
||||||
if ENABLE_WALLET
|
if ENABLE_WALLET
|
||||||
test_bitcoin_SOURCES += accounting_tests.cpp wallet_tests.cpp miner_tests.cpp
|
test_bitcoin_SOURCES += accounting_tests.cpp wallet_tests.cpp miner_tests.cpp rpc_wallet_tests.cpp
|
||||||
endif
|
endif
|
||||||
|
|
||||||
nodist_test_bitcoin_SOURCES = $(BUILT_SOURCES)
|
nodist_test_bitcoin_SOURCES = $(BUILT_SOURCES)
|
||||||
|
@ -9,9 +9,7 @@
|
|||||||
using namespace std;
|
using namespace std;
|
||||||
using namespace json_spirit;
|
using namespace json_spirit;
|
||||||
|
|
||||||
BOOST_AUTO_TEST_SUITE(rpc_tests)
|
Array
|
||||||
|
|
||||||
static Array
|
|
||||||
createArgs(int nRequired, const char* address1=NULL, const char* address2=NULL)
|
createArgs(int nRequired, const char* address1=NULL, const char* address2=NULL)
|
||||||
{
|
{
|
||||||
Array result;
|
Array result;
|
||||||
@ -23,46 +21,7 @@ createArgs(int nRequired, const char* address1=NULL, const char* address2=NULL)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef ENABLE_WALLET
|
Value CallRPC(string args)
|
||||||
BOOST_AUTO_TEST_CASE(rpc_addmultisig)
|
|
||||||
{
|
|
||||||
rpcfn_type addmultisig = tableRPC["addmultisigaddress"]->actor;
|
|
||||||
|
|
||||||
// old, 65-byte-long:
|
|
||||||
const char address1Hex[] = "0434e3e09f49ea168c5bbf53f877ff4206923858aab7c7e1df25bc263978107c95e35065a27ef6f1b27222db0ec97e0e895eaca603d3ee0d4c060ce3d8a00286c8";
|
|
||||||
// new, compressed:
|
|
||||||
const char address2Hex[] = "0388c2037017c62240b6b72ac1a2a5f94da790596ebd06177c8572752922165cb4";
|
|
||||||
|
|
||||||
Value v;
|
|
||||||
CBitcoinAddress address;
|
|
||||||
BOOST_CHECK_NO_THROW(v = addmultisig(createArgs(1, address1Hex), false));
|
|
||||||
address.SetString(v.get_str());
|
|
||||||
BOOST_CHECK(address.IsValid() && address.IsScript());
|
|
||||||
|
|
||||||
BOOST_CHECK_NO_THROW(v = addmultisig(createArgs(1, address1Hex, address2Hex), false));
|
|
||||||
address.SetString(v.get_str());
|
|
||||||
BOOST_CHECK(address.IsValid() && address.IsScript());
|
|
||||||
|
|
||||||
BOOST_CHECK_NO_THROW(v = addmultisig(createArgs(2, address1Hex, address2Hex), false));
|
|
||||||
address.SetString(v.get_str());
|
|
||||||
BOOST_CHECK(address.IsValid() && address.IsScript());
|
|
||||||
|
|
||||||
BOOST_CHECK_THROW(addmultisig(createArgs(0), false), runtime_error);
|
|
||||||
BOOST_CHECK_THROW(addmultisig(createArgs(1), false), runtime_error);
|
|
||||||
BOOST_CHECK_THROW(addmultisig(createArgs(2, address1Hex), false), runtime_error);
|
|
||||||
|
|
||||||
BOOST_CHECK_THROW(addmultisig(createArgs(1, ""), false), runtime_error);
|
|
||||||
BOOST_CHECK_THROW(addmultisig(createArgs(1, "NotAValidPubkey"), false), runtime_error);
|
|
||||||
|
|
||||||
string short1(address1Hex, address1Hex+sizeof(address1Hex)-2); // last byte missing
|
|
||||||
BOOST_CHECK_THROW(addmultisig(createArgs(2, short1.c_str()), false), runtime_error);
|
|
||||||
|
|
||||||
string short2(address1Hex+1, address1Hex+sizeof(address1Hex)); // first byte missing
|
|
||||||
BOOST_CHECK_THROW(addmultisig(createArgs(2, short2.c_str()), false), runtime_error);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static Value CallRPC(string args)
|
|
||||||
{
|
{
|
||||||
vector<string> vArgs;
|
vector<string> vArgs;
|
||||||
boost::split(vArgs, args, boost::is_any_of(" \t"));
|
boost::split(vArgs, args, boost::is_any_of(" \t"));
|
||||||
@ -81,35 +40,8 @@ static Value CallRPC(string args)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef ENABLE_WALLET
|
|
||||||
BOOST_AUTO_TEST_CASE(rpc_wallet)
|
|
||||||
{
|
|
||||||
// Test RPC calls for various wallet statistics
|
|
||||||
Value r;
|
|
||||||
|
|
||||||
BOOST_CHECK_NO_THROW(CallRPC("listunspent"));
|
BOOST_AUTO_TEST_SUITE(rpc_tests)
|
||||||
BOOST_CHECK_THROW(CallRPC("listunspent string"), runtime_error);
|
|
||||||
BOOST_CHECK_THROW(CallRPC("listunspent 0 string"), runtime_error);
|
|
||||||
BOOST_CHECK_THROW(CallRPC("listunspent 0 1 not_array"), runtime_error);
|
|
||||||
BOOST_CHECK_THROW(CallRPC("listunspent 0 1 [] extra"), runtime_error);
|
|
||||||
BOOST_CHECK_NO_THROW(r=CallRPC("listunspent 0 1 []"));
|
|
||||||
BOOST_CHECK(r.get_array().empty());
|
|
||||||
|
|
||||||
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaddress"));
|
|
||||||
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaddress 0"));
|
|
||||||
BOOST_CHECK_THROW(CallRPC("listreceivedbyaddress not_int"), runtime_error);
|
|
||||||
BOOST_CHECK_THROW(CallRPC("listreceivedbyaddress 0 not_bool"), runtime_error);
|
|
||||||
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaddress 0 true"));
|
|
||||||
BOOST_CHECK_THROW(CallRPC("listreceivedbyaddress 0 true extra"), runtime_error);
|
|
||||||
|
|
||||||
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaccount"));
|
|
||||||
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaccount 0"));
|
|
||||||
BOOST_CHECK_THROW(CallRPC("listreceivedbyaccount not_int"), runtime_error);
|
|
||||||
BOOST_CHECK_THROW(CallRPC("listreceivedbyaccount 0 not_bool"), runtime_error);
|
|
||||||
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaccount 0 true"));
|
|
||||||
BOOST_CHECK_THROW(CallRPC("listreceivedbyaccount 0 true extra"), runtime_error);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(rpc_rawparams)
|
BOOST_AUTO_TEST_CASE(rpc_rawparams)
|
||||||
{
|
{
|
||||||
|
82
src/test/rpc_wallet_tests.cpp
Normal file
82
src/test/rpc_wallet_tests.cpp
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
#include "rpcserver.h"
|
||||||
|
#include "rpcclient.h"
|
||||||
|
|
||||||
|
#include "base58.h"
|
||||||
|
|
||||||
|
#include <boost/algorithm/string.hpp>
|
||||||
|
#include <boost/test/unit_test.hpp>
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
using namespace json_spirit;
|
||||||
|
|
||||||
|
extern Array createArgs(int nRequired, const char* address1=NULL, const char* address2=NULL);
|
||||||
|
extern Value CallRPC(string args);
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_SUITE(rpc_wallet_tests)
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(rpc_addmultisig)
|
||||||
|
{
|
||||||
|
rpcfn_type addmultisig = tableRPC["addmultisigaddress"]->actor;
|
||||||
|
|
||||||
|
// old, 65-byte-long:
|
||||||
|
const char address1Hex[] = "0434e3e09f49ea168c5bbf53f877ff4206923858aab7c7e1df25bc263978107c95e35065a27ef6f1b27222db0ec97e0e895eaca603d3ee0d4c060ce3d8a00286c8";
|
||||||
|
// new, compressed:
|
||||||
|
const char address2Hex[] = "0388c2037017c62240b6b72ac1a2a5f94da790596ebd06177c8572752922165cb4";
|
||||||
|
|
||||||
|
Value v;
|
||||||
|
CBitcoinAddress address;
|
||||||
|
BOOST_CHECK_NO_THROW(v = addmultisig(createArgs(1, address1Hex), false));
|
||||||
|
address.SetString(v.get_str());
|
||||||
|
BOOST_CHECK(address.IsValid() && address.IsScript());
|
||||||
|
|
||||||
|
BOOST_CHECK_NO_THROW(v = addmultisig(createArgs(1, address1Hex, address2Hex), false));
|
||||||
|
address.SetString(v.get_str());
|
||||||
|
BOOST_CHECK(address.IsValid() && address.IsScript());
|
||||||
|
|
||||||
|
BOOST_CHECK_NO_THROW(v = addmultisig(createArgs(2, address1Hex, address2Hex), false));
|
||||||
|
address.SetString(v.get_str());
|
||||||
|
BOOST_CHECK(address.IsValid() && address.IsScript());
|
||||||
|
|
||||||
|
BOOST_CHECK_THROW(addmultisig(createArgs(0), false), runtime_error);
|
||||||
|
BOOST_CHECK_THROW(addmultisig(createArgs(1), false), runtime_error);
|
||||||
|
BOOST_CHECK_THROW(addmultisig(createArgs(2, address1Hex), false), runtime_error);
|
||||||
|
|
||||||
|
BOOST_CHECK_THROW(addmultisig(createArgs(1, ""), false), runtime_error);
|
||||||
|
BOOST_CHECK_THROW(addmultisig(createArgs(1, "NotAValidPubkey"), false), runtime_error);
|
||||||
|
|
||||||
|
string short1(address1Hex, address1Hex+sizeof(address1Hex)-2); // last byte missing
|
||||||
|
BOOST_CHECK_THROW(addmultisig(createArgs(2, short1.c_str()), false), runtime_error);
|
||||||
|
|
||||||
|
string short2(address1Hex+1, address1Hex+sizeof(address1Hex)); // first byte missing
|
||||||
|
BOOST_CHECK_THROW(addmultisig(createArgs(2, short2.c_str()), false), runtime_error);
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(rpc_wallet)
|
||||||
|
{
|
||||||
|
// Test RPC calls for various wallet statistics
|
||||||
|
Value r;
|
||||||
|
|
||||||
|
BOOST_CHECK_NO_THROW(CallRPC("listunspent"));
|
||||||
|
BOOST_CHECK_THROW(CallRPC("listunspent string"), runtime_error);
|
||||||
|
BOOST_CHECK_THROW(CallRPC("listunspent 0 string"), runtime_error);
|
||||||
|
BOOST_CHECK_THROW(CallRPC("listunspent 0 1 not_array"), runtime_error);
|
||||||
|
BOOST_CHECK_THROW(CallRPC("listunspent 0 1 [] extra"), runtime_error);
|
||||||
|
BOOST_CHECK_NO_THROW(r=CallRPC("listunspent 0 1 []"));
|
||||||
|
BOOST_CHECK(r.get_array().empty());
|
||||||
|
|
||||||
|
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaddress"));
|
||||||
|
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaddress 0"));
|
||||||
|
BOOST_CHECK_THROW(CallRPC("listreceivedbyaddress not_int"), runtime_error);
|
||||||
|
BOOST_CHECK_THROW(CallRPC("listreceivedbyaddress 0 not_bool"), runtime_error);
|
||||||
|
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaddress 0 true"));
|
||||||
|
BOOST_CHECK_THROW(CallRPC("listreceivedbyaddress 0 true extra"), runtime_error);
|
||||||
|
|
||||||
|
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaccount"));
|
||||||
|
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaccount 0"));
|
||||||
|
BOOST_CHECK_THROW(CallRPC("listreceivedbyaccount not_int"), runtime_error);
|
||||||
|
BOOST_CHECK_THROW(CallRPC("listreceivedbyaccount 0 not_bool"), runtime_error);
|
||||||
|
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaccount 0 true"));
|
||||||
|
BOOST_CHECK_THROW(CallRPC("listreceivedbyaccount 0 true extra"), runtime_error);
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_SUITE_END()
|
Loading…
Reference in New Issue
Block a user