From b93dcde57e1c55282bf76be5656ca257aca6f0b5 Mon Sep 17 00:00:00 2001 From: Paul Miller Date: Thu, 9 May 2024 09:13:53 -0500 Subject: [PATCH] throw error if faucet fails --- e2e/roundtrip.spec.ts | 30 ++++++++++++++++-------------- src/components/FederationPopup.tsx | 2 +- src/state/megaStore.tsx | 24 +++++++++++++++++++----- 3 files changed, 36 insertions(+), 20 deletions(-) diff --git a/e2e/roundtrip.spec.ts b/e2e/roundtrip.spec.ts index e922e755..32aecb31 100644 --- a/e2e/roundtrip.spec.ts +++ b/e2e/roundtrip.spec.ts @@ -54,21 +54,23 @@ test("rountrip receive and send", async ({ page }) => { // The SVG's value property includes "lightning:l" expect(value).toContain("lightning:l"); - const lightningInvoice = value?.split("lightning:")[1]; - // Post the lightning invoice to the server - const _response = await fetch( - "https://faucet.mutinynet.com/api/lightning", - { - method: "POST", - headers: { - "Content-Type": "application/json" - }, - body: JSON.stringify({ - bolt11: lightningInvoice - }) - } - ); + const response = await fetch("https://faucet.mutinynet.com/api/lightning", { + method: "POST", + mode: "cors", + headers: { + "Content-Type": "application/json" + }, + body: JSON.stringify({ + bolt11: value + }) + }); + + if (!response.ok) { + response.text().then((text) => { + throw new Error("failed to post invoice to faucet: " + text); + }); + } // Wait for an h1 to appear in the dom that says "Payment Received" await page.waitForSelector("text=Payment Received", { timeout: 30000 }); diff --git a/src/components/FederationPopup.tsx b/src/components/FederationPopup.tsx index b30dd5df..44d46516 100644 --- a/src/components/FederationPopup.tsx +++ b/src/components/FederationPopup.tsx @@ -18,7 +18,7 @@ export function FederationPopup() { return ( { if (!open) { diff --git a/src/state/megaStore.tsx b/src/state/megaStore.tsx index 126f475c..a6b7b234 100644 --- a/src/state/megaStore.tsx +++ b/src/state/megaStore.tsx @@ -89,7 +89,11 @@ export const makeMegaStoreContext = () => { federations: undefined as MutinyFederationIdentity[] | undefined, balanceView: localStorage.getItem("balanceView") || "sats", expiration_warning: undefined as - | { expiresTimestamp: number; expiresMessage: string } + | { + expiresTimestamp: number; + expiresMessage: string; + federationName: string; + } | undefined, expiration_warning_seen: false }); @@ -233,14 +237,19 @@ export const makeMegaStoreContext = () => { const federations = await sw.list_federations(); let expiration_warning: - | { expiresTimestamp: number; expiresMessage: string } + | { + expiresTimestamp: number; + expiresMessage: string; + federationName: string; + } | undefined = undefined; federations.forEach((f) => { if (f.popup_countdown_message && f.popup_end_timestamp) { expiration_warning = { expiresTimestamp: f.popup_end_timestamp, - expiresMessage: f.popup_countdown_message + expiresMessage: f.popup_countdown_message, + federationName: f.federation_name }; } }); @@ -485,14 +494,19 @@ export const makeMegaStoreContext = () => { const federations = await sw.list_federations(); let expiration_warning: - | { expiresTimestamp: number; expiresMessage: string } + | { + expiresTimestamp: number; + expiresMessage: string; + federationName: string; + } | undefined = undefined; federations.forEach((f) => { if (f.popup_countdown_message && f.popup_end_timestamp) { expiration_warning = { expiresTimestamp: f.popup_end_timestamp, - expiresMessage: f.popup_countdown_message + expiresMessage: f.popup_countdown_message, + federationName: f.federation_name }; } });