mirror of
https://github.com/monero-project/monero.git
synced 2025-01-08 20:09:47 +00:00
functional_tests: add wallet password change, store and tag tests
This commit is contained in:
parent
8e077a5fc0
commit
0dc49fc918
3 changed files with 249 additions and 9 deletions
|
@ -10,7 +10,7 @@ import string
|
|||
import os
|
||||
|
||||
USAGE = 'usage: functional_tests_rpc.py <python> <srcdir> <builddir> [<tests-to-run> | all]'
|
||||
DEFAULT_TESTS = ['bans', 'daemon_info', 'blockchain', 'wallet_address', 'integrated_address', 'mining', 'transfer', 'txpool', 'multisig', 'cold_signing', 'sign_message', 'proofs', 'get_output_distribution']
|
||||
DEFAULT_TESTS = ['bans', 'daemon_info', 'blockchain', 'wallet', 'integrated_address', 'mining', 'transfer', 'txpool', 'multisig', 'cold_signing', 'sign_message', 'proofs', 'get_output_distribution']
|
||||
try:
|
||||
python = sys.argv[1]
|
||||
srcdir = sys.argv[2]
|
||||
|
@ -36,9 +36,10 @@ except:
|
|||
|
||||
N_MONERODS = 1
|
||||
N_WALLETS = 4
|
||||
WALLET_DIRECTORY = builddir + "/functional-tests-directory"
|
||||
|
||||
monerod_base = [builddir + "/bin/monerod", "--regtest", "--fixed-difficulty", "1", "--offline", "--no-igd", "--p2p-bind-port", "monerod_p2p_port", "--rpc-bind-port", "monerod_rpc_port", "--zmq-rpc-bind-port", "monerod_zmq_port", "--non-interactive", "--disable-dns-checkpoints", "--check-updates", "disabled", "--rpc-ssl", "disabled", "--log-level", "1"]
|
||||
wallet_base = [builddir + "/bin/monero-wallet-rpc", "--wallet-dir", builddir + "/functional-tests-directory", "--rpc-bind-port", "wallet_port", "--disable-rpc-login", "--rpc-ssl", "disabled", "--daemon-ssl", "disabled", "--daemon-port", "18180", "--log-level", "1"]
|
||||
wallet_base = [builddir + "/bin/monero-wallet-rpc", "--wallet-dir", WALLET_DIRECTORY, "--rpc-bind-port", "wallet_port", "--disable-rpc-login", "--rpc-ssl", "disabled", "--daemon-ssl", "disabled", "--daemon-port", "18180", "--log-level", "1"]
|
||||
|
||||
command_lines = []
|
||||
processes = []
|
||||
|
@ -62,6 +63,7 @@ try:
|
|||
PYTHONPATH += ':'
|
||||
PYTHONPATH += srcdir + '/../../utils/python-rpc'
|
||||
os.environ['PYTHONPATH'] = PYTHONPATH
|
||||
os.environ['WALLET_DIRECTORY'] = WALLET_DIRECTORY
|
||||
for i in range(len(command_lines)):
|
||||
#print('Running: ' + str(command_lines[i]))
|
||||
processes.append(subprocess.Popen(command_lines[i], stdout = outputs[i]))
|
||||
|
|
|
@ -29,26 +29,46 @@
|
|||
# STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
|
||||
# THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
"""Test transaction creation RPC calls
|
||||
|
||||
Test the following RPCs:
|
||||
- [TODO: many tests still need to be written]
|
||||
|
||||
"""Test basic wallet functionality
|
||||
"""
|
||||
|
||||
from __future__ import print_function
|
||||
import os
|
||||
import errno
|
||||
|
||||
from framework.wallet import Wallet
|
||||
from framework.daemon import Daemon
|
||||
|
||||
class WalletAddressTest():
|
||||
class WalletTest():
|
||||
def run_test(self):
|
||||
self.reset()
|
||||
self.create()
|
||||
self.check_main_address()
|
||||
self.check_keys()
|
||||
self.create_subaddresses()
|
||||
self.tags()
|
||||
self.open_close()
|
||||
self.languages()
|
||||
self.change_password()
|
||||
self.store()
|
||||
|
||||
def remove_file(self, name):
|
||||
WALLET_DIRECTORY = os.environ['WALLET_DIRECTORY']
|
||||
assert WALLET_DIRECTORY != ''
|
||||
try:
|
||||
os.unlink(WALLET_DIRECTORY + '/' + name)
|
||||
except OSError, e:
|
||||
if e.errno != errno.ENOENT:
|
||||
raise
|
||||
|
||||
def remove_wallet_files(self, name):
|
||||
for suffix in ['', '.keys']:
|
||||
self.remove_file(name + suffix)
|
||||
|
||||
def file_exists(self, name):
|
||||
WALLET_DIRECTORY = os.environ['WALLET_DIRECTORY']
|
||||
assert WALLET_DIRECTORY != ''
|
||||
return os.path.isfile(WALLET_DIRECTORY + '/' + name)
|
||||
|
||||
def reset(self):
|
||||
print('Resetting blockchain')
|
||||
|
@ -158,6 +178,81 @@ class WalletAddressTest():
|
|||
res = wallet.get_address_index('82pP87g1Vkd3LUMssBCumk3MfyEsFqLAaGDf6oxddu61EgSFzt8gCwUD4tr3kp9TUfdPs2CnpD7xLZzyC1Ei9UsW3oyCWDf')
|
||||
assert res.index == {'major': 1, 'minor': 0}
|
||||
|
||||
res = wallet.label_account(0, "main")
|
||||
|
||||
def tags(self):
|
||||
print 'Testing tags'
|
||||
wallet = Wallet()
|
||||
res = wallet.get_account_tags()
|
||||
assert not 'account_tags' in res or len(res.account_tags) == 0
|
||||
ok = False
|
||||
try: res = wallet.get_accounts('tag')
|
||||
except: ok = True
|
||||
assert ok or not 'subaddress_accounts' in res or res.subaddress_accounts == 0
|
||||
wallet.tag_accounts('tag0', [1])
|
||||
res = wallet.get_account_tags()
|
||||
assert len(res.account_tags) == 1
|
||||
assert res.account_tags[0].tag == 'tag0'
|
||||
assert res.account_tags[0].label == ''
|
||||
assert res.account_tags[0].accounts == [1]
|
||||
res = wallet.get_accounts('tag0')
|
||||
assert len(res.subaddress_accounts) == 1
|
||||
assert res.subaddress_accounts[0].account_index == 1
|
||||
assert res.subaddress_accounts[0].base_address == '82pP87g1Vkd3LUMssBCumk3MfyEsFqLAaGDf6oxddu61EgSFzt8gCwUD4tr3kp9TUfdPs2CnpD7xLZzyC1Ei9UsW3oyCWDf'
|
||||
assert res.subaddress_accounts[0].balance == 0
|
||||
assert res.subaddress_accounts[0].unlocked_balance == 0
|
||||
assert res.subaddress_accounts[0].label == 'idx1_new'
|
||||
assert res.subaddress_accounts[0].tag == 'tag0'
|
||||
wallet.untag_accounts([0])
|
||||
res = wallet.get_account_tags()
|
||||
assert len(res.account_tags) == 1
|
||||
assert res.account_tags[0].tag == 'tag0'
|
||||
assert res.account_tags[0].label == ''
|
||||
assert res.account_tags[0].accounts == [1]
|
||||
wallet.untag_accounts([1])
|
||||
res = wallet.get_account_tags()
|
||||
assert not 'account_tags' in res or len(res.account_tags) == 0
|
||||
wallet.tag_accounts('tag0', [0])
|
||||
wallet.tag_accounts('tag1', [1])
|
||||
res = wallet.get_account_tags()
|
||||
assert len(res.account_tags) == 2
|
||||
x = [x for x in res.account_tags if x.tag == 'tag0']
|
||||
assert len(x) == 1
|
||||
assert x[0].tag == 'tag0'
|
||||
assert x[0].label == ''
|
||||
assert x[0].accounts == [0]
|
||||
x = [x for x in res.account_tags if x.tag == 'tag1']
|
||||
assert len(x) == 1
|
||||
assert x[0].tag == 'tag1'
|
||||
assert x[0].label == ''
|
||||
assert x[0].accounts == [1]
|
||||
wallet.tag_accounts('tagA', [0, 1])
|
||||
res = wallet.get_account_tags()
|
||||
assert len(res.account_tags) == 1
|
||||
assert res.account_tags[0].tag == 'tagA'
|
||||
assert res.account_tags[0].label == ''
|
||||
assert res.account_tags[0].accounts == [0, 1]
|
||||
wallet.tag_accounts('tagB', [1, 0])
|
||||
res = wallet.get_account_tags()
|
||||
assert len(res.account_tags) == 1
|
||||
assert res.account_tags[0].tag == 'tagB'
|
||||
assert res.account_tags[0].label == ''
|
||||
assert res.account_tags[0].accounts == [0, 1]
|
||||
wallet.set_account_tag_description('tagB', 'tag B')
|
||||
res = wallet.get_account_tags()
|
||||
assert len(res.account_tags) == 1
|
||||
assert res.account_tags[0].tag == 'tagB'
|
||||
assert res.account_tags[0].label == 'tag B'
|
||||
assert res.account_tags[0].accounts == [0, 1]
|
||||
res = wallet.get_accounts('tagB')
|
||||
assert len(res.subaddress_accounts) == 2
|
||||
subaddress_accounts = []
|
||||
for x in res.subaddress_accounts:
|
||||
assert x.balance == 0
|
||||
assert x.unlocked_balance == 0
|
||||
subaddress_accounts.append((x.account_index, x.base_address, x.label))
|
||||
assert sorted(subaddress_accounts) == [(0, '42ey1afDFnn4886T7196doS9GPMzexD9gXpsZJDwVjeRVdFCSoHnv7KPbBeGpzJBzHRCAs9UxqeoyFQMYbqSWYTfJJQAWDm', 'main'), (1, '82pP87g1Vkd3LUMssBCumk3MfyEsFqLAaGDf6oxddu61EgSFzt8gCwUD4tr3kp9TUfdPs2CnpD7xLZzyC1Ei9UsW3oyCWDf', 'idx1_new')]
|
||||
|
||||
def open_close(self):
|
||||
print('Testing open/close')
|
||||
wallet = Wallet()
|
||||
|
@ -205,6 +300,65 @@ class WalletAddressTest():
|
|||
res = wallet.query_key('mnemonic')
|
||||
wallet.close_wallet()
|
||||
|
||||
def change_password(self):
|
||||
print 'Testing password change'
|
||||
wallet = Wallet()
|
||||
|
||||
# close the wallet if any, will throw if none is loaded
|
||||
try: wallet.close_wallet()
|
||||
except: pass
|
||||
|
||||
self.remove_wallet_files('test1')
|
||||
|
||||
seed = 'velvet lymph giddy number token physics poetry unquoted nibs useful sabotage limits benches lifestyle eden nitrogen anvil fewest avoid batch vials washing fences goat unquoted'
|
||||
res = wallet.restore_deterministic_wallet(seed = seed, filename = 'test1')
|
||||
assert res.address == '42ey1afDFnn4886T7196doS9GPMzexD9gXpsZJDwVjeRVdFCSoHnv7KPbBeGpzJBzHRCAs9UxqeoyFQMYbqSWYTfJJQAWDm'
|
||||
assert res.seed == seed
|
||||
|
||||
wallet.close_wallet()
|
||||
res = wallet.open_wallet('test1', password = '')
|
||||
res = wallet.get_address()
|
||||
assert res.address == '42ey1afDFnn4886T7196doS9GPMzexD9gXpsZJDwVjeRVdFCSoHnv7KPbBeGpzJBzHRCAs9UxqeoyFQMYbqSWYTfJJQAWDm'
|
||||
|
||||
res = wallet.change_wallet_password(old_password = '', new_password = 'foo')
|
||||
wallet.close_wallet()
|
||||
|
||||
ok = False
|
||||
try: res = wallet.open_wallet('test1', password = '')
|
||||
except: ok = True
|
||||
assert ok
|
||||
|
||||
res = wallet.open_wallet('test1', password = 'foo')
|
||||
res = wallet.get_address()
|
||||
assert res.address == '42ey1afDFnn4886T7196doS9GPMzexD9gXpsZJDwVjeRVdFCSoHnv7KPbBeGpzJBzHRCAs9UxqeoyFQMYbqSWYTfJJQAWDm'
|
||||
|
||||
self.remove_wallet_files('test1')
|
||||
|
||||
def store(self):
|
||||
print 'Testing store'
|
||||
wallet = Wallet()
|
||||
|
||||
# close the wallet if any, will throw if none is loaded
|
||||
try: wallet.close_wallet()
|
||||
except: pass
|
||||
|
||||
self.remove_wallet_files('test1')
|
||||
|
||||
seed = 'velvet lymph giddy number token physics poetry unquoted nibs useful sabotage limits benches lifestyle eden nitrogen anvil fewest avoid batch vials washing fences goat unquoted'
|
||||
res = wallet.restore_deterministic_wallet(seed = seed, filename = 'test1')
|
||||
assert res.address == '42ey1afDFnn4886T7196doS9GPMzexD9gXpsZJDwVjeRVdFCSoHnv7KPbBeGpzJBzHRCAs9UxqeoyFQMYbqSWYTfJJQAWDm'
|
||||
assert res.seed == seed
|
||||
|
||||
self.remove_file('test1')
|
||||
assert self.file_exists('test1.keys')
|
||||
assert not self.file_exists('test1')
|
||||
wallet.store()
|
||||
assert self.file_exists('test1.keys')
|
||||
assert self.file_exists('test1')
|
||||
|
||||
wallet.close_wallet()
|
||||
self.remove_wallet_files('test1')
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
WalletAddressTest().run_test()
|
||||
WalletTest().run_test()
|
|
@ -350,6 +350,34 @@ class Wallet(object):
|
|||
}
|
||||
return self.rpc.send_json_rpc_request(close_wallet)
|
||||
|
||||
def change_wallet_password(self, old_password, new_password):
|
||||
change_wallet_password = {
|
||||
'method': 'change_wallet_password',
|
||||
'params' : {
|
||||
'old_password': old_password,
|
||||
'new_password': new_password,
|
||||
},
|
||||
'jsonrpc': '2.0',
|
||||
'id': '0'
|
||||
}
|
||||
return self.rpc.send_json_rpc_request(change_wallet_password)
|
||||
|
||||
def store(self):
|
||||
store = {
|
||||
'method': 'store',
|
||||
'jsonrpc': '2.0',
|
||||
'id': '0'
|
||||
}
|
||||
return self.rpc.send_json_rpc_request(store)
|
||||
|
||||
def stop_wallet(self):
|
||||
stop_wallet = {
|
||||
'method': 'stop_wallet',
|
||||
'jsonrpc': '2.0',
|
||||
'id': '0'
|
||||
}
|
||||
return self.rpc.send_json_rpc_request(stop_wallet)
|
||||
|
||||
def refresh(self):
|
||||
refresh = {
|
||||
'method': 'refresh',
|
||||
|
@ -806,6 +834,62 @@ class Wallet(object):
|
|||
}
|
||||
return self.rpc.send_json_rpc_request(validate_address)
|
||||
|
||||
def get_accounts(self, tag):
|
||||
get_accounts = {
|
||||
'method': 'get_accounts',
|
||||
'params': {
|
||||
'tag': tag,
|
||||
},
|
||||
'jsonrpc': '2.0',
|
||||
'id': '0'
|
||||
}
|
||||
return self.rpc.send_json_rpc_request(get_accounts)
|
||||
|
||||
def get_account_tags(self):
|
||||
get_account_tags = {
|
||||
'method': 'get_account_tags',
|
||||
'params': {
|
||||
},
|
||||
'jsonrpc': '2.0',
|
||||
'id': '0'
|
||||
}
|
||||
return self.rpc.send_json_rpc_request(get_account_tags)
|
||||
|
||||
def tag_accounts(self, tag, accounts = []):
|
||||
tag_accounts = {
|
||||
'method': 'tag_accounts',
|
||||
'params': {
|
||||
'tag': tag,
|
||||
'accounts': accounts,
|
||||
},
|
||||
'jsonrpc': '2.0',
|
||||
'id': '0'
|
||||
}
|
||||
return self.rpc.send_json_rpc_request(tag_accounts)
|
||||
|
||||
def untag_accounts(self, accounts = []):
|
||||
untag_accounts = {
|
||||
'method': 'untag_accounts',
|
||||
'params': {
|
||||
'accounts': accounts,
|
||||
},
|
||||
'jsonrpc': '2.0',
|
||||
'id': '0'
|
||||
}
|
||||
return self.rpc.send_json_rpc_request(untag_accounts)
|
||||
|
||||
def set_account_tag_description(self, tag, description):
|
||||
set_account_tag_description = {
|
||||
'method': 'set_account_tag_description',
|
||||
'params': {
|
||||
'tag': tag,
|
||||
'description': description,
|
||||
},
|
||||
'jsonrpc': '2.0',
|
||||
'id': '0'
|
||||
}
|
||||
return self.rpc.send_json_rpc_request(set_account_tag_description)
|
||||
|
||||
def start_mining(self, threads_count, do_background_mining = False, ignore_battery = False):
|
||||
start_mining = {
|
||||
'method': 'start_mining',
|
||||
|
|
Loading…
Reference in a new issue