basicswap_miserver/tests/basicswap/test_xmr_reload.py

148 lines
4.2 KiB
Python
Raw Normal View History

2021-01-11 22:15:06 +00:00
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
# Copyright (c) 2020-2022 tecnovert
2021-01-11 22:15:06 +00:00
# Distributed under the MIT software license, see the accompanying
# file LICENSE or http://www.opensource.org/licenses/mit-license.php.
"""
2022-07-13 21:28:38 +00:00
export TEST_PATH=/tmp/test_basicswap
mkdir -p ${TEST_PATH}/bin
cp -r ~/tmp/basicswap_bin/* ${TEST_PATH}/bin
2021-01-11 22:15:06 +00:00
export PYTHONPATH=$(pwd)
python tests/basicswap/test_xmr_reload.py
"""
import sys
import logging
import unittest
import multiprocessing
from tests.basicswap.util import (
read_json_api,
post_json_api,
2021-01-11 22:15:06 +00:00
waitForServer,
)
from tests.basicswap.common import (
2021-01-11 22:15:06 +00:00
waitForNumOffers,
waitForNumBids,
waitForNumSwapping,
)
from tests.basicswap.common_xmr import (
XmrTestBase,
)
logger = logging.getLogger()
logger.level = logging.DEBUG
if not len(logger.handlers):
logger.addHandler(logging.StreamHandler(sys.stdout))
class Test(XmrTestBase):
def test_reload(self):
self.start_processes()
waitForServer(self.delay_event, 12700)
waitForServer(self.delay_event, 12701)
wallets1 = read_json_api(12701, 'wallets')
assert (float(wallets1['XMR']['balance']) > 0.0)
2021-01-11 22:15:06 +00:00
data = {
2021-01-11 22:15:06 +00:00
'addr_from': '-1',
'coin_from': 'part',
'coin_to': 'xmr',
2021-01-11 22:15:06 +00:00
'amt_from': '1',
'amt_to': '1',
'lockhrs': '24'}
2021-01-11 22:15:06 +00:00
offer_id = post_json_api(12700, 'offers/new', data)['offer_id']
summary = read_json_api(12700)
assert (summary['num_sent_offers'] == 1)
2021-01-11 22:15:06 +00:00
logger.info('Waiting for offer')
waitForNumOffers(self.delay_event, 12701, 1)
offers = read_json_api(12701, 'offers')
2021-01-11 22:15:06 +00:00
offer = offers[0]
data = {
2021-01-11 22:15:06 +00:00
'offer_id': offer['offer_id'],
'amount_from': offer['amount_from']}
data['valid_for_seconds'] = 24 * 60 * 60 + 1
bid = post_json_api(12701, 'bids/new', data)
assert (bid['error'] == 'Bid TTL too high')
del data['valid_for_seconds']
data['validmins'] = 24 * 60 + 1
bid = post_json_api(12701, 'bids/new', data)
assert (bid['error'] == 'Bid TTL too high')
del data['validmins']
data['valid_for_seconds'] = 10
bid = post_json_api(12701, 'bids/new', data)
assert (bid['error'] == 'Bid TTL too low')
del data['valid_for_seconds']
data['validmins'] = 1
bid = post_json_api(12701, 'bids/new', data)
assert (bid['error'] == 'Bid TTL too low')
data['validmins'] = 60
bid_id = post_json_api(12701, 'bids/new', data)
2021-01-11 22:15:06 +00:00
waitForNumBids(self.delay_event, 12700, 1)
for i in range(10):
bids = read_json_api(12700, 'bids')
2021-01-11 22:15:06 +00:00
bid = bids[0]
if bid['bid_state'] == 'Received':
break
self.delay_event.wait(1)
assert (bid['expire_at'] == bid['created_at'] + data['validmins'] * 60)
2021-01-11 22:15:06 +00:00
data = {
2021-01-11 22:15:06 +00:00
'accept': True
}
rv = post_json_api(12700, 'bids/{}'.format(bid['bid_id']), data)
assert (rv['bid_state'] == 'Accepted')
2021-01-11 22:15:06 +00:00
waitForNumSwapping(self.delay_event, 12701, 1)
logger.info('Restarting client')
c1 = self.processes[1]
c1.terminate()
c1.join()
self.processes[1] = multiprocessing.Process(target=self.run_thread, args=(1,))
self.processes[1].start()
waitForServer(self.delay_event, 12701)
rv = read_json_api(12701)
assert (rv['num_swapping'] == 1)
2021-01-11 22:15:06 +00:00
rv = read_json_api(12700, 'revokeoffer/{}'.format(offer_id))
assert (rv['revoked_offer'] == offer_id)
2021-01-11 22:15:06 +00:00
logger.info('Completing swap')
for i in range(240):
if self.delay_event.is_set():
raise ValueError('Test stopped.')
self.delay_event.wait(4)
rv = read_json_api(12700, 'bids/{}'.format(bid['bid_id']))
2021-01-11 22:15:06 +00:00
if rv['bid_state'] == 'Completed':
break
assert (rv['bid_state'] == 'Completed')
2021-01-11 22:15:06 +00:00
# Ensure offer was revoked
summary = read_json_api(12700)
assert (summary['num_network_offers'] == 0)
2021-01-11 22:15:06 +00:00
# Wait for bid to be removed from in-progress
waitForNumBids(self.delay_event, 12700, 0)
if __name__ == '__main__':
unittest.main()