2022-08-03 12:10:32 +00:00
|
|
|
import secrets
|
|
|
|
|
2021-11-17 16:53:32 +00:00
|
|
|
import pytest
|
2022-07-07 16:29:26 +00:00
|
|
|
import pytest_asyncio
|
2022-08-03 12:10:32 +00:00
|
|
|
|
2021-11-17 16:53:32 +00:00
|
|
|
from lnbits.core.crud import get_wallet
|
|
|
|
from lnbits.extensions.bleskomat.crud import get_bleskomat_lnurl
|
2022-03-16 06:20:15 +00:00
|
|
|
from lnbits.extensions.bleskomat.helpers import (
|
|
|
|
generate_bleskomat_lnurl_signature,
|
|
|
|
query_to_signing_payload,
|
|
|
|
)
|
2022-10-03 14:46:56 +00:00
|
|
|
from lnbits.settings import settings
|
2021-11-17 16:53:32 +00:00
|
|
|
from tests.conftest import client
|
|
|
|
from tests.extensions.bleskomat.conftest import bleskomat, lnurl
|
Boltz.exchange Extension (#922)
* initial commit and still draft, ready for review
* forgot to uncomment this line
* fee estimation and blockheight
* resolve conversation with michael, to use mempool websockets instead of boltz status event
* Update lnbits/extensions/boltz/boltz.py
Co-authored-by: michael1011 <me@michael1011.at>
* add status to swaps, add sorting and data into listing
* add swap status checks, change urls to docker test setup, dynamic minimum and maximum limits
* fix docker hosts for development
* add api endpoints to _api_docs
* add wallet name and id, to list and status information
* fix status_update for reverse_swaps
* chore: format with black
* more blackformatting and refactoring create_swap()
* fix variable bug
* check if swap is already refunded
* use create_task instead of ensure_future
* add mempool and boltz urls depending on DEBUG .env
* raise exception in mempool fails
* fix onchain txs, sending funds to wrong address and add a refund address for normal swaps beforehand
* add status to swaps, add sorting and data into listing
* add swap status checks, change urls to docker test setup, dynamic minimum and maximum limits
* add wallet name and id, to list and status information
* fix status_update for reverse_swaps
* chore: format with black
* use create_task instead of ensure_future
* add mempool and boltz urls depending on DEBUG .env
* fix onchain txs, sending funds to wrong address and add a refund address for normal swaps beforehand
* black formatting
* add some logging with loguru, and remove function duplication
* cleanup readme
* updates/suggestions from calle
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* remove unused comments
* Update API Endpoints
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* un-factor get_boltz_pairs
* added a explaination for the onchain tx
* remove unused template file
* rename api endpoints
* fix isort and prettier
* more verbose logging!!
* add boltz to mock_data.zip
* new mockdata
* remove comment
* better readme
* fix mempool urls
* change /refund /check /status to post requests
* first step in tests2
* add first tests
* change refund,check,status to post requests
* next try on tests
* overall code improvements
* just testing tests
* throw http exceptions in views_api
* require admincheck for refund,check,status and added fastapi documentation for those
* added more tests
* black
* many code improvements
* adding tests
* temp fix test
* fix race condition when pay_invoice fails
* test are working
* add boltz env variables
* add startup check, bugfixes, improvements
* improve on status checking
* remove check_invoice_status
* more fixes and tests
* testing testing testing
* make tests run again inside regtest
* fix bad error :O
* fix postgres boolean bug and add swap test
* Update README.md
Update README.md
Update README.md
Update README.md
* some mypy
* blacked
* the missing commit?
* fix api_docs readme link
* better refunding error catching
fix
* check swaps now also shows pending reverse swap, ui improvements, tooltips
* add backend check for boltz limits
fixup
* many improvements, startup check for swaps working, reverse needs more testing
* little last fixes
* remove unused logic
* fastapi documentation
fixup
* formatting and remove unused tests
* fix test
* fix swapstatus model
* Update lnbits/extensions/boltz/tasks.py
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* Update lnbits/extensions/boltz/views_api.py
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* balance check msg, format
* fix mypy data override
* fix swapstatus, remove can refund column
* Update lnbits/extensions/boltz/README.md
Co-authored-by: michael1011 <me@michael1011.at>
* empty lines
* fix error message when swap is not found
* remove preimage_hash from database
* fix api_docs html
fix api_docs html
* catch boltz network exceptions better
* formatting
* check for timeout on swap at get request
Co-authored-by: michael1011 <me@michael1011.at>
Co-authored-by: fusion44 <some.fusion@gmail.com>
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
2022-08-30 10:51:17 +00:00
|
|
|
from tests.helpers import credit_wallet, is_regtest
|
2021-11-17 16:53:32 +00:00
|
|
|
from tests.mocks import WALLET
|
|
|
|
|
2022-02-14 12:42:43 +00:00
|
|
|
|
2021-11-17 16:53:32 +00:00
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_bleskomat_lnurl_api_missing_secret(client):
|
|
|
|
response = await client.get("/bleskomat/u")
|
|
|
|
assert response.status_code == 200
|
|
|
|
assert response.json() == {"status": "ERROR", "reason": "Missing secret"}
|
|
|
|
|
2022-02-14 12:42:43 +00:00
|
|
|
|
2021-11-17 16:53:32 +00:00
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_bleskomat_lnurl_api_invalid_secret(client):
|
|
|
|
response = await client.get("/bleskomat/u?k1=invalid-secret")
|
|
|
|
assert response.status_code == 200
|
|
|
|
assert response.json() == {"status": "ERROR", "reason": "Invalid secret"}
|
|
|
|
|
2022-02-14 12:42:43 +00:00
|
|
|
|
2021-11-17 16:53:32 +00:00
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_bleskomat_lnurl_api_unknown_api_key(client):
|
|
|
|
query = {
|
|
|
|
"id": "does-not-exist",
|
|
|
|
"nonce": secrets.token_hex(10),
|
|
|
|
"tag": "withdrawRequest",
|
|
|
|
"minWithdrawable": "1",
|
|
|
|
"maxWithdrawable": "1",
|
|
|
|
"defaultDescription": "",
|
|
|
|
"f": "EUR",
|
|
|
|
}
|
|
|
|
payload = query_to_signing_payload(query)
|
2022-02-14 12:42:43 +00:00
|
|
|
signature = "xxx" # not checked, so doesn't matter
|
|
|
|
response = await client.get(f"/bleskomat/u?{payload}&signature={signature}")
|
2021-11-17 16:53:32 +00:00
|
|
|
assert response.status_code == 200
|
|
|
|
assert response.json() == {"status": "ERROR", "reason": "Unknown API key"}
|
|
|
|
|
2022-02-14 12:42:43 +00:00
|
|
|
|
2021-11-17 16:53:32 +00:00
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_bleskomat_lnurl_api_invalid_signature(client, bleskomat):
|
|
|
|
query = {
|
|
|
|
"id": bleskomat.api_key_id,
|
|
|
|
"nonce": secrets.token_hex(10),
|
|
|
|
"tag": "withdrawRequest",
|
|
|
|
"minWithdrawable": "1",
|
|
|
|
"maxWithdrawable": "1",
|
|
|
|
"defaultDescription": "",
|
|
|
|
"f": "EUR",
|
|
|
|
}
|
|
|
|
payload = query_to_signing_payload(query)
|
|
|
|
signature = "invalid"
|
2022-02-14 12:42:43 +00:00
|
|
|
response = await client.get(f"/bleskomat/u?{payload}&signature={signature}")
|
2021-11-17 16:53:32 +00:00
|
|
|
assert response.status_code == 200
|
|
|
|
assert response.json() == {"status": "ERROR", "reason": "Invalid API key signature"}
|
|
|
|
|
2022-02-14 12:42:43 +00:00
|
|
|
|
2021-11-17 16:53:32 +00:00
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_bleskomat_lnurl_api_valid_signature(client, bleskomat):
|
|
|
|
query = {
|
|
|
|
"id": bleskomat.api_key_id,
|
|
|
|
"nonce": secrets.token_hex(10),
|
|
|
|
"tag": "withdrawRequest",
|
|
|
|
"minWithdrawable": "1",
|
|
|
|
"maxWithdrawable": "1",
|
|
|
|
"defaultDescription": "test valid sig",
|
2022-02-14 12:42:43 +00:00
|
|
|
"f": "EUR", # tests use the dummy exchange rate provider
|
2021-11-17 16:53:32 +00:00
|
|
|
}
|
|
|
|
payload = query_to_signing_payload(query)
|
|
|
|
signature = generate_bleskomat_lnurl_signature(
|
2022-03-16 06:20:15 +00:00
|
|
|
payload=payload,
|
|
|
|
api_key_secret=bleskomat.api_key_secret,
|
|
|
|
api_key_encoding=bleskomat.api_key_encoding,
|
2021-11-17 16:53:32 +00:00
|
|
|
)
|
2022-02-14 12:42:43 +00:00
|
|
|
response = await client.get(f"/bleskomat/u?{payload}&signature={signature}")
|
2021-11-17 16:53:32 +00:00
|
|
|
assert response.status_code == 200
|
|
|
|
data = response.json()
|
|
|
|
assert data["tag"] == "withdrawRequest"
|
|
|
|
assert data["minWithdrawable"] == 1000
|
|
|
|
assert data["maxWithdrawable"] == 1000
|
|
|
|
assert data["defaultDescription"] == "test valid sig"
|
2022-10-03 14:46:56 +00:00
|
|
|
assert data["callback"] == f"http://{settings.host}:{settings.port}/bleskomat/u"
|
2021-11-17 16:53:32 +00:00
|
|
|
k1 = data["k1"]
|
|
|
|
lnurl = await get_bleskomat_lnurl(secret=k1)
|
|
|
|
assert lnurl
|
|
|
|
|
2022-02-14 12:42:43 +00:00
|
|
|
|
2021-11-17 16:53:32 +00:00
|
|
|
@pytest.mark.asyncio
|
Boltz.exchange Extension (#922)
* initial commit and still draft, ready for review
* forgot to uncomment this line
* fee estimation and blockheight
* resolve conversation with michael, to use mempool websockets instead of boltz status event
* Update lnbits/extensions/boltz/boltz.py
Co-authored-by: michael1011 <me@michael1011.at>
* add status to swaps, add sorting and data into listing
* add swap status checks, change urls to docker test setup, dynamic minimum and maximum limits
* fix docker hosts for development
* add api endpoints to _api_docs
* add wallet name and id, to list and status information
* fix status_update for reverse_swaps
* chore: format with black
* more blackformatting and refactoring create_swap()
* fix variable bug
* check if swap is already refunded
* use create_task instead of ensure_future
* add mempool and boltz urls depending on DEBUG .env
* raise exception in mempool fails
* fix onchain txs, sending funds to wrong address and add a refund address for normal swaps beforehand
* add status to swaps, add sorting and data into listing
* add swap status checks, change urls to docker test setup, dynamic minimum and maximum limits
* add wallet name and id, to list and status information
* fix status_update for reverse_swaps
* chore: format with black
* use create_task instead of ensure_future
* add mempool and boltz urls depending on DEBUG .env
* fix onchain txs, sending funds to wrong address and add a refund address for normal swaps beforehand
* black formatting
* add some logging with loguru, and remove function duplication
* cleanup readme
* updates/suggestions from calle
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* remove unused comments
* Update API Endpoints
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* un-factor get_boltz_pairs
* added a explaination for the onchain tx
* remove unused template file
* rename api endpoints
* fix isort and prettier
* more verbose logging!!
* add boltz to mock_data.zip
* new mockdata
* remove comment
* better readme
* fix mempool urls
* change /refund /check /status to post requests
* first step in tests2
* add first tests
* change refund,check,status to post requests
* next try on tests
* overall code improvements
* just testing tests
* throw http exceptions in views_api
* require admincheck for refund,check,status and added fastapi documentation for those
* added more tests
* black
* many code improvements
* adding tests
* temp fix test
* fix race condition when pay_invoice fails
* test are working
* add boltz env variables
* add startup check, bugfixes, improvements
* improve on status checking
* remove check_invoice_status
* more fixes and tests
* testing testing testing
* make tests run again inside regtest
* fix bad error :O
* fix postgres boolean bug and add swap test
* Update README.md
Update README.md
Update README.md
Update README.md
* some mypy
* blacked
* the missing commit?
* fix api_docs readme link
* better refunding error catching
fix
* check swaps now also shows pending reverse swap, ui improvements, tooltips
* add backend check for boltz limits
fixup
* many improvements, startup check for swaps working, reverse needs more testing
* little last fixes
* remove unused logic
* fastapi documentation
fixup
* formatting and remove unused tests
* fix test
* fix swapstatus model
* Update lnbits/extensions/boltz/tasks.py
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* Update lnbits/extensions/boltz/views_api.py
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* balance check msg, format
* fix mypy data override
* fix swapstatus, remove can refund column
* Update lnbits/extensions/boltz/README.md
Co-authored-by: michael1011 <me@michael1011.at>
* empty lines
* fix error message when swap is not found
* remove preimage_hash from database
* fix api_docs html
fix api_docs html
* catch boltz network exceptions better
* formatting
* check for timeout on swap at get request
Co-authored-by: michael1011 <me@michael1011.at>
Co-authored-by: fusion44 <some.fusion@gmail.com>
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
2022-08-30 10:51:17 +00:00
|
|
|
@pytest.mark.skipif(is_regtest, reason="this test is only passes in fakewallet")
|
2021-11-17 16:53:32 +00:00
|
|
|
async def test_bleskomat_lnurl_api_action_insufficient_balance(client, lnurl):
|
|
|
|
bleskomat = lnurl["bleskomat"]
|
|
|
|
secret = lnurl["secret"]
|
|
|
|
pr = "lntb500n1pseq44upp5xqd38rgad72lnlh4gl339njlrsl3ykep82j6gj4g02dkule7k54qdqqcqzpgxqyz5vqsp5h0zgewuxdxcl2rnlumh6g520t4fr05rgudakpxm789xgjekha75s9qyyssq5vhwsy9knhfeqg0wn6hcnppwmum8fs3g3jxkgw45havgfl6evchjsz3s8e8kr6eyacz02szdhs7v5lg0m7wehd5rpf6yg8480cddjlqpae52xu"
|
|
|
|
WALLET.pay_invoice.reset_mock()
|
2022-02-14 12:42:43 +00:00
|
|
|
response = await client.get(f"/bleskomat/u?k1={secret}&pr={pr}")
|
2021-11-17 16:53:32 +00:00
|
|
|
assert response.status_code == 200
|
2022-02-14 12:42:43 +00:00
|
|
|
assert response.json()["status"] == "ERROR"
|
2022-03-16 06:20:15 +00:00
|
|
|
assert ("Insufficient balance" in response.json()["reason"]) or (
|
|
|
|
"fee" in response.json()["reason"]
|
|
|
|
)
|
2021-11-17 16:53:32 +00:00
|
|
|
wallet = await get_wallet(bleskomat.wallet)
|
|
|
|
assert wallet.balance_msat == 0
|
|
|
|
bleskomat_lnurl = await get_bleskomat_lnurl(secret)
|
|
|
|
assert bleskomat_lnurl.has_uses_remaining() == True
|
|
|
|
WALLET.pay_invoice.assert_not_called()
|
|
|
|
|
2022-02-14 12:42:43 +00:00
|
|
|
|
2021-11-17 16:53:32 +00:00
|
|
|
@pytest.mark.asyncio
|
Boltz.exchange Extension (#922)
* initial commit and still draft, ready for review
* forgot to uncomment this line
* fee estimation and blockheight
* resolve conversation with michael, to use mempool websockets instead of boltz status event
* Update lnbits/extensions/boltz/boltz.py
Co-authored-by: michael1011 <me@michael1011.at>
* add status to swaps, add sorting and data into listing
* add swap status checks, change urls to docker test setup, dynamic minimum and maximum limits
* fix docker hosts for development
* add api endpoints to _api_docs
* add wallet name and id, to list and status information
* fix status_update for reverse_swaps
* chore: format with black
* more blackformatting and refactoring create_swap()
* fix variable bug
* check if swap is already refunded
* use create_task instead of ensure_future
* add mempool and boltz urls depending on DEBUG .env
* raise exception in mempool fails
* fix onchain txs, sending funds to wrong address and add a refund address for normal swaps beforehand
* add status to swaps, add sorting and data into listing
* add swap status checks, change urls to docker test setup, dynamic minimum and maximum limits
* add wallet name and id, to list and status information
* fix status_update for reverse_swaps
* chore: format with black
* use create_task instead of ensure_future
* add mempool and boltz urls depending on DEBUG .env
* fix onchain txs, sending funds to wrong address and add a refund address for normal swaps beforehand
* black formatting
* add some logging with loguru, and remove function duplication
* cleanup readme
* updates/suggestions from calle
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* remove unused comments
* Update API Endpoints
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* un-factor get_boltz_pairs
* added a explaination for the onchain tx
* remove unused template file
* rename api endpoints
* fix isort and prettier
* more verbose logging!!
* add boltz to mock_data.zip
* new mockdata
* remove comment
* better readme
* fix mempool urls
* change /refund /check /status to post requests
* first step in tests2
* add first tests
* change refund,check,status to post requests
* next try on tests
* overall code improvements
* just testing tests
* throw http exceptions in views_api
* require admincheck for refund,check,status and added fastapi documentation for those
* added more tests
* black
* many code improvements
* adding tests
* temp fix test
* fix race condition when pay_invoice fails
* test are working
* add boltz env variables
* add startup check, bugfixes, improvements
* improve on status checking
* remove check_invoice_status
* more fixes and tests
* testing testing testing
* make tests run again inside regtest
* fix bad error :O
* fix postgres boolean bug and add swap test
* Update README.md
Update README.md
Update README.md
Update README.md
* some mypy
* blacked
* the missing commit?
* fix api_docs readme link
* better refunding error catching
fix
* check swaps now also shows pending reverse swap, ui improvements, tooltips
* add backend check for boltz limits
fixup
* many improvements, startup check for swaps working, reverse needs more testing
* little last fixes
* remove unused logic
* fastapi documentation
fixup
* formatting and remove unused tests
* fix test
* fix swapstatus model
* Update lnbits/extensions/boltz/tasks.py
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* Update lnbits/extensions/boltz/views_api.py
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
* balance check msg, format
* fix mypy data override
* fix swapstatus, remove can refund column
* Update lnbits/extensions/boltz/README.md
Co-authored-by: michael1011 <me@michael1011.at>
* empty lines
* fix error message when swap is not found
* remove preimage_hash from database
* fix api_docs html
fix api_docs html
* catch boltz network exceptions better
* formatting
* check for timeout on swap at get request
Co-authored-by: michael1011 <me@michael1011.at>
Co-authored-by: fusion44 <some.fusion@gmail.com>
Co-authored-by: calle <93376500+callebtc@users.noreply.github.com>
2022-08-30 10:51:17 +00:00
|
|
|
@pytest.mark.skipif(is_regtest, reason="this test is only passes in fakewallet")
|
2021-11-17 16:53:32 +00:00
|
|
|
async def test_bleskomat_lnurl_api_action_success(client, lnurl):
|
|
|
|
bleskomat = lnurl["bleskomat"]
|
|
|
|
secret = lnurl["secret"]
|
|
|
|
pr = "lntb500n1pseq44upp5xqd38rgad72lnlh4gl339njlrsl3ykep82j6gj4g02dkule7k54qdqqcqzpgxqyz5vqsp5h0zgewuxdxcl2rnlumh6g520t4fr05rgudakpxm789xgjekha75s9qyyssq5vhwsy9knhfeqg0wn6hcnppwmum8fs3g3jxkgw45havgfl6evchjsz3s8e8kr6eyacz02szdhs7v5lg0m7wehd5rpf6yg8480cddjlqpae52xu"
|
|
|
|
await credit_wallet(
|
|
|
|
wallet_id=bleskomat.wallet,
|
|
|
|
amount=100000,
|
|
|
|
)
|
|
|
|
wallet = await get_wallet(bleskomat.wallet)
|
|
|
|
assert wallet.balance_msat == 100000
|
|
|
|
WALLET.pay_invoice.reset_mock()
|
2022-02-14 12:42:43 +00:00
|
|
|
response = await client.get(f"/bleskomat/u?k1={secret}&pr={pr}")
|
2021-11-17 16:53:32 +00:00
|
|
|
assert response.json() == {"status": "OK"}
|
|
|
|
wallet = await get_wallet(bleskomat.wallet)
|
|
|
|
assert wallet.balance_msat == 50000
|
|
|
|
bleskomat_lnurl = await get_bleskomat_lnurl(secret)
|
|
|
|
assert bleskomat_lnurl.has_uses_remaining() == False
|
2022-03-16 06:20:15 +00:00
|
|
|
WALLET.pay_invoice.assert_called_once_with(pr, 2000)
|