|
|
|
@ -14,7 +14,7 @@
@@ -14,7 +14,7 @@
|
|
|
|
|
using namespace std; |
|
|
|
|
using namespace json_spirit; |
|
|
|
|
|
|
|
|
|
extern Array createArgs(int nRequired, const char* address1=NULL, const char* address2=NULL); |
|
|
|
|
extern Array createArgs(int nRequired, const char* address1 = NULL, const char* address2 = NULL); |
|
|
|
|
extern Value CallRPC(string args); |
|
|
|
|
|
|
|
|
|
extern CWallet* pwalletMain; |
|
|
|
@ -53,10 +53,10 @@ BOOST_AUTO_TEST_CASE(rpc_addmultisig)
@@ -53,10 +53,10 @@ BOOST_AUTO_TEST_CASE(rpc_addmultisig)
|
|
|
|
|
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
|
|
|
|
|
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
|
|
|
|
|
string short2(address1Hex + 1, address1Hex + sizeof(address1Hex)); // first byte missing
|
|
|
|
|
BOOST_CHECK_THROW(addmultisig(createArgs(2, short2.c_str()), false), runtime_error); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
@ -68,30 +68,30 @@ BOOST_AUTO_TEST_CASE(rpc_wallet)
@@ -68,30 +68,30 @@ BOOST_AUTO_TEST_CASE(rpc_wallet)
|
|
|
|
|
LOCK2(cs_main, pwalletMain->cs_wallet); |
|
|
|
|
|
|
|
|
|
CPubKey demoPubkey = pwalletMain->GenerateNewKey(); |
|
|
|
|
CBitcoinAddress demoAddress = CBitcoinAddress(CTxDestination(demoPubkey.GetID())); |
|
|
|
|
Value retValue; |
|
|
|
|
string strAccount = "walletDemoAccount"; |
|
|
|
|
string strPurpose = "receive"; |
|
|
|
|
BOOST_CHECK_NO_THROW({ /*Initialize Wallet with an account */ |
|
|
|
|
CWalletDB walletdb(pwalletMain->strWalletFile); |
|
|
|
|
CAccount account; |
|
|
|
|
account.vchPubKey = demoPubkey; |
|
|
|
|
pwalletMain->SetAddressBook(account.vchPubKey.GetID(), strAccount, strPurpose); |
|
|
|
|
walletdb.WriteAccount(strAccount, account); |
|
|
|
|
}); |
|
|
|
|
CBitcoinAddress demoAddress = CBitcoinAddress(CTxDestination(demoPubkey.GetID())); |
|
|
|
|
Value retValue; |
|
|
|
|
string strAccount = "walletDemoAccount"; |
|
|
|
|
string strPurpose = "receive"; |
|
|
|
|
BOOST_CHECK_NO_THROW({ /*Initialize Wallet with an account */ |
|
|
|
|
CWalletDB walletdb(pwalletMain->strWalletFile); |
|
|
|
|
CAccount account; |
|
|
|
|
account.vchPubKey = demoPubkey; |
|
|
|
|
pwalletMain->SetAddressBook(account.vchPubKey.GetID(), strAccount, strPurpose); |
|
|
|
|
walletdb.WriteAccount(strAccount, account); |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
CPubKey setaccountDemoPubkey = pwalletMain->GenerateNewKey(); |
|
|
|
|
CBitcoinAddress setaccountDemoAddress = CBitcoinAddress(CTxDestination(setaccountDemoPubkey.GetID())); |
|
|
|
|
|
|
|
|
|
/*********************************
|
|
|
|
|
* setaccount |
|
|
|
|
*********************************/ |
|
|
|
|
BOOST_CHECK_NO_THROW(CallRPC("setaccount " + setaccountDemoAddress.ToString() + " nullaccount")); |
|
|
|
|
/* 1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4XZ is not owned by the test wallet. */ |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("setaccount 1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4XZ nullaccount"), runtime_error); |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("setaccount"), runtime_error); |
|
|
|
|
/* 1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4X (33 chars) is an illegal address (should be 34 chars) */ |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("setaccount 1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4X nullaccount"), runtime_error); |
|
|
|
|
CBitcoinAddress setaccountDemoAddress = CBitcoinAddress(CTxDestination(setaccountDemoPubkey.GetID())); |
|
|
|
|
|
|
|
|
|
/*********************************
|
|
|
|
|
* setaccount |
|
|
|
|
*********************************/ |
|
|
|
|
BOOST_CHECK_NO_THROW(CallRPC("setaccount " + setaccountDemoAddress.ToString() + " nullaccount")); |
|
|
|
|
/* 1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4XZ is not owned by the test wallet. */ |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("setaccount 1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4XZ nullaccount"), runtime_error); |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("setaccount"), runtime_error); |
|
|
|
|
/* 1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4X (33 chars) is an illegal address (should be 34 chars) */ |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("setaccount 1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4X nullaccount"), runtime_error); |
|
|
|
|
|
|
|
|
|
/*********************************
|
|
|
|
|
* listunspent |
|
|
|
@ -101,12 +101,12 @@ BOOST_AUTO_TEST_CASE(rpc_wallet)
@@ -101,12 +101,12 @@ BOOST_AUTO_TEST_CASE(rpc_wallet)
|
|
|
|
|
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_NO_THROW(r = CallRPC("listunspent 0 1 []")); |
|
|
|
|
BOOST_CHECK(r.get_array().empty()); |
|
|
|
|
|
|
|
|
|
/*********************************
|
|
|
|
|
* listreceivedbyaddress |
|
|
|
|
*********************************/ |
|
|
|
|
* listreceivedbyaddress |
|
|
|
|
*********************************/ |
|
|
|
|
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaddress")); |
|
|
|
|
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaddress 0")); |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("listreceivedbyaddress not_int"), runtime_error); |
|
|
|
@ -115,8 +115,8 @@ BOOST_AUTO_TEST_CASE(rpc_wallet)
@@ -115,8 +115,8 @@ BOOST_AUTO_TEST_CASE(rpc_wallet)
|
|
|
|
|
BOOST_CHECK_THROW(CallRPC("listreceivedbyaddress 0 true extra"), runtime_error); |
|
|
|
|
|
|
|
|
|
/*********************************
|
|
|
|
|
* listreceivedbyaccount |
|
|
|
|
*********************************/ |
|
|
|
|
* listreceivedbyaccount |
|
|
|
|
*********************************/ |
|
|
|
|
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaccount")); |
|
|
|
|
BOOST_CHECK_NO_THROW(CallRPC("listreceivedbyaccount 0")); |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("listreceivedbyaccount not_int"), runtime_error); |
|
|
|
@ -125,59 +125,58 @@ BOOST_AUTO_TEST_CASE(rpc_wallet)
@@ -125,59 +125,58 @@ BOOST_AUTO_TEST_CASE(rpc_wallet)
|
|
|
|
|
BOOST_CHECK_THROW(CallRPC("listreceivedbyaccount 0 true extra"), runtime_error); |
|
|
|
|
|
|
|
|
|
/*********************************
|
|
|
|
|
* getrawchangeaddress |
|
|
|
|
*********************************/ |
|
|
|
|
* getrawchangeaddress |
|
|
|
|
*********************************/ |
|
|
|
|
BOOST_CHECK_NO_THROW(CallRPC("getrawchangeaddress")); |
|
|
|
|
|
|
|
|
|
/*********************************
|
|
|
|
|
* getnewaddress |
|
|
|
|
*********************************/ |
|
|
|
|
* getnewaddress |
|
|
|
|
*********************************/ |
|
|
|
|
BOOST_CHECK_NO_THROW(CallRPC("getnewaddress")); |
|
|
|
|
BOOST_CHECK_NO_THROW(CallRPC("getnewaddress getnewaddress_demoaccount")); |
|
|
|
|
|
|
|
|
|
/*********************************
|
|
|
|
|
* getaccountaddress |
|
|
|
|
*********************************/ |
|
|
|
|
* getaccountaddress |
|
|
|
|
*********************************/ |
|
|
|
|
BOOST_CHECK_NO_THROW(CallRPC("getaccountaddress \"\"")); |
|
|
|
|
BOOST_CHECK_NO_THROW(CallRPC("getaccountaddress accountThatDoesntExists")); // Should generate a new account
|
|
|
|
|
BOOST_CHECK_NO_THROW(retValue = CallRPC("getaccountaddress " + strAccount)); |
|
|
|
|
BOOST_CHECK(CBitcoinAddress(retValue.get_str()).Get() == demoAddress.Get()); |
|
|
|
|
|
|
|
|
|
/*********************************
|
|
|
|
|
* getaccount |
|
|
|
|
*********************************/ |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("getaccount"), runtime_error); |
|
|
|
|
BOOST_CHECK_NO_THROW(CallRPC("getaccount " + demoAddress.ToString())); |
|
|
|
|
|
|
|
|
|
/*********************************
|
|
|
|
|
* signmessage + verifymessage |
|
|
|
|
*********************************/ |
|
|
|
|
BOOST_CHECK_NO_THROW(retValue = CallRPC("signmessage " + demoAddress.ToString() + " mymessage")); |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("signmessage"), runtime_error); |
|
|
|
|
/* Should throw error because this address is not loaded in the wallet */ |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("signmessage 1QFqqMUD55ZV3PJEJZtaKCsQmjLT6JkjvJ mymessage"), runtime_error); |
|
|
|
|
|
|
|
|
|
/* missing arguments */ |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("verifymessage "+ demoAddress.ToString()), runtime_error); |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("verifymessage "+ demoAddress.ToString() + " " + retValue.get_str()), runtime_error); |
|
|
|
|
/* Illegal address */ |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("verifymessage 1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4X " + retValue.get_str() + " mymessage"), runtime_error); |
|
|
|
|
/* wrong address */ |
|
|
|
|
BOOST_CHECK(CallRPC("verifymessage 1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4XZ " + retValue.get_str() + " mymessage").get_bool() == false); |
|
|
|
|
/* Correct address and signature but wrong message */ |
|
|
|
|
BOOST_CHECK(CallRPC("verifymessage "+ demoAddress.ToString() + " " + retValue.get_str() + " wrongmessage").get_bool() == false); |
|
|
|
|
/* Correct address, message and signature*/ |
|
|
|
|
BOOST_CHECK(CallRPC("verifymessage "+ demoAddress.ToString() + " " + retValue.get_str() + " mymessage").get_bool() == true); |
|
|
|
|
|
|
|
|
|
/*********************************
|
|
|
|
|
* getaddressesbyaccount |
|
|
|
|
*********************************/ |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("getaddressesbyaccount"), runtime_error); |
|
|
|
|
BOOST_CHECK_NO_THROW(retValue = CallRPC("getaddressesbyaccount " + strAccount)); |
|
|
|
|
Array arr = retValue.get_array(); |
|
|
|
|
BOOST_CHECK(arr.size() > 0); |
|
|
|
|
BOOST_CHECK(CBitcoinAddress(arr[0].get_str()).Get() == demoAddress.Get()); |
|
|
|
|
BOOST_CHECK_NO_THROW(CallRPC("getaccountaddress accountThatDoesntExists")); // Should generate a new account
|
|
|
|
|
BOOST_CHECK_NO_THROW(retValue = CallRPC("getaccountaddress " + strAccount)); |
|
|
|
|
BOOST_CHECK(CBitcoinAddress(retValue.get_str()).Get() == demoAddress.Get()); |
|
|
|
|
|
|
|
|
|
/*********************************
|
|
|
|
|
* getaccount |
|
|
|
|
*********************************/ |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("getaccount"), runtime_error); |
|
|
|
|
BOOST_CHECK_NO_THROW(CallRPC("getaccount " + demoAddress.ToString())); |
|
|
|
|
|
|
|
|
|
/*********************************
|
|
|
|
|
* signmessage + verifymessage |
|
|
|
|
*********************************/ |
|
|
|
|
BOOST_CHECK_NO_THROW(retValue = CallRPC("signmessage " + demoAddress.ToString() + " mymessage")); |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("signmessage"), runtime_error); |
|
|
|
|
/* Should throw error because this address is not loaded in the wallet */ |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("signmessage 1QFqqMUD55ZV3PJEJZtaKCsQmjLT6JkjvJ mymessage"), runtime_error); |
|
|
|
|
|
|
|
|
|
/* missing arguments */ |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("verifymessage " + demoAddress.ToString()), runtime_error); |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("verifymessage " + demoAddress.ToString() + " " + retValue.get_str()), runtime_error); |
|
|
|
|
/* Illegal address */ |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("verifymessage 1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4X " + retValue.get_str() + " mymessage"), runtime_error); |
|
|
|
|
/* wrong address */ |
|
|
|
|
BOOST_CHECK(CallRPC("verifymessage 1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4XZ " + retValue.get_str() + " mymessage").get_bool() == false); |
|
|
|
|
/* Correct address and signature but wrong message */ |
|
|
|
|
BOOST_CHECK(CallRPC("verifymessage " + demoAddress.ToString() + " " + retValue.get_str() + " wrongmessage").get_bool() == false); |
|
|
|
|
/* Correct address, message and signature*/ |
|
|
|
|
BOOST_CHECK(CallRPC("verifymessage " + demoAddress.ToString() + " " + retValue.get_str() + " mymessage").get_bool() == true); |
|
|
|
|
|
|
|
|
|
/*********************************
|
|
|
|
|
* getaddressesbyaccount |
|
|
|
|
*********************************/ |
|
|
|
|
BOOST_CHECK_THROW(CallRPC("getaddressesbyaccount"), runtime_error); |
|
|
|
|
BOOST_CHECK_NO_THROW(retValue = CallRPC("getaddressesbyaccount " + strAccount)); |
|
|
|
|
Array arr = retValue.get_array(); |
|
|
|
|
BOOST_CHECK(arr.size() > 0); |
|
|
|
|
BOOST_CHECK(CBitcoinAddress(arr[0].get_str()).Get() == demoAddress.Get()); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|