Report group call errors to sentry

This commit is contained in:
Valere
2026-04-03 11:12:39 +02:00
parent b1f84a34a8
commit de1304a9a7
2 changed files with 44 additions and 0 deletions

View File

@@ -16,6 +16,7 @@ import {
} from "react";
import { BrowserRouter } from "react-router-dom";
import userEvent from "@testing-library/user-event";
import * as Sentry from "@sentry/react";
import {
type CallErrorRecoveryAction,
@@ -32,6 +33,15 @@ import {
import { mockConfig } from "../utils/test.ts";
import { ElementWidgetActions, type WidgetHelpers } from "../widget.ts";
// Mock Sentry before importing the component
vi.mock("@sentry/react", async () => {
const actual = await vi.importActual("@sentry/react");
return {
...actual,
captureException: vi.fn(),
};
});
test.each([
{
error: new MatrixRTCTransportMissingError("example.com"),
@@ -212,6 +222,33 @@ describe("Rageshake button", () => {
});
});
test("should call Sentry.captureException for unknown errors", async () => {
vi.mocked(Sentry.captureException).mockClear(); // Clear previous calls
const originalError = new Error("Unknown test error");
const error = new UnknownCallError(originalError);
const TestComponent = (): ReactNode => {
throw error;
};
render(
<BrowserRouter>
<GroupCallErrorBoundary
onError={vi.fn()}
recoveryActionHandler={vi.fn()}
widget={null}
>
<TestComponent />
</GroupCallErrorBoundary>
</BrowserRouter>,
);
await screen.findByText(/Something went wrong/);
expect(Sentry.captureException).toHaveBeenCalledWith(error);
expect(Sentry.captureException).toHaveBeenCalledOnce();
});
test("should have a close button in widget mode", async () => {
const error = new MatrixRTCTransportMissingError("example.com");
const TestComponent = (): ReactNode => {

View File

@@ -13,7 +13,9 @@ import {
type ReactNode,
type SVGAttributes,
useCallback,
useEffect,
} from "react";
import * as Sentry from "@sentry/react";
import { Trans, useTranslation } from "react-i18next";
import {
ErrorSolidIcon,
@@ -53,6 +55,11 @@ const ErrorPage: FC<ErrorPageProps> = ({
recoveryActionHandler,
widget,
}: ErrorPageProps): ReactElement => {
// We want to auto capture to sentry
useEffect(() => {
Sentry.captureException(error);
}, [error]);
const { t } = useTranslation();
logger.error("Error boundary caught:", error);
let icon: ComponentType<SVGAttributes<SVGElement>>;