mirror of
https://github.com/aljazceru/nutshell.git
synced 2025-12-23 11:44:19 +01:00
Add get quote API to wallet + check proof states in batches (#637)
* add get quote api to wallet * wrong string * test before pushing * fix tests for deprecated api only * sigh
This commit is contained in:
@@ -4,6 +4,7 @@ import pytest_asyncio
|
||||
from cashu.core.base import MeltQuoteState
|
||||
from cashu.core.helpers import sum_proofs
|
||||
from cashu.core.models import PostMeltQuoteRequest, PostMintQuoteRequest
|
||||
from cashu.core.settings import settings
|
||||
from cashu.mint.ledger import Ledger
|
||||
from cashu.wallet.wallet import Wallet
|
||||
from cashu.wallet.wallet import Wallet as Wallet1
|
||||
@@ -55,6 +56,13 @@ async def test_melt_internal(wallet1: Wallet, ledger: Ledger):
|
||||
assert melt_quote.amount == 64
|
||||
assert melt_quote.fee_reserve == 0
|
||||
|
||||
if not settings.debug_mint_only_deprecated:
|
||||
melt_quote_response_pre_payment = await wallet1.get_melt_quote(melt_quote.quote)
|
||||
assert (
|
||||
not melt_quote_response_pre_payment.state == MeltQuoteState.paid.value
|
||||
), "melt quote should not be paid"
|
||||
assert melt_quote_response_pre_payment.amount == 64
|
||||
|
||||
melt_quote_pre_payment = await ledger.get_melt_quote(melt_quote.quote)
|
||||
assert not melt_quote_pre_payment.paid, "melt quote should not be paid"
|
||||
assert melt_quote_pre_payment.unpaid
|
||||
@@ -89,6 +97,13 @@ async def test_melt_external(wallet1: Wallet, ledger: Ledger):
|
||||
PostMeltQuoteRequest(request=invoice_payment_request, unit="sat")
|
||||
)
|
||||
|
||||
if not settings.debug_mint_only_deprecated:
|
||||
melt_quote_response_pre_payment = await wallet1.get_melt_quote(melt_quote.quote)
|
||||
assert (
|
||||
melt_quote_response_pre_payment.state == MeltQuoteState.unpaid.value
|
||||
), "melt quote should not be paid"
|
||||
assert melt_quote_response_pre_payment.amount == melt_quote.amount
|
||||
|
||||
melt_quote_pre_payment = await ledger.get_melt_quote(melt_quote.quote)
|
||||
assert not melt_quote_pre_payment.paid, "melt quote should not be paid"
|
||||
assert melt_quote_pre_payment.unpaid
|
||||
@@ -109,7 +124,12 @@ async def test_mint_internal(wallet1: Wallet, ledger: Ledger):
|
||||
mint_quote = await ledger.get_mint_quote(invoice.id)
|
||||
|
||||
assert mint_quote.paid, "mint quote should be paid"
|
||||
assert mint_quote.paid
|
||||
|
||||
if not settings.debug_mint_only_deprecated:
|
||||
mint_quote_resp = await wallet1.get_mint_quote(invoice.id)
|
||||
assert (
|
||||
mint_quote_resp.state == MeltQuoteState.paid.value
|
||||
), "mint quote should be paid"
|
||||
|
||||
output_amounts = [128]
|
||||
secrets, rs, derivation_paths = await wallet1.generate_n_secrets(
|
||||
@@ -139,6 +159,10 @@ async def test_mint_external(wallet1: Wallet, ledger: Ledger):
|
||||
assert not mint_quote.paid, "mint quote already paid"
|
||||
assert mint_quote.unpaid
|
||||
|
||||
if not settings.debug_mint_only_deprecated:
|
||||
mint_quote_resp = await wallet1.get_mint_quote(quote.quote)
|
||||
assert not mint_quote_resp.paid, "mint quote should not be paid"
|
||||
|
||||
await assert_err(
|
||||
wallet1.mint(128, id=quote.quote),
|
||||
"quote not paid",
|
||||
|
||||
Reference in New Issue
Block a user