mirror of
https://github.com/aljazceru/nutshell.git
synced 2025-12-20 18:44:20 +01:00
* fix keys * fix tests * backwards compatible api upgrade * upgrade seems to work * fix tests * add deprecated api functions * add more tests of backwards compat * add test serialization for nut00 * remove a redundant test * move mint and melt to new api * mypy works * CI: mypy --check-untyped-defs * add deprecated router * add hints and remove logs * fix tests * cleanup * use new mint and melt endpoints * tests passing? * fix mypy * make format * make format * make format * commit * errors gone * save * adjust the API * store quotes in db * make mypy happy * add fakewallet settings * remove LIGHTNING=True and pass quote id for melt * format * tests passing * add CoreLightningRestWallet * add macaroon loader * add correct config * preimage -> proof * move wallet.status() to cli.helpers.print_status() * remove statuses from tests * remove * make format * Use httpx in deprecated wallet * fix cln interface * create invoice before quote * internal transactions and deprecated api testing * fix tests * add deprecated API tests * fastapi type hints break things * fix duplicate wallet error * make format * update poetry in CI to 1.7.1 * precommit restore * remove bolt11 * oops * default poetry * store fee reserve for melt quotes and refactor melt() * works? * make format * test * finally * fix deprecated models * rename v1 endpoints to bolt11 * raise restore and check to v1, bump version to 0.15.0 * add version byte to keyset id * remove redundant fields in json * checks * generate bip32 keyset wip * migrate old keysets * load duplicate keys * duplicate old keysets * revert router changes * add deprecated /check and /restore endpoints * try except invalidate * parse unit from derivation path, adjust keyset id calculation with bytes * remove keyest id from functions again and rely on self.keyset_id * mosts tests work * mint loads multiple derivation paths * make format * properly print units * fix tests * wallet works with multiple units * add strike wallet and choose backend dynamically * fix mypy * add get_payment_quote to lightning backends * make format * fix startup * fix lnbitswallet * fix tests * LightningWallet -> LightningBackend * remove comments * make format * remove msat conversion * add Amount type * fix regtest * use melt_quote as argument for pay_invoice * test old api * fees in sats * fix deprecated fees * fixes * print balance correctly * internally index keyset response by int * add pydantic validation to input models * add timestamps to mint db * store timestamps for invoices, promises, proofs_used * fix wallet migration * rotate keys correctly for testing * remove print * update latest keyset * fix tests * fix test * make format * make format with correct black version * remove nsat and cheese * test against deprecated mint * fix tests? * actually use env var * mint run with env vars * moar test * cleanup * simplify tests, load all keys * try out testing with internal invoices * fix internal melt test * fix test * deprecated checkfees expects appropriate fees * adjust comment * drop lightning table * split migration for testing for now, remove it later * remove unused lightning table * skip_private_key -> skip_db_read * throw error on migration error * reorder * fix migrations * fix lnbits fee return value negative * fix typo * comments * add type * make format * split must use correct amount * fix tests * test deprecated api with internal/external melts * do not split if not necessary * refactor * fix test * make format with new black * cleanup and add comments * add quote state check endpoints * fix deprecated wallet response * split -> swap endpoint * make format * add expiry to quotes, get quote endpoints, and adjust to nut review comments * allow overpayment of melt * add lightning wallet tests * commiting to save * fix tests a bit * make format * remove comments * get mint info * check_spendable default False, and return payment quote checking id * make format * bump version in pyproject * update to /v1/checkstate * make format * fix mint api checks * return witness on /v1/checkstate * no failfast * try fail-fast: false in ci.yaml * fix db lookup * clean up literals
198 lines
6.6 KiB
Python
198 lines
6.6 KiB
Python
import asyncio
|
|
|
|
import pytest
|
|
import pytest_asyncio
|
|
from fastapi.testclient import TestClient
|
|
|
|
from cashu.lightning.base import InvoiceResponse, PaymentStatus
|
|
from cashu.wallet.api.app import app
|
|
from cashu.wallet.wallet import Wallet
|
|
from tests.conftest import SERVER_ENDPOINT
|
|
from tests.helpers import is_regtest
|
|
|
|
|
|
@pytest_asyncio.fixture(scope="function")
|
|
async def wallet():
|
|
wallet = await Wallet.with_db(
|
|
url=SERVER_ENDPOINT,
|
|
db="test_data/wallet",
|
|
name="wallet",
|
|
)
|
|
await wallet.load_mint()
|
|
yield wallet
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_invoice(wallet: Wallet):
|
|
with TestClient(app) as client:
|
|
response = client.post("/lightning/create_invoice?amount=100")
|
|
assert response.status_code == 200
|
|
invoice_response = InvoiceResponse.parse_obj(response.json())
|
|
state = PaymentStatus(paid=False)
|
|
while not state.paid:
|
|
print("checking invoice state")
|
|
response2 = client.get(
|
|
f"/lightning/invoice_state?payment_hash={invoice_response.checking_id}"
|
|
)
|
|
state = PaymentStatus.parse_obj(response2.json())
|
|
await asyncio.sleep(0.1)
|
|
print("state:", state)
|
|
print("paid")
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_balance():
|
|
with TestClient(app) as client:
|
|
response = client.get("/balance")
|
|
assert response.status_code == 200
|
|
assert "balance" in response.json()
|
|
assert response.json()["keysets"]
|
|
assert response.json()["mints"]
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_send(wallet: Wallet):
|
|
with TestClient(app) as client:
|
|
response = client.post("/send?amount=10")
|
|
assert response.status_code == 200
|
|
assert response.json()["balance"]
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_send_without_split(wallet: Wallet):
|
|
with TestClient(app) as client:
|
|
response = client.post("/send?amount=2&nosplit=true")
|
|
assert response.status_code == 200
|
|
assert response.json()["balance"]
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_send_without_split_but_wrong_amount(wallet: Wallet):
|
|
with TestClient(app) as client:
|
|
response = client.post("/send?amount=10&nosplit=true")
|
|
assert response.status_code == 400
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_pending():
|
|
with TestClient(app) as client:
|
|
response = client.get("/pending")
|
|
assert response.status_code == 200
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_receive_all(wallet: Wallet):
|
|
with TestClient(app) as client:
|
|
response = client.post("/receive?all=true")
|
|
assert response.status_code == 200
|
|
assert response.json()["initial_balance"]
|
|
assert response.json()["balance"]
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_burn_all(wallet: Wallet):
|
|
with TestClient(app) as client:
|
|
response = client.post("/send?amount=20")
|
|
assert response.status_code == 200
|
|
response = client.post("/burn?all=true")
|
|
assert response.status_code == 200
|
|
assert response.json()["balance"]
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_pay():
|
|
with TestClient(app) as client:
|
|
invoice = (
|
|
"lnbc100n1pjjcqzfdq4gdshx6r4ypjx2ur0wd5hgpp58xvj8yn00d5"
|
|
"7uhshwzcwgy9uj3vwf5y2lr5fjf78s4w9l4vhr6xssp5stezsyty9r"
|
|
"hv3lat69g4mhqxqun56jyehhkq3y8zufh83xyfkmmq4usaqwrt5q4f"
|
|
"adm44g6crckp0hzvuyv9sja7t65hxj0ucf9y46qstkay7gfnwhuxgr"
|
|
"krf7djs38rml39l8wpn5ug9shp3n55quxhdecqfwxg23"
|
|
)
|
|
response = client.post(f"/lightning/pay_invoice?bolt11={invoice}")
|
|
assert response.status_code == 200
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_lock():
|
|
with TestClient(app) as client:
|
|
response = client.get("/lock")
|
|
assert response.status_code == 200
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_locks():
|
|
with TestClient(app) as client:
|
|
response = client.get("/locks")
|
|
assert response.status_code == 200
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_invoices():
|
|
with TestClient(app) as client:
|
|
response = client.get("/invoices")
|
|
assert response.status_code == 200
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_wallets():
|
|
with TestClient(app) as client:
|
|
response = client.get("/wallets")
|
|
assert response.status_code == 200
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_info():
|
|
with TestClient(app) as client:
|
|
response = client.get("/info")
|
|
assert response.status_code == 200
|
|
assert response.json()["version"]
|
|
|
|
|
|
@pytest.mark.skipif(is_regtest, reason="regtest")
|
|
@pytest.mark.asyncio
|
|
async def test_flow(wallet: Wallet):
|
|
with TestClient(app) as client:
|
|
response = client.get("/balance")
|
|
initial_balance = response.json()["balance"]
|
|
response = client.post("/lightning/create_invoice?amount=100")
|
|
invoice_response = InvoiceResponse.parse_obj(response.json())
|
|
state = PaymentStatus(paid=False)
|
|
while not state.paid:
|
|
print("checking invoice state")
|
|
response2 = client.get(
|
|
f"/lightning/invoice_state?payment_hash={invoice_response.checking_id}"
|
|
)
|
|
state = PaymentStatus.parse_obj(response2.json())
|
|
await asyncio.sleep(0.1)
|
|
print("state:", state)
|
|
|
|
response = client.get("/balance")
|
|
assert response.json()["balance"] == initial_balance + 100
|
|
response = client.post("/send?amount=50")
|
|
response = client.get("/balance")
|
|
assert response.json()["balance"] == initial_balance + 50
|
|
response = client.post("/send?amount=50")
|
|
response = client.get("/balance")
|
|
assert response.json()["balance"] == initial_balance
|
|
response = client.get("/pending")
|
|
token = response.json()["pending_token"]["0"]["token"]
|
|
amount = response.json()["pending_token"]["0"]["amount"]
|
|
response = client.post(f"/receive?token={token}")
|
|
response = client.get("/balance")
|
|
assert response.json()["balance"] == initial_balance + amount
|