From 659ac77b977e1e6800c33e691d256efcd14401bc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dafydd=20Ll=C5=B7r=20Pearson?= Date: Sat, 7 Oct 2023 11:03:28 +0100 Subject: [PATCH 1/3] wip: Handle async views --- e2e/tests/ui-driven/playwright.config.ts | 2 +- editor.planx.uk/src/routes/authenticated.tsx | 2 +- editor.planx.uk/src/routes/team.tsx | 2 +- editor.planx.uk/src/routes/views/team.tsx | 26 ++++++++++++-------- 4 files changed, 19 insertions(+), 13 deletions(-) diff --git a/e2e/tests/ui-driven/playwright.config.ts b/e2e/tests/ui-driven/playwright.config.ts index 1e9b9cee58..e76e9771e1 100644 --- a/e2e/tests/ui-driven/playwright.config.ts +++ b/e2e/tests/ui-driven/playwright.config.ts @@ -46,7 +46,7 @@ const config: PlaywrightTestConfig = { webServer: { command: `pnpm ui`, port: 3000, - reuseExistingServer: false, + reuseExistingServer: !process.env.CI, }, /* Configure projects for major browsers */ projects: [ diff --git a/editor.planx.uk/src/routes/authenticated.tsx b/editor.planx.uk/src/routes/authenticated.tsx index d8a7966536..96d1bb41c0 100644 --- a/editor.planx.uk/src/routes/authenticated.tsx +++ b/editor.planx.uk/src/routes/authenticated.tsx @@ -10,7 +10,7 @@ import { makeTitle } from "./utils"; import { authenticatedView } from "./views/authenticated"; const editorRoutes = compose( - withView(authenticatedView), + withView(async () => await authenticatedView()), mount({ "/": route(async () => { diff --git a/editor.planx.uk/src/routes/team.tsx b/editor.planx.uk/src/routes/team.tsx index 12e3f355b2..5279c3afdd 100644 --- a/editor.planx.uk/src/routes/team.tsx +++ b/editor.planx.uk/src/routes/team.tsx @@ -14,7 +14,7 @@ let cached: { flowSlug?: string; teamSlug?: string } = { }; const routes = compose( - withView(teamView), + withView(async (req) => await teamView(req)), mount({ "/": route(() => ({ diff --git a/editor.planx.uk/src/routes/views/team.tsx b/editor.planx.uk/src/routes/views/team.tsx index 3a2a02d296..0d6332f03f 100644 --- a/editor.planx.uk/src/routes/views/team.tsx +++ b/editor.planx.uk/src/routes/views/team.tsx @@ -1,3 +1,4 @@ +import { logger } from "airbrake"; import { NaviRequest, NotFoundError } from "navi"; import { useStore } from "pages/FlowEditor/lib/store"; import React from "react"; @@ -9,17 +10,22 @@ import { getTeamFromDomain } from "routes/utils"; * Initialises TeamStore if not already set */ export const teamView = async (req: NaviRequest) => { - const { initTeamStore, teamSlug: currentSlug } = useStore.getState(); - const routeSlug = - req.params.team || (await getTeamFromDomain(window.location.hostname)); + try { + const { initTeamStore, teamSlug: currentSlug } = useStore.getState(); + const routeSlug = + req.params.team || (await getTeamFromDomain(window.location.hostname)); - if (currentSlug !== routeSlug) { - try { - await initTeamStore(routeSlug); - } catch (error) { - throw new NotFoundError(`Team not found: ${error}`); + if (currentSlug !== routeSlug) { + try { + await initTeamStore(routeSlug); + } catch (error) { + throw new NotFoundError(`Team not found: ${error}`); + } } - } - return ; + return ; + } catch (error) { + console.error("ERROR WITHIN TEAM VIEW: ", error); + logger.notify(error); + } }; From f7dde3729d78486326b8cd1e275907590ec1441f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dafydd=20Ll=C5=B7r=20Pearson?= Date: Sat, 7 Oct 2023 11:56:26 +0100 Subject: [PATCH 2/3] wip: Logging, trycatch --- editor.planx.uk/src/routes/index.tsx | 9 +++- editor.planx.uk/src/routes/pay.tsx | 26 +++++++---- .../src/routes/views/standalone.tsx | 44 +++++++++++-------- 3 files changed, 51 insertions(+), 28 deletions(-) diff --git a/editor.planx.uk/src/routes/index.tsx b/editor.planx.uk/src/routes/index.tsx index 9acce1e60f..cbcb28b0f5 100644 --- a/editor.planx.uk/src/routes/index.tsx +++ b/editor.planx.uk/src/routes/index.tsx @@ -1,3 +1,4 @@ +import { logger } from "airbrake"; import { lazy, map, mount, redirect, route } from "navi"; import * as React from "react"; @@ -58,7 +59,13 @@ const editorRoutes = mount({ const mountPayRoutes = () => map(async () => { - return lazy(() => import("./pay")); + try { + return lazy(() => import("./pay")); + } catch (error) { + console.log("ERROR MOUNTING PAY ROUTES"); + logger.notify(error); + throw Error(`error in pay mount: ${error}`); + } }); export default isPreviewOnlyDomain diff --git a/editor.planx.uk/src/routes/pay.tsx b/editor.planx.uk/src/routes/pay.tsx index ca0da6e521..d7e9fe3368 100644 --- a/editor.planx.uk/src/routes/pay.tsx +++ b/editor.planx.uk/src/routes/pay.tsx @@ -21,19 +21,27 @@ import standaloneView from "./views/standalone"; const payRoutes = compose( withData(async (req) => { - const externalDomainTeam = await getTeamFromDomain( - window.location.hostname, - ); + try { + const externalDomainTeam = await getTeamFromDomain( + window.location.hostname, + ); - return { - mountpath: req.mountpath, - isPreviewOnlyDomain: Boolean(externalDomainTeam), - }; + return { + mountpath: req.mountpath, + isPreviewOnlyDomain: Boolean(externalDomainTeam), + }; + } catch (error) { + throw Error(`ERROR IN PAY WITHDATA: ${error}`); + } }), withView(async (req) => { - await validateTeamRoute(req); - return await standaloneView(req); + try { + await validateTeamRoute(req); + return await standaloneView(req); + } catch (error) { + throw Error(`ERROR IN PAY WITHVIEW: ${error}`); + } }), mount({ diff --git a/editor.planx.uk/src/routes/views/standalone.tsx b/editor.planx.uk/src/routes/views/standalone.tsx index 9169cde616..beb4029c19 100644 --- a/editor.planx.uk/src/routes/views/standalone.tsx +++ b/editor.planx.uk/src/routes/views/standalone.tsx @@ -1,3 +1,4 @@ +import { logger } from "airbrake"; import gql from "graphql-tag"; import { publicClient } from "lib/graphql"; import { NaviRequest, NotFoundError } from "navi"; @@ -19,27 +20,34 @@ interface StandaloneViewData { * Fetches all necessary data, and sets up layout for a standalone page */ const standaloneView = async (req: NaviRequest) => { - const flowSlug = req.params.flow.split(",")[0]; - const teamSlug = - req.params.team || (await getTeamFromDomain(window.location.hostname)); - const data = await fetchDataForStandaloneView(flowSlug, teamSlug); + try { + const flowSlug = req.params.flow.split(",")[0]; + const teamSlug = + req.params.team || (await getTeamFromDomain(window.location.hostname)); + const data = await fetchDataForStandaloneView(flowSlug, teamSlug); + if (!data) return; - const { - flows: [{ team, settings: flowSettings }], - globalSettings, - } = data; + // ERROR HERE + const { + flows: [{ team, settings: flowSettings }], + globalSettings, + } = data; - const state = useStore.getState(); - state.setFlowNameFromSlug(flowSlug); - state.setGlobalSettings(globalSettings[0]); - state.setFlowSettings(flowSettings); - state.setTeam(team); + const state = useStore.getState(); + state.setFlowNameFromSlug(flowSlug); + state.setGlobalSettings(globalSettings[0]); + state.setFlowSettings(flowSettings); + state.setTeam(team); - return ( - - - - ); + return ( + + + + ); + } catch (error) { + console.log("ERROR IN STANDALONE VIEW: ", error); + logger.notify(error); + } }; const fetchDataForStandaloneView = async ( From 7e1d876253a53b6d0d88b90a1c9977bac54334f0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dafydd=20Ll=C5=B7r=20Pearson?= Date: Sat, 7 Oct 2023 13:07:16 +0100 Subject: [PATCH 3/3] wip: More debugging --- editor.planx.uk/src/routes/index.tsx | 22 +++++++++------------- editor.planx.uk/src/routes/pay.tsx | 2 ++ editor.planx.uk/src/routes/utils.ts | 1 + 3 files changed, 12 insertions(+), 13 deletions(-) diff --git a/editor.planx.uk/src/routes/index.tsx b/editor.planx.uk/src/routes/index.tsx index cbcb28b0f5..8a7d8048fd 100644 --- a/editor.planx.uk/src/routes/index.tsx +++ b/editor.planx.uk/src/routes/index.tsx @@ -1,4 +1,3 @@ -import { logger } from "airbrake"; import { lazy, map, mount, redirect, route } from "navi"; import * as React from "react"; @@ -57,28 +56,25 @@ const editorRoutes = mount({ ), }); -const mountPayRoutes = () => - map(async () => { - try { - return lazy(() => import("./pay")); - } catch (error) { - console.log("ERROR MOUNTING PAY ROUTES"); - logger.notify(error); - throw Error(`error in pay mount: ${error}`); - } - }); +const tryImport = () => { + try { + return lazy(() => import("./pay")); + } catch (error) { + throw Error(`ERROR MOUNTING PAY ROUTES (LAZY): ${error}`); + } +}; export default isPreviewOnlyDomain ? mount({ "/:team/:flow/preview": lazy(() => import("./preview")), // XXX: keeps old URL working, but only for the team listed in the domain. "/:flow": lazy(() => import("./preview")), - "/:flow/pay": mountPayRoutes(), + "/:flow/pay": tryImport(), // XXX: We're not sure where to redirect `/` to so for now we'll just return the default 404 // "/": redirect("somewhere?"), }) : mount({ "/:team/:flow/preview": lazy(() => import("./preview")), // loads published flow if exists, or current flow "/:team/:flow/unpublished": lazy(() => import("./unpublished")), // loads current flow - "/:team/:flow/pay": mountPayRoutes(), + "/:team/:flow/pay": tryImport(), "*": editorRoutes, }); diff --git a/editor.planx.uk/src/routes/pay.tsx b/editor.planx.uk/src/routes/pay.tsx index d7e9fe3368..1b1cc5cdf9 100644 --- a/editor.planx.uk/src/routes/pay.tsx +++ b/editor.planx.uk/src/routes/pay.tsx @@ -21,6 +21,7 @@ import standaloneView from "./views/standalone"; const payRoutes = compose( withData(async (req) => { + console.log("inside pay withData"); try { const externalDomainTeam = await getTeamFromDomain( window.location.hostname, @@ -46,6 +47,7 @@ const payRoutes = compose( mount({ "/": route(async (req) => { + console.log("inside pay mount"); const paymentRequest = await getPaymentRequest(req); if (!paymentRequest) { return { diff --git a/editor.planx.uk/src/routes/utils.ts b/editor.planx.uk/src/routes/utils.ts index 9822188c8a..4e7541f12b 100644 --- a/editor.planx.uk/src/routes/utils.ts +++ b/editor.planx.uk/src/routes/utils.ts @@ -90,6 +90,7 @@ export const getTeamFromDomain = pMemoize(async (domain: string) => { * e.g. https://planningservices.southwark.gov.uk/lambeth/some-flow/preview */ export const validateTeamRoute = async (req: NaviRequest) => { + console.log("inside ValidateTeamRoute"); const externalTeamName = await getTeamFromDomain(window.location.hostname); if ( req.params.team &&