Skip to content

Commit

Permalink
Test is added for wrapper.
Browse files Browse the repository at this point in the history
Signed-off-by: Mikhail Aheichyk <mikhail.aheichyk@nordeck.net>
  • Loading branch information
Mikhail Aheichyk committed Aug 22, 2023
1 parent 761d08e commit 845d911
Showing 1 changed file with 90 additions and 0 deletions.
90 changes: 90 additions & 0 deletions test/app-tests/wrapper-test.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
/*
Copyright 2023 Mikhail Aheichyk
Copyright 2023 Nordeck IT + Consulting GmbH.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/

import React from "react";
import SdkConfig from "matrix-react-sdk/src/SdkConfig";
import PlatformPeg from "matrix-react-sdk/src/PlatformPeg";
import fetchMock from "fetch-mock-jest";
import { render, RenderResult, screen, waitFor } from "@testing-library/react";
import { ModuleRunner } from "matrix-react-sdk/src/modules/ModuleRunner";
import { WrapperLifecycle, WrapperOpts } from "@matrix-org/react-sdk-module-api/lib/lifecycles/WrapperLifecycle";

import WebPlatform from "../../src/vector/platform/WebPlatform";
import { loadApp } from "../../src/vector/app";

fetchMock.config.overwriteRoutes = true;

describe("Wrapper", () => {
beforeEach(async () => {
SdkConfig.reset();
PlatformPeg.set(new WebPlatform());
fetchMock.get("https://matrix-client.matrix.org/_matrix/client/versions", {
unstable_features: {},
versions: ["v1.1"],
});
fetchMock.get("https://matrix.org/.well-known/matrix/client", {
"m.homeserver": {
base_url: "https://matrix-client.matrix.org",
},
});
fetchMock.get("/version", "1.10.13");
});

it("wrap a matrix client with header and footer", async () => {
SdkConfig.put({
default_server_config: {
"m.homeserver": {
base_url: "https://matrix-client.matrix.org",
},
},
});

jest.spyOn(ModuleRunner.instance, "invoke").mockImplementation((lifecycleEvent, opts) => {
if (lifecycleEvent === WrapperLifecycle.Wrapper) {
(opts as WrapperOpts).Wrapper = ({ children }) => {
return (
<>
<div>Header</div>
{children}
<div>Footer</div>
</>
);
};
}
});

const matrixChat: RenderResult = render(await loadApp({}));

// at this point, we're trying to do a guest registration;
// we expect a spinner
await assertAtLoadingSpinner();

await awaitWelcomeComponent(matrixChat);

// Are not semantic elements because Element has a footer already.
screen.getByRole(/Header/i);

Check failure on line 79 in test/app-tests/wrapper-test.tsx

View workflow job for this annotation

GitHub Actions / Jest

Wrapper › wrap a matrix client with header and footer

TestingLibraryElementError: Unable to find an accessible element with the role "/Header/i" Here are the accessible roles: button: Name "Language Dropdown": <div aria-describedby="mx_LanguageDropdown_value" aria-expanded="false" aria-haspopup="listbox" aria-label="Language Dropdown" aria-owns="mx_LanguageDropdown_input" class="mx_AccessibleButton mx_Dropdown_input mx_no_textinput" role="button" tabindex="0" /> -------------------------------------------------- contentinfo: Name "": <footer class="mx_AuthFooter" role="contentinfo" /> -------------------------------------------------- link: Name "powered by Matrix": <a href="https://matrix.org" rel="noreferrer noopener" target="_blank" /> -------------------------------------------------- Ignored nodes: comments, script, style <body> <div> <div> Header </div> <div class="mx_AuthPage" > <div class="mx_AuthPage_modal" > <div class="mx_Welcome" > <div class="mx_WelcomePage mx_WelcomePage_guest" > <div class="mx_WelcomePage_body" > Couldn't load page </div> </div> <div class="mx_Dropdown mx_AuthBody_language" > <div aria-describedby="mx_LanguageDropdown_value" aria-expanded="false" aria-haspopup="listbox" aria-label="Language Dropdown" aria-owns="mx_LanguageDropdown_input" class="mx_AccessibleButton mx_Dropdown_input mx_no_textinput" role="button" tabindex="0" > <div class="mx_Dropdown_option" id="mx_LanguageDropdown_value" > <div> English </div> </div> <span class="mx_Dropdown_arrow" /> </div> </div> </div> </div> <footer class="mx_AuthFooter" role="contentinfo" > <a href="https://matrix.org" rel="noreferrer noopener" target="_blank" > powered by Matrix </a> </footer> </div> <div> Footer </div> </div> </body> at Object.getElementError (node_modules/@testing-library/dom/dist/config.js:37:19) at node_modules/@testing-library/dom/dist/query-helpers.js:76:38 at node_modules/@testing-library/dom/dist/query-helpers.js:52:17 at node_modules/@testing-library/dom/dist/query-helpers.js:95:19 at Object.getByRole (test/app-tests/wrapper-test.tsx:79:16)
screen.getByText(/Footer/i);
});
});

async function assertAtLoadingSpinner(): Promise<void> {
await screen.findByRole("progressbar");
}

async function awaitWelcomeComponent(matrixChat?: RenderResult): Promise<void> {
await waitFor(() => matrixChat?.container.querySelector(".mx_Welcome"));
}

0 comments on commit 845d911

Please sign in to comment.