diff --git a/packages/orbit-components/src/Checkbox/Checkbox.ct-story.tsx b/packages/orbit-components/src/Checkbox/Checkbox.ct-story.tsx
index eb7f224fe3..e385708d61 100644
--- a/packages/orbit-components/src/Checkbox/Checkbox.ct-story.tsx
+++ b/packages/orbit-components/src/Checkbox/Checkbox.ct-story.tsx
@@ -1,10 +1,10 @@
import React from "react";
-import Text from "../Text";
+import Tooltip from "../Tooltip";
import Checkbox from ".";
-export default function CheckboxStory() {
+export function CheckboxStory() {
return (
@@ -12,8 +12,32 @@ export default function CheckboxStory() {
- Tooltip} />
);
}
+
+export function CheckboxWithTooltipStory({
+ checked,
+ disabled,
+ hasError,
+ readOnly,
+}: {
+ checked?: boolean;
+ disabled?: boolean;
+ hasError?: boolean;
+ readOnly?: boolean;
+}) {
+ return (
+
+ }
+ />
+
+ );
+}
diff --git a/packages/orbit-components/src/Checkbox/Checkbox.ct.tsx b/packages/orbit-components/src/Checkbox/Checkbox.ct.tsx
index e01e0577f8..372068511f 100644
--- a/packages/orbit-components/src/Checkbox/Checkbox.ct.tsx
+++ b/packages/orbit-components/src/Checkbox/Checkbox.ct.tsx
@@ -1,12 +1,113 @@
import * as React from "react";
import { test, expect } from "@playwright/experimental-ct-react";
-import CheckboxStory from "./Checkbox.ct-story";
+import { CheckboxStory, CheckboxWithTooltipStory } from "./Checkbox.ct-story";
test.describe("visual Checkbox", () => {
test("Checkbox", async ({ mount }) => {
const component = await mount();
+ await expect(component).toHaveScreenshot();
+ });
+
+ test("Checkbox - disabled, active tooltip on desktop", async ({ mount, browserName }) => {
+ /**
+ * This command skips the test if the browser is not Chromium.
+ * Condition inside is based on the browser name,
+ * which is specified by the device name in playwright-ct.config.ts file.
+ * Using that we can distinguish mobile/tablet devices and desktop devices.
+ */
+ test.skip(browserName !== "chromium", "This feature is desktop-only");
+
+ const component = await mount();
+
+ await component.getByRole("button").hover();
+ await expect(component).toHaveScreenshot();
+ });
+
+ test("Checkbox - checked, active tooltip on desktop", async ({ mount, browserName }) => {
+ test.skip(browserName !== "chromium", "This feature is desktop-only");
+
+ const component = await mount();
+
+ await component.getByRole("button").hover();
+ await expect(component).toHaveScreenshot();
+ });
+
+ test("Checkbox - readOnly, active tooltip on desktop", async ({ mount, browserName }) => {
+ test.skip(browserName !== "chromium", "This feature is desktop-only");
+
+ const component = await mount();
+
+ await component.getByRole("button").hover();
+ await expect(component).toHaveScreenshot();
+ });
+
+ test("Checkbox - hasError, active tooltip on desktop", async ({ mount, browserName }) => {
+ test.skip(browserName !== "chromium", "This feature is desktop-only");
+
+ const component = await mount();
+
+ await component.getByRole("button").hover();
+ await expect(component).toHaveScreenshot();
+ });
+
+ test("Checkbox - checked, disabled tooltip on desktop", async ({ mount, browserName }) => {
+ test.skip(browserName !== "chromium", "This feature is desktop-only");
+
+ const component = await mount();
+
+ await component.getByRole("button").hover();
+ await expect(component).toHaveScreenshot();
+ });
+
+ test("Checkbox - disabled, active tooltip on mobile", async ({ mount, browserName, page }) => {
+ /**
+ * This command skips the test if the browser is not Webkit.
+ * Condition inside is based on the browser name,
+ * which is specified by the device name in playwright-ct.config.ts file.
+ * Using that we can distinguish mobile/tablet devices and desktop devices.
+ */
+ test.skip(browserName !== "webkit", "This feature is mobile and tablet only");
+ const component = await mount();
+
+ await component.getByRole("button").click();
+ await page.getByRole("tooltip").last().isVisible();
+ await expect(component).toHaveScreenshot();
+ });
+
+ test("Checkbox - checked, active tooltip on mobile", async ({ mount, browserName, page }) => {
+ test.skip(browserName !== "webkit", "This feature is mobile and tablet only");
+ const component = await mount();
+
+ await component.getByRole("button").click();
+ await page.getByRole("tooltip").last().isVisible();
+ await expect(component).toHaveScreenshot();
+ });
+
+ test("Checkbox - readOnly, active tooltip on mobile", async ({ mount, browserName, page }) => {
+ test.skip(browserName !== "webkit", "This feature is mobile and tablet only");
+ const component = await mount();
+
+ await component.getByRole("button").click();
+ await page.getByRole("tooltip").last().isVisible();
+ await expect(component).toHaveScreenshot();
+ });
+
+ test("Checkbox - hasError, active tooltip on mobile", async ({ mount, browserName, page }) => {
+ test.skip(browserName !== "webkit", "This feature is mobile and tablet only");
+ const component = await mount();
+
+ await component.getByRole("button").click();
+ await page.getByRole("tooltip").last().isVisible();
+ await expect(component).toHaveScreenshot();
+ });
+
+ test("Checkbox - checked, disbled tooltip on mobile", async ({ mount, browserName, page }) => {
+ test.skip(browserName !== "webkit", "This feature is mobile and tablet only");
+ const component = await mount();
+ await component.getByRole("button").click();
+ await page.getByRole("tooltip").last().isVisible();
await expect(component).toHaveScreenshot();
});
});