@windstream/react-shared-components 0.1.93 → 0.1.95

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (112) hide show
  1. package/dist/contentful/index.esm.js +2 -2
  2. package/dist/contentful/index.esm.js.map +1 -1
  3. package/dist/contentful/index.js +3 -3
  4. package/dist/contentful/index.js.map +1 -1
  5. package/dist/core.d.ts +2 -2
  6. package/dist/index.d.ts +2 -2
  7. package/dist/index.esm.js +1 -1
  8. package/dist/index.esm.js.map +1 -1
  9. package/dist/index.js +3 -3
  10. package/dist/index.js.map +1 -1
  11. package/dist/styles.css +1 -1
  12. package/dist/utils/index.esm.js +1 -1
  13. package/dist/utils/index.js +1 -1
  14. package/package.json +14 -8
  15. package/src/components/accordion/index.test.tsx +270 -0
  16. package/src/components/alert-card/index.test.tsx +152 -0
  17. package/src/components/animation-wrapper/index.test.tsx +424 -0
  18. package/src/components/brand-button/index.test.tsx +292 -0
  19. package/src/components/button/index.test.tsx +91 -0
  20. package/src/components/call-button/index.test.tsx +260 -0
  21. package/src/components/checkbox/index.test.tsx +252 -0
  22. package/src/components/checklist/index.test.tsx +231 -0
  23. package/src/components/checklist/index.tsx +64 -29
  24. package/src/components/checklist/types.ts +7 -1
  25. package/src/components/collapse/index.test.tsx +277 -0
  26. package/src/components/collapse/index.tsx +1 -0
  27. package/src/components/divider/index.test.tsx +53 -0
  28. package/src/components/image/index.test.tsx +174 -0
  29. package/src/components/input/index.test.tsx +348 -0
  30. package/src/components/link/index.test.tsx +199 -0
  31. package/src/components/list/index.test.tsx +166 -0
  32. package/src/components/material-icon/index.test.tsx +130 -0
  33. package/src/components/modal/index.test.tsx +310 -0
  34. package/src/components/next-image/index.test.tsx +406 -0
  35. package/src/components/pagination/index.test.tsx +521 -0
  36. package/src/components/radio-button/index.test.tsx +151 -0
  37. package/src/components/see-more/index.test.tsx +96 -0
  38. package/src/components/select/index.test.tsx +256 -0
  39. package/src/components/select-plan-button/index.test.tsx +173 -0
  40. package/src/components/skeleton/index.test.tsx +74 -0
  41. package/src/components/spinner/index.test.tsx +76 -0
  42. package/src/components/text/index.test.tsx +65 -0
  43. package/src/components/tooltip/index.test.tsx +50 -0
  44. package/src/components/view-cart-button/index.test.tsx +57 -0
  45. package/src/contentful/blocks/accordion/index.test.tsx +218 -0
  46. package/src/contentful/blocks/accordion/index.tsx +3 -1
  47. package/src/contentful/blocks/address-input-banner/index.test.tsx +132 -0
  48. package/src/contentful/blocks/anchored-bottom-banner/index.test.tsx +287 -0
  49. package/src/contentful/blocks/blogs-grid/BlogGrid.stories.tsx +5 -4
  50. package/src/contentful/blocks/blogs-grid/index.test.tsx +355 -0
  51. package/src/contentful/blocks/blogs-grid-base/index.test.tsx +274 -0
  52. package/src/contentful/blocks/breadcrumbs/index.test.tsx +281 -0
  53. package/src/contentful/blocks/button/index.test.tsx +339 -0
  54. package/src/contentful/blocks/callout/index.test.tsx +539 -0
  55. package/src/contentful/blocks/cards/blog-card/index.test.tsx +218 -0
  56. package/src/contentful/blocks/cards/floating-image-card/index.test.tsx +201 -0
  57. package/src/contentful/blocks/cards/full-image-card/index.test.tsx +216 -0
  58. package/src/contentful/blocks/cards/index.test.tsx +39 -0
  59. package/src/contentful/blocks/cards/product-card/index.test.tsx +263 -0
  60. package/src/contentful/blocks/cards/simple-card/index.test.tsx +364 -0
  61. package/src/contentful/blocks/cards/simple-card/index.tsx +1 -1
  62. package/src/contentful/blocks/cards/testimonial-card/index.test.tsx +180 -0
  63. package/src/contentful/blocks/carousel/helper.test.tsx +539 -0
  64. package/src/contentful/blocks/carousel/index.test.tsx +308 -0
  65. package/src/contentful/blocks/carousel/types.test.ts +16 -0
  66. package/src/contentful/blocks/cart-retention-banner/index.test.tsx +409 -0
  67. package/src/contentful/blocks/cart-retention-banner/index.tsx +4 -4
  68. package/src/contentful/blocks/comparison-table/index.test.tsx +114 -0
  69. package/src/contentful/blocks/cookiebanner/index.test.tsx +277 -0
  70. package/src/contentful/blocks/cta-callout/index.test.tsx +244 -0
  71. package/src/contentful/blocks/dynamic-tabs/index.test.tsx +240 -0
  72. package/src/contentful/blocks/email-input-block/index.test.tsx +213 -0
  73. package/src/contentful/blocks/email-input-block/index.tsx +40 -35
  74. package/src/contentful/blocks/find-kinetic/index.test.tsx +269 -0
  75. package/src/contentful/blocks/floating-banner/index.test.tsx +246 -0
  76. package/src/contentful/blocks/footer/index.test.tsx +302 -0
  77. package/src/contentful/blocks/image-promo-bar/helper.test.tsx +61 -0
  78. package/src/contentful/blocks/image-promo-bar/index.test.tsx +467 -0
  79. package/src/contentful/blocks/image-promo-bar/index.tsx +248 -246
  80. package/src/contentful/blocks/image-promo-bar/vimeo-embed.test.tsx +142 -0
  81. package/src/contentful/blocks/image-promo-bar/youtube-embed.test.tsx +104 -0
  82. package/src/contentful/blocks/modal/index.test.tsx +209 -0
  83. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.test.tsx +208 -0
  84. package/src/contentful/blocks/navigation/index.test.tsx +924 -0
  85. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.test.tsx +131 -0
  86. package/src/contentful/blocks/primary-hero/index.test.tsx +286 -0
  87. package/src/contentful/blocks/primary-hero/index.tsx +7 -4
  88. package/src/contentful/blocks/search-block/index.test.tsx +268 -0
  89. package/src/contentful/blocks/shape-background-wrapper/index.test.tsx +284 -0
  90. package/src/contentful/blocks/text/index.test.tsx +36 -0
  91. package/src/contentful/index.test.ts +45 -0
  92. package/src/global-mocks/contentful/to-document.ts +25 -0
  93. package/src/global-mocks/cookie.ts +48 -0
  94. package/src/global-mocks/cx.ts +37 -0
  95. package/src/global-mocks/index.ts +89 -0
  96. package/src/global-mocks/speed-card-bg.ts +27 -0
  97. package/src/global-mocks/utm.ts +49 -0
  98. package/src/hooks/contentful/use-contentful-rich-text.test.tsx +1758 -0
  99. package/src/hooks/contentful/use-contentful-rich-text.tsx +1 -1
  100. package/src/hooks/contentful/use-processed-check-list.test.tsx +277 -0
  101. package/src/hooks/use-body-scroll-lock.test.ts +134 -0
  102. package/src/hooks/use-carousel-swipe.test.ts +393 -0
  103. package/src/hooks/use-outside-click.test.ts +142 -0
  104. package/src/index.ts +1 -1
  105. package/src/next/index.test.ts +7 -0
  106. package/src/setupTests.ts +17 -11
  107. package/src/utils/contentful/to-document.test.ts +85 -0
  108. package/src/utils/cookie.test.ts +180 -0
  109. package/src/utils/cx.test.ts +90 -0
  110. package/src/utils/index.test.ts +115 -0
  111. package/src/utils/speed-card-bg.test.ts +46 -0
  112. package/src/utils/utm.test.ts +359 -0
