mirror of
https://github.com/RoboSats/robosats.git
synced 2024-12-14 03:16:24 +00:00
Add test to reproduce errors when all wallet balance is pending
This commit is contained in:
parent
707f76832b
commit
db1a220744
@ -11,7 +11,12 @@ from django.contrib.admin.sites import AdminSite
|
|||||||
from control.models import BalanceLog
|
from control.models import BalanceLog
|
||||||
from control.tasks import compute_node_balance, do_accounting
|
from control.tasks import compute_node_balance, do_accounting
|
||||||
from tests.test_api import BaseAPITestCase
|
from tests.test_api import BaseAPITestCase
|
||||||
from tests.utils.node import add_invoice, set_up_regtest_network
|
from tests.utils.node import (
|
||||||
|
add_invoice,
|
||||||
|
set_up_regtest_network,
|
||||||
|
send_all_coins_to_self,
|
||||||
|
gen_blocks_to_confirm_pending,
|
||||||
|
)
|
||||||
from tests.utils.pgp import sign_message
|
from tests.utils.pgp import sign_message
|
||||||
from tests.utils.trade import Trade
|
from tests.utils.trade import Trade
|
||||||
|
|
||||||
@ -504,6 +509,46 @@ class TradeTest(BaseAPITestCase):
|
|||||||
trade.cancel_order(trade.maker_index)
|
trade.cancel_order(trade.maker_index)
|
||||||
trade.cancel_order(trade.taker_index)
|
trade.cancel_order(trade.taker_index)
|
||||||
|
|
||||||
|
def test_trade_to_submitted_invoice_with_no_confirmed_onchain_balance(self):
|
||||||
|
"""
|
||||||
|
Tests a trade from order creation until escrow locked and
|
||||||
|
invoice is submitted by buyer while the node has all its onchain balance
|
||||||
|
as pending.
|
||||||
|
"""
|
||||||
|
|
||||||
|
# Spend all balance to self, leaving all balance "unconfirmed"
|
||||||
|
send_all_coins_to_self("coordinator")
|
||||||
|
|
||||||
|
trade = Trade(self.client)
|
||||||
|
trade.publish_order()
|
||||||
|
trade.take_order()
|
||||||
|
trade.lock_taker_bond()
|
||||||
|
|
||||||
|
trade.get_order()
|
||||||
|
self.assertEqual(trade.response.status_code, 200)
|
||||||
|
self.assertResponse(trade.response)
|
||||||
|
|
||||||
|
# Onchain payout option "swap_allowed" should not be possible
|
||||||
|
self.assertFalse(trade.response.json()["swap_allowed"])
|
||||||
|
|
||||||
|
trade.lock_escrow(trade.taker_index)
|
||||||
|
trade.submit_payout_invoice(trade.maker_index)
|
||||||
|
|
||||||
|
data = trade.response.json()
|
||||||
|
|
||||||
|
self.assertEqual(trade.response.status_code, 200)
|
||||||
|
self.assertResponse(trade.response)
|
||||||
|
|
||||||
|
self.assertEqual(data["status_message"], Order.Status(Order.Status.CHA).label)
|
||||||
|
self.assertFalse(data["is_fiat_sent"])
|
||||||
|
|
||||||
|
# Cancel order to avoid leaving pending HTLCs after a successful test
|
||||||
|
trade.cancel_order(trade.maker_index)
|
||||||
|
trade.cancel_order(trade.taker_index)
|
||||||
|
|
||||||
|
# Generate blocks to confirm the onchain pending balance
|
||||||
|
gen_blocks_to_confirm_pending("coordinator")
|
||||||
|
|
||||||
def test_trade_to_confirm_fiat_sent_LN(self):
|
def test_trade_to_confirm_fiat_sent_LN(self):
|
||||||
"""
|
"""
|
||||||
Tests a trade from order creation until fiat sent confirmed
|
Tests a trade from order creation until fiat sent confirmed
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import codecs
|
import codecs
|
||||||
import sys
|
import sys
|
||||||
import time
|
import time
|
||||||
|
import json
|
||||||
|
|
||||||
import requests
|
import requests
|
||||||
from decouple import config
|
from decouple import config
|
||||||
@ -150,6 +151,33 @@ def wait_channels():
|
|||||||
wait_for_active_channels("LND", "robot")
|
wait_for_active_channels("LND", "robot")
|
||||||
|
|
||||||
|
|
||||||
|
def send_coins(node_name, address, amount=0, send_all=False, spend_unconfirmed=False):
|
||||||
|
node = get_node(node_name)
|
||||||
|
data = {
|
||||||
|
"addr": address,
|
||||||
|
"amount": amount,
|
||||||
|
"send_all": send_all,
|
||||||
|
"spend_unconfirmed": spend_unconfirmed,
|
||||||
|
}
|
||||||
|
|
||||||
|
response = requests.post(
|
||||||
|
f'http://localhost:{node["port"]}/v1/transactions',
|
||||||
|
headers=node["headers"],
|
||||||
|
data=json.dumps(data),
|
||||||
|
)
|
||||||
|
return response.json()
|
||||||
|
|
||||||
|
|
||||||
|
def send_all_coins_to_self(node_name):
|
||||||
|
address = create_address(node_name)
|
||||||
|
send_coins(node_name, address, send_all=True)
|
||||||
|
|
||||||
|
|
||||||
|
def gen_blocks_to_confirm_pending(node_name):
|
||||||
|
address = create_address(node_name)
|
||||||
|
generate_blocks(address, 10)
|
||||||
|
|
||||||
|
|
||||||
def set_up_regtest_network():
|
def set_up_regtest_network():
|
||||||
if channel_is_active():
|
if channel_is_active():
|
||||||
print("Regtest network was already ready. Skipping initalization.")
|
print("Regtest network was already ready. Skipping initalization.")
|
||||||
|
Loading…
Reference in New Issue
Block a user