1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00
lens/packages/core/src/features/welcome/setting-welcome-page.test.tsx
Sebastian Malton a63f737adb
Change typing for after/before window/application start (#7342)
- Now the callback is provided with an object containing either
  `mainDi` or `windowDi` fields. This should help with confusion
  over which environment the `di` is for

Signed-off-by: Sebastian Malton <sebastian@malton.name>
2023-03-13 15:35:33 +02:00

100 lines
3.5 KiB
TypeScript

/**
* Copyright (c) OpenLens Authors. All rights reserved.
* Licensed under MIT License. See LICENSE in root directory for more information.
*/
import type { RenderResult } from "@testing-library/react";
import React from "react";
import type { ApplicationBuilder } from "../../renderer/components/test-utils/get-application-builder";
import { getApplicationBuilder } from "../../renderer/components/test-utils/get-application-builder";
import type { FakeExtensionOptions } from "../../renderer/components/test-utils/get-extension-fake";
import welcomeRouteConfigInjectable from "../../common/front-end-routing/routes/welcome/welcome-route-config.injectable";
import welcomeRouteInjectable from "../../common/front-end-routing/routes/welcome/welcome-route.injectable";
import type { Route } from "../../common/front-end-routing/front-end-route-injection-token";
describe("setting-welcome-page", () => {
let applicationBuilder: ApplicationBuilder;
let rendered : RenderResult;
let welcomeRoute: Route;
beforeEach(() => {
applicationBuilder = getApplicationBuilder();
});
describe("given configuration of welcome page route is the default", () => {
beforeEach(async () => {
applicationBuilder.beforeApplicationStart(({ mainDi }) => {
mainDi.override(welcomeRouteConfigInjectable, () => "/welcome");
});
applicationBuilder.beforeWindowStart(({ windowDi }) => {
windowDi.override(welcomeRouteConfigInjectable, () => "/welcome");
});
// enable the extension even though the welcomeRoute is not overriden
applicationBuilder.extensions.enable(extensionWithWelcomePage);
rendered = await applicationBuilder.render();
const windowDi = applicationBuilder.applicationWindow.only.di;
welcomeRoute = windowDi.inject(welcomeRouteInjectable);
});
it("sets the default welcome page", () => {
expect(welcomeRoute.path).toEqual("/welcome");
});
it("launches to the default welcome page", () => {
const welcomePage = rendered.getByTestId("welcome-page"); // from the Welcome component (welcome.tsx)
expect(welcomePage).toBeInTheDocument();
});
});
describe("given configuration of welcome page route is set to a custom page", () => {
beforeEach(async () => {
applicationBuilder.beforeApplicationStart(({ mainDi }) => {
mainDi.override(welcomeRouteConfigInjectable, () => "/extension/some-extension-name/some-welcome-page");
});
applicationBuilder.beforeWindowStart(({ windowDi }) => {
windowDi.override(welcomeRouteConfigInjectable, () => "/extension/some-extension-name/some-welcome-page");
});
applicationBuilder.extensions.enable(extensionWithWelcomePage);
rendered = await applicationBuilder.render();
const windowDi = applicationBuilder.applicationWindow.only.di;
welcomeRoute = windowDi.inject(welcomeRouteInjectable);
});
it("sets the custom welcome page", () => {
expect(welcomeRoute.path).toEqual("/extension/some-extension-name/some-welcome-page");
});
it("launches to the custom welcome page ", () => {
const welcomePage = rendered.getByTestId("some-welcome-test-id");
expect(welcomePage).toBeInTheDocument();
});
});
});
const extensionWithWelcomePage: FakeExtensionOptions = {
id: "some-extension-id",
name: "some-extension-name",
rendererOptions: {
globalPages: [
{
id: "some-welcome-page",
components: {
Page: () => <div data-testid="some-welcome-test-id">Welcome page</div>,
},
},
],
},
};