@@ -0,0 +1,467 @@
1
+ import React from "react";
2
+ import { ImagePromoBar } from "./index";
3
+ import { ImagePromoBarProps } from "./types";
4
+
5
+ import { fireEvent, render, screen } from "@testing-library/react";
6
+
7
+ jest.mock("../button", () => ({
8
+ __esModule: true,
9
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
10
+ Button: ({ buttonLabel, ...rest }: any) => (
11
+ <button data-testid="cta-button">{buttonLabel || "CTA"}</button>
12
+ ),
13
+ default: ({ buttonLabel }: any) => (
14
+ <button data-testid="cta-button">{buttonLabel || "CTA"}</button>
15
+ ),
16
+ }));
17
+
18
+ jest.mock("./helper", () => ({
19
+ PlayButton: ({ isHovered }: any) => (
20
+ <div data-testid="play-button" data-hovered={isHovered} />
21
+ ),
22
+ }));
23
+
24
+ jest.mock("./vimeo-embed", () => ({
25
+ VimeoEmbed: ({ link, autoplay }: any) => (
26
+ <div data-testid="vimeo-embed" data-link={link} data-autoplay={autoplay} />
27
+ ),
28
+ }));
29
+
30
+ jest.mock("./youtube-embed", () => ({
31
+ YoutubeEmbed: ({ link, autoplay }: any) => (
32
+ <div
33
+ data-testid="youtube-embed"
34
+ data-link={link}
35
+ data-autoplay={autoplay}
36
+ />
37
+ ),
38
+ }));
39
+
40
+ jest.mock("@shared/components/checklist", () => ({
41
+ Checklist: ({ items }: any) => (
42
+ <ul data-testid="checklist">
43
+ {items.map((i: string, idx: number) => (
44
+ <li key={idx}>{i}</li>
45
+ ))}
46
+ </ul>
47
+ ),
48
+ }));
49
+
50
+ jest.mock("@shared/components/image", () => ({
51
+ Image: ({ src, alt }: any) => <img data-testid="image" src={src} alt={alt} />,
52
+ }));
53
+
54
+ jest.mock("@shared/components/link", () => ({
55
+ Link: ({ children, href }: any) => (
56
+ <a data-testid="image-link" href={href}>
57
+ {children}
58
+ </a>
59
+ ),
60
+ }));
61
+
62
+ jest.mock("@shared/components/next-image", () => ({
63
+ NextImage: ({ src, alt }: any) => (
64
+ <img data-testid="next-image" src={src} alt={alt} />
65
+ ),
66
+ }));
67
+
68
+ jest.mock("@shared/components/text", () => ({
69
+ Text: ({ as: Tag = "span", children, className }: any) => (
70
+ <Tag className={className}>{children}</Tag>
71
+ ),
72
+ }));
73
+
74
+ jest.mock("@shared/utils", () => ({
75
+ cx: (...args: any[]) => args.filter(Boolean).join(" "),
76
+ }));
77
+
78
+ const defaultProps: ImagePromoBarProps = {
79
+ brow: "",
80
+ enableHeading: false,
81
+ title: "",
82
+ subTitle: "",
83
+ image: "",
84
+ imageWidth: 660,
85
+ imageHeight: 660,
86
+ mediaPosition: true,
87
+ description: null,
88
+ openDescriptionLinksOnANewTab: false,
89
+ checklist: [],
90
+ disclaimer: null,
91
+ imageLinks: [],
92
+ cta: null,
93
+ secondaryCta: null,
94
+ ctaDisclaimer: null,
95
+ videoLink: { link: "", image: "", videoPopup: false },
96
+ maxWidth: true,
97
+ color: "light",
98
+ };
99
+
100
+ describe("ImagePromoBar", () => {
101
+ describe("Text content", () => {
102
+ it("renders brow text when provided", () => {
103
+ render(<ImagePromoBar {...defaultProps} brow="New" />);
104
+ expect(screen.getByText("New")).toBeInTheDocument();
105
+ });
106
+
107
+ it("renders title as h2 when enableHeading is false", () => {
108
+ render(<ImagePromoBar {...defaultProps} title="Title" />);
109
+ expect(screen.getByRole("heading", { level: 2 })).toHaveTextContent(
110
+ "Title"
111
+ );
112
+ });
113
+
114
+ it("renders title as h1 when enableHeading is true", () => {
115
+ render(
116
+ <ImagePromoBar {...defaultProps} title="Title" enableHeading={true} />
117
+ );
118
+ expect(screen.getByRole("heading", { level: 1 })).toHaveTextContent(
119
+ "Title"
120
+ );
121
+ });
122
+
123
+ it("renders subTitle as h3 when enableHeading is false", () => {
124
+ render(<ImagePromoBar {...defaultProps} subTitle="Sub" />);
125
+ expect(screen.getByRole("heading", { level: 3 })).toHaveTextContent(
126
+ "Sub"
127
+ );
128
+ });
129
+
130
+ it("renders subTitle as h2 when enableHeading is true", () => {
131
+ render(
132
+ <ImagePromoBar {...defaultProps} subTitle="Sub" enableHeading={true} />
133
+ );
134
+ expect(screen.getByText("Sub").tagName).toBe("H2");
135
+ });
136
+
137
+ it("renders description", () => {
138
+ render(<ImagePromoBar {...defaultProps} description="Desc text" />);
139
+ expect(screen.getByText("Desc text")).toBeInTheDocument();
140
+ });
141
+
142
+ it("renders ctaDisclaimer and disclaimer", () => {
143
+ render(
144
+ <ImagePromoBar
145
+ {...defaultProps}
146
+ ctaDisclaimer="Discl1"
147
+ disclaimer="Discl2"
148
+ />
149
+ );
150
+ expect(screen.getByText("Discl1")).toBeInTheDocument();
151
+ expect(screen.getByText("Discl2")).toBeInTheDocument();
152
+ });
153
+ });
154
+
155
+ describe("Color and layout", () => {
156
+ it("applies text-white for light color", () => {
157
+ const { container } = render(
158
+ <ImagePromoBar {...defaultProps} color="light" />
159
+ );
160
+ expect(container.querySelector(".text-white")).toBeInTheDocument();
161
+ });
162
+
163
+ it("applies text-text for dark color", () => {
164
+ const { container } = render(
165
+ <ImagePromoBar {...defaultProps} color="dark" />
166
+ );
167
+ expect(container.querySelector(".text-text")).toBeInTheDocument();
168
+ });
169
+
170
+ it("applies max-w-120 when maxWidth is true", () => {
171
+ const { container } = render(
172
+ <ImagePromoBar {...defaultProps} maxWidth={true} />
173
+ );
174
+ expect(container.querySelector(".max-w-120")).toBeInTheDocument();
175
+ });
176
+
177
+ it("does not apply max-w-120 when maxWidth is false", () => {
178
+ const { container } = render(
179
+ <ImagePromoBar {...defaultProps} maxWidth={false} />
180
+ );
181
+ expect(container.querySelector(".max-w-120")).not.toBeInTheDocument();
182
+ });
183
+
184
+ it("applies lg:flex-row-reverse when mediaPosition is true", () => {
185
+ const { container } = render(
186
+ <ImagePromoBar {...defaultProps} mediaPosition={true} />
187
+ );
188
+ expect(container.innerHTML).toContain("lg:flex-row-reverse");
189
+ });
190
+
191
+ it("applies lg:flex-row when mediaPosition is false", () => {
192
+ const { container } = render(
193
+ <ImagePromoBar {...defaultProps} mediaPosition={false} />
194
+ );
195
+ expect(container.innerHTML).toContain("lg:flex-row");
196
+ expect(container.innerHTML).not.toContain("lg:flex-row-reverse");
197
+ });
198
+ });
199
+
200
+ describe("Checklist", () => {
201
+ it("renders checklist when items exist", () => {
202
+ render(
203
+ <ImagePromoBar {...defaultProps} checklist={["Item 1", "Item 2"]} />
204
+ );
205
+ expect(screen.getByTestId("checklist")).toBeInTheDocument();
206
+ });
207
+
208
+ it("does not render checklist when empty", () => {
209
+ render(<ImagePromoBar {...defaultProps} checklist={[]} />);
210
+ expect(screen.queryByTestId("checklist")).not.toBeInTheDocument();
211
+ });
212
+ });
213
+
214
+ describe("Image links", () => {
215
+ it("renders image links when provided", () => {
216
+ const imageLinks = [
217
+ { url: "https://a.com", image: "https://img.test/a.png" },
218
+ { url: "https://b.com", image: "https://img.test/b.png" },
219
+ ];
220
+ render(<ImagePromoBar {...defaultProps} imageLinks={imageLinks} />);
221
+ const links = screen.getAllByTestId("image-link");
222
+ expect(links).toHaveLength(2);
223
+ expect(links[0]).toHaveAttribute("href", "https://a.com");
224
+ });
225
+ });
226
+
227
+ describe("CTAs", () => {
228
+ it("renders primary CTA", () => {
229
+ render(<ImagePromoBar {...defaultProps} cta={{ buttonLabel: "Buy" }} />);
230
+ expect(screen.getByTestId("cta-button")).toBeInTheDocument();
231
+ });
232
+
233
+ it("renders both CTAs", () => {
234
+ render(
235
+ <ImagePromoBar
236
+ {...defaultProps}
237
+ cta={{ buttonLabel: "Primary" }}
238
+ secondaryCta={{ buttonLabel: "Secondary" }}
239
+ />
240
+ );
241
+ expect(screen.getAllByTestId("cta-button")).toHaveLength(2);
242
+ });
243
+
244
+ it("does not render CTA section when neither provided", () => {
245
+ const { container } = render(<ImagePromoBar {...defaultProps} />);
246
+ expect(container.querySelector(".primary-cta")).not.toBeInTheDocument();
247
+ });
248
+ });
249
+
250
+ describe("Image", () => {
251
+ it("renders NextImage when image is provided", () => {
252
+ render(
253
+ <ImagePromoBar {...defaultProps} image="https://img.test/hero.jpg" />
254
+ );
255
+ const img = screen.getByTestId("next-image");
256
+ expect(img).toHaveAttribute("src", "https://img.test/hero.jpg");
257
+ });
258
+
259
+ it("does not render image section when image is empty", () => {
260
+ render(<ImagePromoBar {...defaultProps} image="" />);
261
+ expect(screen.queryByTestId("next-image")).not.toBeInTheDocument();
262
+ });
263
+ });
264
+
265
+ describe("Video", () => {
266
+ it("renders video section with play button when videoLink has link and image", () => {
267
+ render(
268
+ <ImagePromoBar
269
+ {...defaultProps}
270
+ videoLink={{
271
+ link: "https://youtube.com/watch?v=123",
272
+ image: "thumb.jpg",
273
+ }}
274
+ />
275
+ );
276
+ expect(screen.getByTestId("play-button")).toBeInTheDocument();
277
+ expect(screen.getByAltText("Video preview")).toBeInTheDocument();
278
+ });
279
+
280
+ it("shows youtube embed on click for youtube link", () => {
281
+ render(
282
+ <ImagePromoBar
283
+ {...defaultProps}
284
+ videoLink={{
285
+ link: "https://youtube.com/watch?v=123",
286
+ image: "thumb.jpg",
287
+ videoPopup: false,
288
+ }}
289
+ />
290
+ );
291
+ fireEvent.click(
292
+ screen.getByTestId("play-button").closest(".video-section")!
293
+ );
294
+ expect(screen.getByTestId("youtube-embed")).toBeInTheDocument();
295
+ });
296
+
297
+ it("shows vimeo embed on click for vimeo link", () => {
298
+ render(
299
+ <ImagePromoBar
300
+ {...defaultProps}
301
+ videoLink={{
302
+ link: "https://vimeo.com/123",
303
+ image: "thumb.jpg",
304
+ videoPopup: false,
305
+ }}
306
+ />
307
+ );
308
+ fireEvent.click(
309
+ screen.getByTestId("play-button").closest(".video-section")!
310
+ );
311
+ expect(screen.getByTestId("vimeo-embed")).toBeInTheDocument();
312
+ });
313
+
314
+ it("shows popup overlay when videoPopup is true and playing", () => {
315
+ const { container } = render(
316
+ <ImagePromoBar
317
+ {...defaultProps}
318
+ videoLink={{
319
+ link: "https://youtube.com/watch?v=123",
320
+ image: "thumb.jpg",
321
+ videoPopup: true,
322
+ }}
323
+ />
324
+ );
325
+ fireEvent.click(
326
+ screen.getByTestId("play-button").closest(".video-section")!
327
+ );
328
+ expect(container.querySelector(".fixed")).toBeInTheDocument();
329
+ });
330
+
331
+ it("closes popup on overlay click", () => {
332
+ const { container } = render(
333
+ <ImagePromoBar
334
+ {...defaultProps}
335
+ videoLink={{
336
+ link: "https://youtube.com/watch?v=123",
337
+ image: "thumb.jpg",
338
+ videoPopup: true,
339
+ }}
340
+ />
341
+ );
342
+ fireEvent.click(
343
+ screen.getByTestId("play-button").closest(".video-section")!
344
+ );
345
+ fireEvent.click(container.querySelector(".fixed")!);
346
+ expect(container.querySelector(".fixed")).not.toBeInTheDocument();
347
+ });
348
+
349
+ it("does not close popup when clicking inside video container", () => {
350
+ const { container } = render(
351
+ <ImagePromoBar
352
+ {...defaultProps}
353
+ videoLink={{
354
+ link: "https://youtube.com/watch?v=123",
355
+ image: "thumb.jpg",
356
+ videoPopup: true,
357
+ }}
358
+ />
359
+ );
360
+ fireEvent.click(
361
+ screen.getByTestId("play-button").closest(".video-section")!
362
+ );
363
+ const inner = container.querySelector(".max-w-6xl");
364
+ fireEvent.click(inner!);
365
+ expect(container.querySelector(".fixed")).toBeInTheDocument();
366
+ });
367
+
368
+ it("handles hover state on video section", () => {
369
+ render(
370
+ <ImagePromoBar
371
+ {...defaultProps}
372
+ videoLink={{
373
+ link: "https://youtube.com/watch?v=123",
374
+ image: "thumb.jpg",
375
+ }}
376
+ />
377
+ );
378
+ const videoSection = screen
379
+ .getByTestId("play-button")
380
+ .closest(".video-section")!;
381
+ fireEvent.mouseEnter(videoSection);
382
+ expect(screen.getByTestId("play-button")).toHaveAttribute(
383
+ "data-hovered",
384
+ "true"
385
+ );
386
+ fireEvent.mouseLeave(videoSection);
387
+ expect(screen.getByTestId("play-button")).toHaveAttribute(
388
+ "data-hovered",
389
+ "false"
390
+ );
391
+ });
392
+
393
+ it("does not render video section when videoLink.link is empty", () => {
394
+ const { container } = render(
395
+ <ImagePromoBar
396
+ {...defaultProps}
397
+ videoLink={{ link: "", image: "thumb.jpg" }}
398
+ />
399
+ );
400
+ expect(container.querySelector(".video-section")).not.toBeInTheDocument();
401
+ });
402
+
403
+ it("does not render video preview image when videoLink.image is missing", () => {
404
+ render(
405
+ <ImagePromoBar
406
+ {...defaultProps}
407
+ videoLink={{ link: "https://youtube.com/watch?v=123" }}
408
+ />
409
+ );
410
+ expect(screen.queryByAltText("Video preview")).not.toBeInTheDocument();
411
+ });
412
+
413
+ it("handles videoLink being undefined", () => {
414
+ const { container } = render(
415
+ <ImagePromoBar {...defaultProps} videoLink={undefined as any} />
416
+ );
417
+ expect(container.querySelector(".video-section")).not.toBeInTheDocument();
418
+ });
419
+
420
+ it("handles videoLink with no videoPopup property (defaults to false)", () => {
421
+ const { container } = render(
422
+ <ImagePromoBar
423
+ {...defaultProps}
424
+ videoLink={{
425
+ link: "https://youtube.com/watch?v=123",
426
+ image: "thumb.jpg",
427
+ }}
428
+ />
429
+ );
430
+ fireEvent.click(container.querySelector(".video-section")!);
431
+ // Should show inline embed, not popup
432
+ expect(container.querySelector(".fixed")).not.toBeInTheDocument();
433
+ expect(screen.getByTestId("youtube-embed")).toBeInTheDocument();
434
+ });
435
+
436
+ it("does not render inline embed when videoPopup is true", () => {
437
+ const { container } = render(
438
+ <ImagePromoBar
439
+ {...defaultProps}
440
+ videoLink={{
441
+ link: "https://youtube.com/watch?v=123",
442
+ image: "thumb.jpg",
443
+ videoPopup: true,
444
+ }}
445
+ />
446
+ );
447
+ fireEvent.click(container.querySelector(".video-section")!);
448
+ // Popup renders, inline section hidden via the !videoPopup && isPlaying condition
449
+ expect(container.querySelector(".fixed")).toBeInTheDocument();
450
+ });
451
+
452
+ it("does not render contentVideo embed when videoLink has no image", () => {
453
+ const { container } = render(
454
+ <ImagePromoBar
455
+ {...defaultProps}
456
+ videoLink={{
457
+ link: "https://youtube.com/watch?v=123",
458
+ videoPopup: false,
459
+ }}
460
+ />
461
+ );
462
+ fireEvent.click(container.querySelector(".video-section")!);
463
+ // contentVideo is null when videoImage is falsy
464
+ expect(screen.queryByTestId("youtube-embed")).not.toBeInTheDocument();
465
+ });
466
+ });
467
+ });