mirror of
https://github.com/vector-im/element-web.git
synced 2025-11-09 12:41:07 +01:00
* Make shared component build work in isolation * Add deps that were missing because they were getting picked up from element-web main but shared-components needs itself * Exclude test files from dts generation * Bump version * Change all the shared-component import to be the built artifact * Don't randomly inhale eslint configs in parent dirs please * maybe we don't need this anymore? * maybe fix build * Maybe fix docker build * More build faff * build:res on the parent as part of shared component prepare * link shared component repo inn docker build * 💅 * 💅x2 * Try converting the translation keys to a .d.ts file manually so it gets bundled rather than left as a relative import to the json file * add the script * Add this back for 2nd time now I think * Shouldn't need this anymore * patch-package on prepare because we're patching a dev dependency so it won't be there if we're installed as a dependency * Unused import * Prettier compliance * Only use counterpart from shared components as per comment * Import shared components CSS * Prettier * Call the one from shared components rather than recurse infinitely * Hopefully make tests work * wake up, comment goes before import * Fix lint errors * Fix dupe TranslationKey export * Update compound-web to fix type error An update to @types.react adds the 'hint' value to the enum of the 'popover' attribute and this version of compound-web uses the maching verson of @types/react so they don't conflict. * Maybe, hopefully, get the types working? Please? * Add copyright header to i18nkeys as eslint complains otherwise since it's now in src * prettier * stop running shared-component tests in EW * update snapshots because flex is now from an external stylesheet I guess * More snapshots * Manual class update * Avoid bundling compound bits Because a) it's silly and b) it means we end up bundling a copy of floating-ui too which causes absolute madness with its useDelayGroup contexts. * ignore test util files for coverage * Add !important because the styles are being applied in a different order now * Another !important because css order has changed * Try adding it here to make the test files ignored * More !important * commit yarn lock change * Add shared components coverage file * Update snapshots Because the line height was being overridden to 22.5px somehow by something I can't find, and now isn't: surely the normal 1.5rem is more sensible. * Update snapshots, attempt 2 * Another !important * More snapshot updates * Add test for i18n wrappers & add test script * lint * Prettier * Hopefully run shared component tests * don't need this bit for non-matrix * install ew deps * rigfht coverage location * Rename job here too * Try different coverage filename * Fix copyrights & comment * Typo Co-authored-by: Michael Telatynski <7t3chguy@gmail.com> --------- Co-authored-by: Michael Telatynski <7t3chguy@gmail.com>
75 lines
3.2 KiB
TypeScript
75 lines
3.2 KiB
TypeScript
/*
|
|
Copyright 2024 New Vector Ltd.
|
|
Copyright 2023 The Matrix.org Foundation C.I.C.
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only OR LicenseRef-Element-Commercial
|
|
Please see LICENSE files in the repository root for full details.
|
|
*/
|
|
|
|
import { env } from "process";
|
|
|
|
import type { Config } from "jest";
|
|
|
|
const config: Config = {
|
|
testEnvironment: "jsdom",
|
|
testEnvironmentOptions: {
|
|
url: "http://localhost/",
|
|
// This is needed to be able to load dual CJS/ESM WASM packages e.g. rust crypto & matrix-wywiwyg
|
|
customExportConditions: ["browser", "node"],
|
|
},
|
|
testMatch: ["<rootDir>/test/**/*-test.[tj]s?(x)"],
|
|
globalSetup: "<rootDir>/test/globalSetup.ts",
|
|
setupFiles: ["jest-canvas-mock", "web-streams-polyfill/polyfill"],
|
|
setupFilesAfterEnv: ["<rootDir>/test/setupTests.ts"],
|
|
moduleNameMapper: {
|
|
// Support CSS module
|
|
"\\.(module.css)$": "identity-obj-proxy",
|
|
"\\.(css|scss|pcss)$": "<rootDir>/__mocks__/cssMock.js",
|
|
"\\.(gif|png|ttf|woff2)$": "<rootDir>/__mocks__/imageMock.js",
|
|
"\\.svg$": "<rootDir>/__mocks__/svg.js",
|
|
"\\$webapp/i18n/languages.json": "<rootDir>/__mocks__/languages.json",
|
|
"^react$": "<rootDir>/node_modules/react",
|
|
"^react-dom$": "<rootDir>/node_modules/react-dom",
|
|
"^matrix-js-sdk$": "<rootDir>/node_modules/matrix-js-sdk/src",
|
|
"^matrix-react-sdk$": "<rootDir>/src",
|
|
"decoderWorker\\.min\\.js": "<rootDir>/__mocks__/empty.js",
|
|
"decoderWorker\\.min\\.wasm": "<rootDir>/__mocks__/empty.js",
|
|
"waveWorker\\.min\\.js": "<rootDir>/__mocks__/empty.js",
|
|
"context-filter-polyfill": "<rootDir>/__mocks__/empty.js",
|
|
"workers/(.+)Factory": "<rootDir>/__mocks__/workerFactoryMock.js",
|
|
"^!!raw-loader!.*": "jest-raw-loader",
|
|
"recorderWorkletFactory": "<rootDir>/__mocks__/empty.js",
|
|
"^fetch-mock$": "<rootDir>/node_modules/fetch-mock",
|
|
"counterpart": "<rootDir>/node_modules/counterpart",
|
|
},
|
|
transformIgnorePatterns: [
|
|
"/node_modules/(?!(mime|matrix-js-sdk|uuid|p-retry|is-network-error|react-merge-refs)).+$",
|
|
],
|
|
collectCoverageFrom: [
|
|
"<rootDir>/src/**/*.{js,ts,tsx}",
|
|
"<rootDir>/packages/**/*.{js,ts,tsx}",
|
|
// getSessionLock is piped into a different JS context via stringification, and the coverage functionality is
|
|
// not available in that contest. So, turn off coverage instrumentation for it.
|
|
"!<rootDir>/src/utils/SessionLock.ts",
|
|
// Coverage chokes on type definition files
|
|
"!<rootDir>/src/**/*.d.ts",
|
|
],
|
|
coverageReporters: ["text-summary", "lcov"],
|
|
testResultsProcessor: "@casualbot/jest-sonar-reporter",
|
|
prettierPath: null,
|
|
moduleDirectories: ["node_modules", "test/test-utils"],
|
|
};
|
|
|
|
// if we're running under GHA, enable the GHA reporter
|
|
if (env["GITHUB_ACTIONS"] !== undefined) {
|
|
const reporters: Config["reporters"] = [["github-actions", { silent: false }], "summary"];
|
|
|
|
// if we're running against the develop branch, also enable the slow test reporter
|
|
if (env["GITHUB_REF"] == "refs/heads/develop") {
|
|
reporters.push("<rootDir>/test/slowReporter.cjs");
|
|
}
|
|
config.reporters = reporters;
|
|
}
|
|
|
|
export default config;
|