9cb89162ab
CI Pipeline / test (pull_request) Successful in 7m5s
CI Pipeline / lint (pull_request) Has been cancelled
CI Pipeline / build (pull_request) Has been cancelled
CI Pipeline / e2e (webkit) (pull_request) Has been cancelled
CI Pipeline / e2e (chromium) (pull_request) Successful in 54m11s
CI Pipeline / e2e (firefox) (pull_request) Failing after 22m9s
CI Pipeline / visual-regression (pull_request) Successful in 11m50s
CI Pipeline / performance (pull_request) Successful in 13m59s
67 lines
1.7 KiB
TypeScript
67 lines
1.7 KiB
TypeScript
import React from "react";
|
|
import { render, screen } from "@testing-library/react";
|
|
import { describe, it, expect } from "vitest";
|
|
import HeroBanner from "../../app/components/HeroBanner";
|
|
import {
|
|
componentTestSuite,
|
|
ComponentTestSuiteConfig,
|
|
} from "../utils/componentTestSuite";
|
|
|
|
type HeroBannerProps = React.ComponentProps<typeof HeroBanner>;
|
|
|
|
const baseProps: HeroBannerProps = {
|
|
title: "Welcome",
|
|
};
|
|
|
|
const config: ComponentTestSuiteConfig<HeroBannerProps> = {
|
|
component: HeroBanner,
|
|
name: "HeroBanner",
|
|
props: baseProps,
|
|
optionalProps: {
|
|
subtitle: "Subtitle",
|
|
description: "Description",
|
|
ctaText: "CTA",
|
|
ctaHref: "/link",
|
|
},
|
|
primaryRole: "region",
|
|
testCases: {
|
|
renders: true,
|
|
accessibility: true,
|
|
keyboardNavigation: false,
|
|
disabledState: false,
|
|
errorState: false,
|
|
},
|
|
};
|
|
|
|
componentTestSuite<HeroBannerProps>(config);
|
|
|
|
describe("HeroBanner (behavioral tests)", () => {
|
|
it("renders title", () => {
|
|
render(<HeroBanner title="Test Title" />);
|
|
expect(
|
|
screen.getByRole("heading", { name: "Test Title" }),
|
|
).toBeInTheDocument();
|
|
});
|
|
|
|
it("renders subtitle when provided", () => {
|
|
render(<HeroBanner title="Test" subtitle="Subtitle" />);
|
|
expect(
|
|
screen.getByRole("heading", { name: "Subtitle" }),
|
|
).toBeInTheDocument();
|
|
});
|
|
|
|
it("renders hero image", () => {
|
|
render(<HeroBanner title="Test" />);
|
|
expect(
|
|
screen.getByRole("img", { name: "Hero illustration" }),
|
|
).toBeInTheDocument();
|
|
});
|
|
|
|
it("renders CTA button when provided", () => {
|
|
render(<HeroBanner title="Test" ctaText="Get Started" ctaHref="/start" />);
|
|
expect(
|
|
screen.getAllByRole("button", { name: "Get Started" }).length,
|
|
).toBeGreaterThan(0);
|
|
});
|
|
});
|