mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
- 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>
100 lines
3.5 KiB
TypeScript
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>,
|
|
},
|
|
},
|
|
],
|
|
},
|
|
};
|