@zap-wunschlachen/wl-shared-components 1.0.34 → 1.0.37
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.
- package/.github/workflows/playwright.yml +205 -205
- package/.github/workflows/static.yml +61 -61
- package/.github/workflows/update-snapshots.yml +37 -37
- package/.prettierrc +5 -5
- package/.storybook/main.ts +18 -18
- package/.storybook/preview.ts +37 -37
- package/.storybook/storyWrapper.vue +18 -18
- package/.storybook/withVuetifyTheme.decorator.ts +21 -21
- package/App.vue +43 -41
- package/README.md +56 -56
- package/heroicons.ts +75 -75
- package/index.html +19 -19
- package/package.json +67 -67
- package/playwright.config.ts +48 -48
- package/public/audio/test.aac +0 -0
- package/public/background.svg +60 -60
- package/public/style.css +187 -187
- package/public/technologies.svg +22 -22
- package/src/assets/css/base.css +232 -232
- package/src/assets/css/variables.css +109 -109
- package/src/components/Accordion/Accordion.css +59 -59
- package/src/components/Accordion/AccordionGroup.vue +51 -51
- package/src/components/Accordion/AccordionItem.vue +66 -66
- package/src/components/Appointment/Card/Actions.css +54 -54
- package/src/components/Appointment/Card/Actions.vue +99 -99
- package/src/components/Appointment/Card/AnamneseNotification.css +15 -15
- package/src/components/Appointment/Card/AnamneseNotification.vue +23 -23
- package/src/components/Appointment/Card/Card.css +80 -80
- package/src/components/Appointment/Card/Card.vue +93 -93
- package/src/components/Appointment/Card/Details.css +50 -50
- package/src/components/Appointment/Card/Details.vue +43 -43
- package/src/components/Audio/Audio.vue +187 -187
- package/src/components/Audio/Waveform.vue +118 -117
- package/src/components/Button/Button.vue +174 -136
- package/src/components/CheckBox/CheckBox.css +214 -185
- package/src/components/CheckBox/Checkbox.vue +138 -130
- package/src/components/DateInput/DateInput.css +2 -2
- package/src/components/DateInput/DateInput.vue +262 -262
- package/src/components/Dialog/Dialog.css +6 -6
- package/src/components/Dialog/Dialog.vue +38 -29
- package/src/components/EditField/EditField.css +19 -19
- package/src/components/EditField/EditField.vue +202 -202
- package/src/components/ErrorPage/ErrorPage.css +172 -172
- package/src/components/IconBullet/IconBullet.vue +86 -86
- package/src/components/IconBullet/IconBulletList.vue +41 -41
- package/src/components/Icons/AdvanceAppointments.vue +153 -153
- package/src/components/Icons/Audio/CloudFailed.vue +20 -20
- package/src/components/Icons/Audio/CloudSaved.vue +21 -21
- package/src/components/Icons/Audio/Delete.vue +15 -15
- package/src/components/Icons/Audio/Pause.vue +18 -18
- package/src/components/Icons/Audio/Play.vue +15 -15
- package/src/components/Icons/CalendarNotification.vue +126 -126
- package/src/components/Icons/Chair.vue +32 -32
- package/src/components/Icons/ChairNotification.vue +35 -35
- package/src/components/Icons/Circle.vue +66 -66
- package/src/components/Icons/FavIcon.vue +22 -22
- package/src/components/Icons/FilledCircle.vue +11 -11
- package/src/components/Icons/Group3.vue +46 -46
- package/src/components/Icons/RingNotification.vue +54 -54
- package/src/components/Icons/SolidArrowRight.vue +14 -14
- package/src/components/Icons/calendar.vue +17 -17
- package/src/components/Icons/checkbox.vue +19 -19
- package/src/components/Icons/outlineChecked.vue +27 -27
- package/src/components/Icons/play.vue +5 -5
- package/src/components/Input/Input.css +187 -187
- package/src/components/Input/Input.vue +253 -247
- package/src/components/Laboratory/AppointmentCard/AppointmentCard.css +7 -7
- package/src/components/Laboratory/AppointmentCard/AppointmentCard.vue +116 -116
- package/src/components/Laboratory/ChatBoxImage/ChatBoxImage.vue +81 -81
- package/src/components/Laboratory/ChatMessage/ChatMessage.vue +113 -113
- package/src/components/Laboratory/ChatMessage/ChatMessageBadge.css +4 -4
- package/src/components/Laboratory/ChatMessage/ChatMessageBadge.vue +99 -99
- package/src/components/Laboratory/ChatNotification/ChatNotification.vue +130 -130
- package/src/components/Laboratory/DocumentCard/DocumentCard.css +3 -3
- package/src/components/Laboratory/DocumentCard/DocumentCard.vue +50 -50
- package/src/components/Laboratory/DocumentCard/DocumentCardItem.vue +53 -53
- package/src/components/Laboratory/InfoCard/InfoCard.vue +162 -162
- package/src/components/Laboratory/MainColumnsBar/MainColumnsBar.vue +102 -102
- package/src/components/Laboratory/ProgressCircle/ProgressCircle.vue +152 -152
- package/src/components/Laboratory/ProgressLinear/ProgressLinear.css +33 -33
- package/src/components/Laboratory/ProgressLinear/ProgressLinear.vue +75 -75
- package/src/components/Laboratory/SelectionColumnBar/SelectionColumnBar.vue +92 -92
- package/src/components/Laboratory/StatusNotification/StatusNotification.vue +49 -49
- package/src/components/Laboratory/TagLabel/TagLabel.vue +126 -126
- package/src/components/Laboratory/TagLabelGroup/TagLabelGroup.vue +97 -97
- package/src/components/Laboratory/TicketCard/TicketCard.css +3 -3
- package/src/components/Laboratory/TicketCard/TicketCard.vue +143 -143
- package/src/components/Laboratory/TimeLine/TimeLineEvent.css +18 -18
- package/src/components/Laboratory/TimeLine/TimeLineEvent.vue +119 -119
- package/src/components/Laboratory/TimeLine/Timeline.css +4 -4
- package/src/components/Laboratory/TimeLine/Timeline.vue +30 -30
- package/src/components/Loader/Loader.css +71 -51
- package/src/components/Loader/Loader.vue +1 -0
- package/src/components/MaintenanceBanner/MaintenanceBanner.css +353 -353
- package/src/components/MaintenanceBanner/MaintenanceBanner.vue +127 -127
- package/src/components/MaintenanceBanner/MaintenanceIllustration.vue +54 -54
- package/src/components/Modal/Modal.css +5 -5
- package/src/components/Modal/Modal.vue +22 -22
- package/src/components/NotificationBubble/NotificationBubble.css +4 -4
- package/src/components/NotificationBubble/NotificationBubble.vue +90 -90
- package/src/components/OtpInput/OtpInput.css +39 -39
- package/src/components/OtpInput/OtpInput.vue +151 -151
- package/src/components/PhoneInput/PhoneInput.css +31 -31
- package/src/components/PhoneInput/PhoneInput.vue +113 -113
- package/src/components/Select/Select.css +150 -150
- package/src/components/Select/Select.vue +316 -315
- package/src/components/TextArea/TextArea.css +3 -3
- package/src/components/TextArea/TextArea.vue +126 -126
- package/src/components/TickBox/TickBox.css +49 -49
- package/src/components/TickBox/TickBox.vue +126 -126
- package/src/components/accessibility.css +218 -0
- package/src/components/index.ts +28 -28
- package/src/constants/iconEnums.ts +3 -3
- package/src/i18n/i18n.ts +15 -15
- package/src/i18n/locales/de.json +30 -30
- package/src/i18n/locales/en.json +30 -30
- package/src/index.ts +34 -34
- package/src/main.ts +11 -11
- package/src/plugins/vuetify.ts +141 -141
- package/src/shims-vue.d.ts +10 -10
- package/src/stories/Accordion.stories.ts +650 -650
- package/src/stories/Audio.stories.ts +28 -28
- package/src/stories/Button.stories.ts +263 -263
- package/src/stories/CheckBox.stories.ts +348 -348
- package/src/stories/DateInput.stories.ts +53 -53
- package/src/stories/Dialog.stories.ts +147 -147
- package/src/stories/EditField.stories.ts +78 -78
- package/src/stories/IconBullet/IconBullet.stories.ts +201 -201
- package/src/stories/IconBullet/IconBulletList.stories.ts +275 -275
- package/src/stories/Input.stories.ts +351 -351
- package/src/stories/Laboratory/Cards/AppointmentCard/AppointmentCard.stories.ts +260 -260
- package/src/stories/Laboratory/Cards/DocumentCard/DocumentCard.stories.ts +176 -176
- package/src/stories/Laboratory/Cards/DocumentCard/DocumentCardItem.stories.ts +119 -119
- package/src/stories/Laboratory/Cards/InfoCard/InfoCard.stories.ts +320 -320
- package/src/stories/Laboratory/Cards/TicketCard/TicketCard.stories.ts +335 -335
- package/src/stories/Laboratory/Chat/ChatBoxImage.stories.ts +82 -82
- package/src/stories/Laboratory/Chat/ChatMessage.stories.ts +198 -198
- package/src/stories/Laboratory/Chat/ChatMessageBadge.stories.ts +204 -204
- package/src/stories/Laboratory/Chat/ChatNotification.stories.ts +144 -144
- package/src/stories/Laboratory/Chat/ProgressLinear.stories.ts +186 -186
- package/src/stories/Laboratory/Chat/StatusNotification.stories.ts +111 -111
- package/src/stories/Laboratory/MainColumnsBar.stories.ts +48 -48
- package/src/stories/Laboratory/ProgressCircle.stories.ts +261 -261
- package/src/stories/Laboratory/SelectionColumnBar.stories.ts +234 -234
- package/src/stories/Laboratory/TagLabel.stories.ts +418 -418
- package/src/stories/Laboratory/TagLabelGroup.stories.ts +234 -234
- package/src/stories/Laboratory/Timeline.stories.ts +403 -403
- package/src/stories/NotificationBubble.stories.ts +194 -194
- package/src/stories/OtpInput.stories.ts +100 -100
- package/src/stories/PhoneInput.stories.ts +52 -52
- package/src/stories/Select.stories.ts +419 -419
- package/src/stories/TextArea.stories.ts +112 -112
- package/src/stories/TickBox.stories.ts +294 -294
- package/src/stories/v-icon.stories.ts +91 -91
- package/src/utils/index.ts +109 -109
- package/src/vite-env.d.ts +1 -1
- package/tests/e2e/README.md +220 -220
- package/tests/e2e/accessibility.spec.ts +638 -638
- package/tests/e2e/accordion.spec.ts +42 -42
- package/tests/e2e/additional-components.spec.ts +437 -437
- package/tests/e2e/all-components.spec.ts +135 -135
- package/tests/e2e/appointment-card.spec.ts +816 -816
- package/tests/e2e/button-fixed.spec.ts +58 -58
- package/tests/e2e/button.spec.ts +76 -76
- package/tests/e2e/checkbox.spec.ts +50 -50
- package/tests/e2e/date-input.spec.ts +46 -46
- package/tests/e2e/debug.spec.ts +51 -51
- package/tests/e2e/dialog.spec.ts +58 -58
- package/tests/e2e/input.spec.ts +55 -55
- package/tests/e2e/laboratory-components.spec.ts +320 -320
- package/tests/e2e/otp-input.spec.ts +50 -50
- package/tests/e2e/select.spec.ts +52 -52
- package/tests/e2e/storybook-utils.ts +59 -59
- package/tests/e2e/test-basic.spec.ts +33 -33
- package/tests/e2e/visual-regression.spec.ts +350 -350
- package/tests/unit/accessibility/component-a11y.spec.ts +469 -0
- package/tests/unit/components/Accordion/AccordionGroup.spec.ts +228 -0
- package/tests/unit/components/Accordion/AccordionGroup.spec.ts.skip +342 -342
- package/tests/unit/components/Accordion/AccordionItem.spec.ts +292 -0
- package/tests/unit/components/Accordion/AccordionItem.spec.ts.skip +383 -383
- package/tests/unit/components/Appointment/AnamneseNotification.spec.ts +176 -0
- package/tests/unit/components/Appointment/Card/Actions.spec.ts +407 -407
- package/tests/unit/components/Appointment/Card/Card.spec.ts +485 -485
- package/tests/unit/components/Appointment/Card/Details.spec.ts +397 -397
- package/tests/unit/components/Audio/Audio.spec.ts +403 -403
- package/tests/unit/components/Audio/Waveform.spec.ts +483 -483
- package/tests/unit/components/Background/Background.spec.ts +177 -0
- package/tests/unit/components/Core/Button.spec.ts +336 -336
- package/tests/unit/components/Core/Checkbox.spec.ts +544 -544
- package/tests/unit/components/Core/DateInput.spec.ts +690 -690
- package/tests/unit/components/Core/Dialog.spec.ts +485 -485
- package/tests/unit/components/Core/EditField.spec.ts +782 -782
- package/tests/unit/components/Core/Input.spec.ts +512 -512
- package/tests/unit/components/Core/Modal.spec.ts +518 -518
- package/tests/unit/components/Core/NotificationBubble.spec.ts +606 -606
- package/tests/unit/components/Core/OtpInput.spec.ts +708 -708
- package/tests/unit/components/Core/PhoneInput.spec.ts +619 -619
- package/tests/unit/components/Core/Select.spec.ts +712 -712
- package/tests/unit/components/Core/TextArea.spec.ts +565 -565
- package/tests/unit/components/Core/TickBox.spec.ts +779 -779
- package/tests/unit/components/ErrorPage/ErrorPage.spec.ts +313 -0
- package/tests/unit/components/ErrorPage/ErrorPageLogo.spec.ts +153 -0
- package/tests/unit/components/IconBullet/IconBullet.spec.ts +356 -356
- package/tests/unit/components/IconBullet/IconBulletList.spec.ts +371 -371
- package/tests/unit/components/Icons/AdvanceAppointments.spec.ts +61 -0
- package/tests/unit/components/Icons/Audio/CloudFailed.spec.ts +108 -108
- package/tests/unit/components/Icons/Audio/CloudSaved.spec.ts +149 -149
- package/tests/unit/components/Icons/Audio/Delete.spec.ts +158 -158
- package/tests/unit/components/Icons/Audio/Pause.spec.ts +208 -208
- package/tests/unit/components/Icons/Audio/Play.spec.ts +217 -217
- package/tests/unit/components/Icons/CalendarNotification.spec.ts +186 -186
- package/tests/unit/components/Icons/Chair.spec.ts +234 -234
- package/tests/unit/components/Icons/ChairNotification.spec.ts +311 -311
- package/tests/unit/components/Icons/Circle.spec.ts +255 -255
- package/tests/unit/components/Icons/FavIcon.spec.ts +251 -251
- package/tests/unit/components/Icons/FilledCircle.spec.ts +274 -274
- package/tests/unit/components/Icons/Group3.spec.ts +355 -355
- package/tests/unit/components/Icons/Logo.spec.ts +228 -0
- package/tests/unit/components/Icons/MiniLogo.spec.ts +38 -0
- package/tests/unit/components/Icons/RingNotification.spec.ts +393 -393
- package/tests/unit/components/Icons/SolidArrowRight.spec.ts +49 -0
- package/tests/unit/components/Icons/calendar.spec.ts +286 -286
- package/tests/unit/components/Icons/checkbox.spec.ts +315 -315
- package/tests/unit/components/Icons/outlineChecked.spec.ts +434 -434
- package/tests/unit/components/Icons/play.spec.ts +308 -308
- package/tests/unit/components/Laboratory/AppointmentCard.spec.ts +167 -167
- package/tests/unit/components/Laboratory/ChatBoxImage.spec.ts +179 -179
- package/tests/unit/components/Laboratory/ChatMessage.spec.ts +263 -263
- package/tests/unit/components/Laboratory/ChatMessageBadge.spec.ts +282 -282
- package/tests/unit/components/Laboratory/ChatNotification.spec.ts +256 -256
- package/tests/unit/components/Laboratory/DocumentCard.spec.ts +228 -228
- package/tests/unit/components/Laboratory/DocumentCardItem.spec.ts +236 -236
- package/tests/unit/components/Laboratory/InfoCard.spec.ts +308 -308
- package/tests/unit/components/Laboratory/MainColumnsBar.spec.ts +251 -251
- package/tests/unit/components/Laboratory/ProgressCircle.spec.ts +290 -290
- package/tests/unit/components/Laboratory/ProgressLinear.spec.ts +275 -275
- package/tests/unit/components/Laboratory/SelectionColumnBar.spec.ts +288 -288
- package/tests/unit/components/Laboratory/StatusNotification.spec.ts +296 -296
- package/tests/unit/components/Laboratory/TagLabel.spec.ts +353 -353
- package/tests/unit/components/Laboratory/TagLabelGroup.spec.ts +377 -377
- package/tests/unit/components/Laboratory/TicketCard.spec.ts +351 -351
- package/tests/unit/components/Laboratory/TimeLineEvent.spec.ts +381 -381
- package/tests/unit/components/Laboratory/Timeline.spec.ts +419 -419
- package/tests/unit/components/Loader/Loader.spec.ts +197 -0
- package/tests/unit/components/MaintenanceBanner/MaintenanceBanner.spec.ts +302 -0
- package/tests/unit/constants/iconEnums.spec.ts +39 -39
- package/tests/unit/i18n/i18n.spec.ts +88 -88
- package/tests/unit/plugins/vuetify.spec.ts +220 -220
- package/tests/unit/setup.ts +189 -189
- package/tests/unit/src/components/index.spec.ts.skip +192 -192
- package/tests/unit/src/index.spec.ts.skip +182 -182
- package/tests/unit/src/main.spec.ts +151 -151
- package/tests/unit/utils/accessibility.spec.ts +318 -0
- package/tsconfig.json +26 -26
- package/vite.config.ts +29 -29
- package/vitest.config.ts +83 -83
|
@@ -1,357 +1,357 @@
|
|
|
1
|
-
import { describe, it, expect, beforeEach } from 'vitest';
|
|
2
|
-
import { mount, VueWrapper } from '@vue/test-utils';
|
|
3
|
-
import IconBullet from '@components/IconBullet/IconBullet.vue';
|
|
4
|
-
|
|
5
|
-
describe('IconBullet', () => {
|
|
6
|
-
let wrapper: VueWrapper;
|
|
7
|
-
|
|
8
|
-
const defaultProps = {
|
|
9
|
-
header: 'Test Header',
|
|
10
|
-
subHeader: 'Test Sub Header'
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
beforeEach(() => {
|
|
14
|
-
wrapper = mount(IconBullet, {
|
|
15
|
-
props: defaultProps,
|
|
16
|
-
global: {
|
|
17
|
-
stubs: {
|
|
18
|
-
'v-icon': {
|
|
19
|
-
template: '<i class="v-icon" :icon="icon" :size="size">{{ icon }}</i>',
|
|
20
|
-
props: ['icon', 'size']
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
});
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
describe('Component Rendering', () => {
|
|
28
|
-
it('renders the component with root element', () => {
|
|
29
|
-
expect(wrapper.find('[data-testid="root"]').exists()).toBe(true);
|
|
30
|
-
expect(wrapper.find('.container').exists()).toBe(true);
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
it('has correct container classes', () => {
|
|
34
|
-
const container = wrapper.find('.container');
|
|
35
|
-
expect(container.classes()).toContain('d-flex');
|
|
36
|
-
expect(container.classes()).toContain('align-center');
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
it('renders icon container', () => {
|
|
40
|
-
const iconContainer = wrapper.find('.icon-container');
|
|
41
|
-
expect(iconContainer.exists()).toBe(true);
|
|
42
|
-
expect(iconContainer.classes()).toContain('d-flex');
|
|
43
|
-
expect(iconContainer.classes()).toContain('align-start');
|
|
44
|
-
});
|
|
45
|
-
|
|
46
|
-
it('renders text container', () => {
|
|
47
|
-
const textContainer = wrapper.find('.text-container');
|
|
48
|
-
expect(textContainer.exists()).toBe(true);
|
|
49
|
-
expect(textContainer.classes()).toContain('d-flex');
|
|
50
|
-
expect(textContainer.classes()).toContain('flex-column');
|
|
51
|
-
});
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
describe('Header and SubHeader', () => {
|
|
55
|
-
it('displays header when provided', () => {
|
|
56
|
-
const header = wrapper.find('h3');
|
|
57
|
-
expect(header.exists()).toBe(true);
|
|
58
|
-
expect(header.text()).toBe('Test Header');
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
it('displays subHeader when provided', () => {
|
|
62
|
-
const subHeader = wrapper.find('p.p-large');
|
|
63
|
-
expect(subHeader.exists()).toBe(true);
|
|
64
|
-
expect(subHeader.text()).toBe('Test Sub Header');
|
|
65
|
-
});
|
|
66
|
-
|
|
67
|
-
it('does not display header when not provided', () => {
|
|
68
|
-
const wrapper = mount(IconBullet, {
|
|
69
|
-
props: { subHeader: 'Only sub' }
|
|
70
|
-
});
|
|
71
|
-
expect(wrapper.find('h3').exists()).toBe(false);
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
it('does not display subHeader when not provided', () => {
|
|
75
|
-
const wrapper = mount(IconBullet, {
|
|
76
|
-
props: { header: 'Only header' }
|
|
77
|
-
});
|
|
78
|
-
expect(wrapper.find('p.p-large').exists()).toBe(false);
|
|
79
|
-
});
|
|
80
|
-
|
|
81
|
-
it('handles both header and subHeader missing', () => {
|
|
82
|
-
const wrapper = mount(IconBullet);
|
|
83
|
-
expect(wrapper.find('h3').exists()).toBe(false);
|
|
84
|
-
expect(wrapper.find('p.p-large').exists()).toBe(false);
|
|
85
|
-
});
|
|
86
|
-
});
|
|
87
|
-
|
|
88
|
-
describe('Content Property', () => {
|
|
89
|
-
it('displays HTML content when provided', () => {
|
|
90
|
-
const wrapper = mount(IconBullet, {
|
|
91
|
-
props: {
|
|
92
|
-
content: '<p>Custom HTML Content</p>'
|
|
93
|
-
}
|
|
94
|
-
});
|
|
95
|
-
|
|
96
|
-
const contentDiv = wrapper.find('.text-container > div');
|
|
97
|
-
expect(contentDiv.html()).toContain('<p>Custom HTML Content</p>');
|
|
98
|
-
});
|
|
99
|
-
|
|
100
|
-
it('prioritizes content over header and subHeader', () => {
|
|
101
|
-
const wrapper = mount(IconBullet, {
|
|
102
|
-
props: {
|
|
103
|
-
content: '<p>Content</p>',
|
|
104
|
-
header: 'Header',
|
|
105
|
-
subHeader: 'SubHeader'
|
|
106
|
-
}
|
|
107
|
-
});
|
|
108
|
-
|
|
109
|
-
expect(wrapper.find('h3').exists()).toBe(false);
|
|
110
|
-
expect(wrapper.find('p.p-large').exists()).toBe(false);
|
|
111
|
-
expect(wrapper.html()).toContain('<p>Content</p>');
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
it('renders complex HTML content', () => {
|
|
115
|
-
const wrapper = mount(IconBullet, {
|
|
116
|
-
props: {
|
|
117
|
-
content: '<div><h4>Title</h4><ul><li>Item 1</li><li>Item 2</li></ul></div>'
|
|
118
|
-
}
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
const contentDiv = wrapper.find('.text-container > div');
|
|
122
|
-
expect(contentDiv.html()).toContain('<h4>Title</h4>');
|
|
123
|
-
expect(contentDiv.html()).toContain('<li>Item 1</li>');
|
|
124
|
-
expect(contentDiv.html()).toContain('<li>Item 2</li>');
|
|
125
|
-
});
|
|
126
|
-
});
|
|
127
|
-
|
|
128
|
-
describe('Icon Prop', () => {
|
|
129
|
-
it('renders icon when provided', () => {
|
|
130
|
-
const wrapper = mount(IconBullet, {
|
|
131
|
-
props: {
|
|
132
|
-
icon: 'mdi-home'
|
|
133
|
-
},
|
|
134
|
-
global: {
|
|
135
|
-
stubs: {
|
|
136
|
-
'v-icon': {
|
|
137
|
-
template: '<i class="v-icon" :icon="icon" :size="size">{{ icon }}</i>',
|
|
138
|
-
props: ['icon', 'size']
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
});
|
|
143
|
-
|
|
144
|
-
const icon = wrapper.find('.v-icon');
|
|
145
|
-
expect(icon.exists()).toBe(true);
|
|
146
|
-
expect(icon.text()).toBe('mdi-home');
|
|
147
|
-
});
|
|
148
|
-
|
|
149
|
-
it('does not render icon when not provided', () => {
|
|
150
|
-
const wrapper = mount(IconBullet, {
|
|
151
|
-
global: {
|
|
152
|
-
stubs: {
|
|
153
|
-
'v-icon': {
|
|
154
|
-
template: '<i class="v-icon" :icon="icon" :size="size">{{ icon }}</i>',
|
|
155
|
-
props: ['icon', 'size']
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
});
|
|
160
|
-
|
|
161
|
-
const icon = wrapper.find('.v-icon');
|
|
162
|
-
expect(icon.exists()).toBe(false);
|
|
163
|
-
});
|
|
164
|
-
|
|
165
|
-
it('uses default icon size', () => {
|
|
166
|
-
const wrapper = mount(IconBullet, {
|
|
167
|
-
props: {
|
|
168
|
-
icon: 'mdi-home'
|
|
169
|
-
},
|
|
170
|
-
global: {
|
|
171
|
-
stubs: {
|
|
172
|
-
'v-icon': {
|
|
173
|
-
template: '<i class="v-icon" :icon="icon" :size="size">{{ icon }}</i>',
|
|
174
|
-
props: ['icon', 'size']
|
|
175
|
-
}
|
|
176
|
-
}
|
|
177
|
-
}
|
|
178
|
-
});
|
|
179
|
-
|
|
180
|
-
const icon = wrapper.find('.v-icon');
|
|
181
|
-
expect(icon.attributes('size')).toBe('38');
|
|
182
|
-
});
|
|
183
|
-
|
|
184
|
-
it('uses custom icon size when provided', () => {
|
|
185
|
-
const wrapper = mount(IconBullet, {
|
|
186
|
-
props: {
|
|
187
|
-
icon: 'mdi-home',
|
|
188
|
-
iconSize: '24'
|
|
189
|
-
},
|
|
190
|
-
global: {
|
|
191
|
-
stubs: {
|
|
192
|
-
'v-icon': {
|
|
193
|
-
template: '<i class="v-icon" :icon="icon" :size="size">{{ icon }}</i>',
|
|
194
|
-
props: ['icon', 'size']
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
});
|
|
199
|
-
|
|
200
|
-
const icon = wrapper.find('.v-icon');
|
|
201
|
-
expect(icon.attributes('size')).toBe('24');
|
|
202
|
-
});
|
|
203
|
-
});
|
|
204
|
-
|
|
205
|
-
describe('Icon Slot', () => {
|
|
206
|
-
it('renders icon slot content when provided', () => {
|
|
207
|
-
const wrapper = mount(IconBullet, {
|
|
208
|
-
slots: {
|
|
209
|
-
icon: '<div class="custom-icon">Custom Icon</div>'
|
|
210
|
-
}
|
|
211
|
-
});
|
|
212
|
-
|
|
213
|
-
expect(wrapper.find('.custom-icon').exists()).toBe(true);
|
|
214
|
-
expect(wrapper.find('.custom-icon').text()).toBe('Custom Icon');
|
|
215
|
-
});
|
|
216
|
-
|
|
217
|
-
it('prioritizes icon slot over icon prop', () => {
|
|
218
|
-
const wrapper = mount(IconBullet, {
|
|
219
|
-
props: {
|
|
220
|
-
icon: 'mdi-home'
|
|
221
|
-
},
|
|
222
|
-
slots: {
|
|
223
|
-
icon: '<div class="custom-icon">Slot Icon</div>'
|
|
224
|
-
},
|
|
225
|
-
global: {
|
|
226
|
-
stubs: {
|
|
227
|
-
'v-icon': {
|
|
228
|
-
template: '<i class="v-icon" :icon="icon" :size="size">{{ icon }}</i>',
|
|
229
|
-
props: ['icon', 'size']
|
|
230
|
-
}
|
|
231
|
-
}
|
|
232
|
-
}
|
|
233
|
-
});
|
|
234
|
-
|
|
235
|
-
expect(wrapper.find('.custom-icon').exists()).toBe(true);
|
|
236
|
-
expect(wrapper.find('.v-icon').exists()).toBe(false);
|
|
237
|
-
});
|
|
238
|
-
|
|
239
|
-
it('renders complex icon slot content', () => {
|
|
240
|
-
const wrapper = mount(IconBullet, {
|
|
241
|
-
slots: {
|
|
242
|
-
icon: '<svg width="24" height="24"><circle cx="12" cy="12" r="10" /></svg>'
|
|
243
|
-
}
|
|
244
|
-
});
|
|
245
|
-
|
|
246
|
-
expect(wrapper.find('svg').exists()).toBe(true);
|
|
247
|
-
expect(wrapper.find('circle').exists()).toBe(true);
|
|
248
|
-
});
|
|
249
|
-
});
|
|
250
|
-
|
|
251
|
-
describe('Layout and Styling', () => {
|
|
252
|
-
it('applies correct gap to container', () => {
|
|
253
|
-
// Component has gap: 24px in styles
|
|
254
|
-
const container = wrapper.find('.container');
|
|
255
|
-
expect(container.exists()).toBe(true);
|
|
256
|
-
});
|
|
257
|
-
|
|
258
|
-
it('applies correct width constraints', () => {
|
|
259
|
-
// Component has width: 400px, min-width: 300px, max-width: 400px
|
|
260
|
-
const container = wrapper.find('.container');
|
|
261
|
-
expect(container.exists()).toBe(true);
|
|
262
|
-
});
|
|
263
|
-
|
|
264
|
-
it('applies correct padding', () => {
|
|
265
|
-
// Component has padding-left: 50px, padding-right: 40px
|
|
266
|
-
const container = wrapper.find('.container');
|
|
267
|
-
expect(container.exists()).toBe(true);
|
|
268
|
-
});
|
|
269
|
-
|
|
270
|
-
it('applies correct text container gap', () => {
|
|
271
|
-
// Component has gap: 11px for text-container
|
|
272
|
-
const textContainer = wrapper.find('.text-container');
|
|
273
|
-
expect(textContainer.exists()).toBe(true);
|
|
274
|
-
});
|
|
275
|
-
});
|
|
276
|
-
|
|
277
|
-
describe('Edge Cases', () => {
|
|
278
|
-
it('handles empty strings for all props', () => {
|
|
279
|
-
const wrapper = mount(IconBullet, {
|
|
280
|
-
props: {
|
|
281
|
-
header: '',
|
|
282
|
-
subHeader: '',
|
|
283
|
-
content: '',
|
|
284
|
-
icon: ''
|
|
285
|
-
}
|
|
286
|
-
});
|
|
287
|
-
|
|
288
|
-
expect(wrapper.find('h3').exists()).toBe(false);
|
|
289
|
-
expect(wrapper.find('p.p-large').exists()).toBe(false);
|
|
290
|
-
expect(wrapper.find('.v-icon').exists()).toBe(false);
|
|
291
|
-
});
|
|
292
|
-
|
|
293
|
-
it('handles special characters in header', () => {
|
|
294
|
-
const wrapper = mount(IconBullet, {
|
|
295
|
-
props: {
|
|
296
|
-
header: 'Header with <>&"\'',
|
|
297
|
-
subHeader: 'Sub with special @#$%'
|
|
298
|
-
}
|
|
299
|
-
});
|
|
300
|
-
|
|
301
|
-
expect(wrapper.find('h3').text()).toBe('Header with <>&"\'');
|
|
302
|
-
expect(wrapper.find('p.p-large').text()).toBe('Sub with special @#$%');
|
|
303
|
-
});
|
|
304
|
-
|
|
305
|
-
it('handles very long text content', () => {
|
|
306
|
-
const longText = 'a'.repeat(500);
|
|
307
|
-
const wrapper = mount(IconBullet, {
|
|
308
|
-
props: {
|
|
309
|
-
header: longText,
|
|
310
|
-
subHeader: longText
|
|
311
|
-
}
|
|
312
|
-
});
|
|
313
|
-
|
|
314
|
-
expect(wrapper.find('h3').text()).toHaveLength(500);
|
|
315
|
-
expect(wrapper.find('p.p-large').text()).toHaveLength(500);
|
|
316
|
-
});
|
|
317
|
-
});
|
|
318
|
-
|
|
319
|
-
describe('Component Integration', () => {
|
|
320
|
-
it('can be mounted without any props', () => {
|
|
321
|
-
expect(() => {
|
|
322
|
-
mount(IconBullet);
|
|
323
|
-
}).not.toThrow();
|
|
324
|
-
});
|
|
325
|
-
|
|
326
|
-
it('renders consistently on multiple mounts', () => {
|
|
327
|
-
const wrapper1 = mount(IconBullet, { props: defaultProps });
|
|
328
|
-
const wrapper2 = mount(IconBullet, { props: defaultProps });
|
|
329
|
-
|
|
330
|
-
expect(wrapper1.html()).toBe(wrapper2.html());
|
|
331
|
-
});
|
|
332
|
-
|
|
333
|
-
it('combines all features correctly', () => {
|
|
334
|
-
const wrapper = mount(IconBullet, {
|
|
335
|
-
props: {
|
|
336
|
-
header: 'Main Title',
|
|
337
|
-
subHeader: 'Subtitle',
|
|
338
|
-
icon: 'mdi-check',
|
|
339
|
-
iconSize: '48'
|
|
340
|
-
},
|
|
341
|
-
global: {
|
|
342
|
-
stubs: {
|
|
343
|
-
'v-icon': {
|
|
344
|
-
template: '<i class="v-icon" :icon="icon" :size="size">{{ icon }}</i>',
|
|
345
|
-
props: ['icon', 'size']
|
|
346
|
-
}
|
|
347
|
-
}
|
|
348
|
-
}
|
|
349
|
-
});
|
|
350
|
-
|
|
351
|
-
expect(wrapper.find('h3').text()).toBe('Main Title');
|
|
352
|
-
expect(wrapper.find('p.p-large').text()).toBe('Subtitle');
|
|
353
|
-
expect(wrapper.find('.v-icon').text()).toBe('mdi-check');
|
|
354
|
-
expect(wrapper.find('.v-icon').attributes('size')).toBe('48');
|
|
355
|
-
});
|
|
356
|
-
});
|
|
1
|
+
import { describe, it, expect, beforeEach } from 'vitest';
|
|
2
|
+
import { mount, VueWrapper } from '@vue/test-utils';
|
|
3
|
+
import IconBullet from '@components/IconBullet/IconBullet.vue';
|
|
4
|
+
|
|
5
|
+
describe('IconBullet', () => {
|
|
6
|
+
let wrapper: VueWrapper;
|
|
7
|
+
|
|
8
|
+
const defaultProps = {
|
|
9
|
+
header: 'Test Header',
|
|
10
|
+
subHeader: 'Test Sub Header'
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
beforeEach(() => {
|
|
14
|
+
wrapper = mount(IconBullet, {
|
|
15
|
+
props: defaultProps,
|
|
16
|
+
global: {
|
|
17
|
+
stubs: {
|
|
18
|
+
'v-icon': {
|
|
19
|
+
template: '<i class="v-icon" :icon="icon" :size="size">{{ icon }}</i>',
|
|
20
|
+
props: ['icon', 'size']
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
describe('Component Rendering', () => {
|
|
28
|
+
it('renders the component with root element', () => {
|
|
29
|
+
expect(wrapper.find('[data-testid="root"]').exists()).toBe(true);
|
|
30
|
+
expect(wrapper.find('.container').exists()).toBe(true);
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
it('has correct container classes', () => {
|
|
34
|
+
const container = wrapper.find('.container');
|
|
35
|
+
expect(container.classes()).toContain('d-flex');
|
|
36
|
+
expect(container.classes()).toContain('align-center');
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
it('renders icon container', () => {
|
|
40
|
+
const iconContainer = wrapper.find('.icon-container');
|
|
41
|
+
expect(iconContainer.exists()).toBe(true);
|
|
42
|
+
expect(iconContainer.classes()).toContain('d-flex');
|
|
43
|
+
expect(iconContainer.classes()).toContain('align-start');
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
it('renders text container', () => {
|
|
47
|
+
const textContainer = wrapper.find('.text-container');
|
|
48
|
+
expect(textContainer.exists()).toBe(true);
|
|
49
|
+
expect(textContainer.classes()).toContain('d-flex');
|
|
50
|
+
expect(textContainer.classes()).toContain('flex-column');
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
describe('Header and SubHeader', () => {
|
|
55
|
+
it('displays header when provided', () => {
|
|
56
|
+
const header = wrapper.find('h3');
|
|
57
|
+
expect(header.exists()).toBe(true);
|
|
58
|
+
expect(header.text()).toBe('Test Header');
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
it('displays subHeader when provided', () => {
|
|
62
|
+
const subHeader = wrapper.find('p.p-large');
|
|
63
|
+
expect(subHeader.exists()).toBe(true);
|
|
64
|
+
expect(subHeader.text()).toBe('Test Sub Header');
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
it('does not display header when not provided', () => {
|
|
68
|
+
const wrapper = mount(IconBullet, {
|
|
69
|
+
props: { subHeader: 'Only sub' }
|
|
70
|
+
});
|
|
71
|
+
expect(wrapper.find('h3').exists()).toBe(false);
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
it('does not display subHeader when not provided', () => {
|
|
75
|
+
const wrapper = mount(IconBullet, {
|
|
76
|
+
props: { header: 'Only header' }
|
|
77
|
+
});
|
|
78
|
+
expect(wrapper.find('p.p-large').exists()).toBe(false);
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
it('handles both header and subHeader missing', () => {
|
|
82
|
+
const wrapper = mount(IconBullet);
|
|
83
|
+
expect(wrapper.find('h3').exists()).toBe(false);
|
|
84
|
+
expect(wrapper.find('p.p-large').exists()).toBe(false);
|
|
85
|
+
});
|
|
86
|
+
});
|
|
87
|
+
|
|
88
|
+
describe('Content Property', () => {
|
|
89
|
+
it('displays HTML content when provided', () => {
|
|
90
|
+
const wrapper = mount(IconBullet, {
|
|
91
|
+
props: {
|
|
92
|
+
content: '<p>Custom HTML Content</p>'
|
|
93
|
+
}
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
const contentDiv = wrapper.find('.text-container > div');
|
|
97
|
+
expect(contentDiv.html()).toContain('<p>Custom HTML Content</p>');
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
it('prioritizes content over header and subHeader', () => {
|
|
101
|
+
const wrapper = mount(IconBullet, {
|
|
102
|
+
props: {
|
|
103
|
+
content: '<p>Content</p>',
|
|
104
|
+
header: 'Header',
|
|
105
|
+
subHeader: 'SubHeader'
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
|
|
109
|
+
expect(wrapper.find('h3').exists()).toBe(false);
|
|
110
|
+
expect(wrapper.find('p.p-large').exists()).toBe(false);
|
|
111
|
+
expect(wrapper.html()).toContain('<p>Content</p>');
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
it('renders complex HTML content', () => {
|
|
115
|
+
const wrapper = mount(IconBullet, {
|
|
116
|
+
props: {
|
|
117
|
+
content: '<div><h4>Title</h4><ul><li>Item 1</li><li>Item 2</li></ul></div>'
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
|
|
121
|
+
const contentDiv = wrapper.find('.text-container > div');
|
|
122
|
+
expect(contentDiv.html()).toContain('<h4>Title</h4>');
|
|
123
|
+
expect(contentDiv.html()).toContain('<li>Item 1</li>');
|
|
124
|
+
expect(contentDiv.html()).toContain('<li>Item 2</li>');
|
|
125
|
+
});
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
describe('Icon Prop', () => {
|
|
129
|
+
it('renders icon when provided', () => {
|
|
130
|
+
const wrapper = mount(IconBullet, {
|
|
131
|
+
props: {
|
|
132
|
+
icon: 'mdi-home'
|
|
133
|
+
},
|
|
134
|
+
global: {
|
|
135
|
+
stubs: {
|
|
136
|
+
'v-icon': {
|
|
137
|
+
template: '<i class="v-icon" :icon="icon" :size="size">{{ icon }}</i>',
|
|
138
|
+
props: ['icon', 'size']
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
});
|
|
143
|
+
|
|
144
|
+
const icon = wrapper.find('.v-icon');
|
|
145
|
+
expect(icon.exists()).toBe(true);
|
|
146
|
+
expect(icon.text()).toBe('mdi-home');
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
it('does not render icon when not provided', () => {
|
|
150
|
+
const wrapper = mount(IconBullet, {
|
|
151
|
+
global: {
|
|
152
|
+
stubs: {
|
|
153
|
+
'v-icon': {
|
|
154
|
+
template: '<i class="v-icon" :icon="icon" :size="size">{{ icon }}</i>',
|
|
155
|
+
props: ['icon', 'size']
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
});
|
|
160
|
+
|
|
161
|
+
const icon = wrapper.find('.v-icon');
|
|
162
|
+
expect(icon.exists()).toBe(false);
|
|
163
|
+
});
|
|
164
|
+
|
|
165
|
+
it('uses default icon size', () => {
|
|
166
|
+
const wrapper = mount(IconBullet, {
|
|
167
|
+
props: {
|
|
168
|
+
icon: 'mdi-home'
|
|
169
|
+
},
|
|
170
|
+
global: {
|
|
171
|
+
stubs: {
|
|
172
|
+
'v-icon': {
|
|
173
|
+
template: '<i class="v-icon" :icon="icon" :size="size">{{ icon }}</i>',
|
|
174
|
+
props: ['icon', 'size']
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
});
|
|
179
|
+
|
|
180
|
+
const icon = wrapper.find('.v-icon');
|
|
181
|
+
expect(icon.attributes('size')).toBe('38');
|
|
182
|
+
});
|
|
183
|
+
|
|
184
|
+
it('uses custom icon size when provided', () => {
|
|
185
|
+
const wrapper = mount(IconBullet, {
|
|
186
|
+
props: {
|
|
187
|
+
icon: 'mdi-home',
|
|
188
|
+
iconSize: '24'
|
|
189
|
+
},
|
|
190
|
+
global: {
|
|
191
|
+
stubs: {
|
|
192
|
+
'v-icon': {
|
|
193
|
+
template: '<i class="v-icon" :icon="icon" :size="size">{{ icon }}</i>',
|
|
194
|
+
props: ['icon', 'size']
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
});
|
|
199
|
+
|
|
200
|
+
const icon = wrapper.find('.v-icon');
|
|
201
|
+
expect(icon.attributes('size')).toBe('24');
|
|
202
|
+
});
|
|
203
|
+
});
|
|
204
|
+
|
|
205
|
+
describe('Icon Slot', () => {
|
|
206
|
+
it('renders icon slot content when provided', () => {
|
|
207
|
+
const wrapper = mount(IconBullet, {
|
|
208
|
+
slots: {
|
|
209
|
+
icon: '<div class="custom-icon">Custom Icon</div>'
|
|
210
|
+
}
|
|
211
|
+
});
|
|
212
|
+
|
|
213
|
+
expect(wrapper.find('.custom-icon').exists()).toBe(true);
|
|
214
|
+
expect(wrapper.find('.custom-icon').text()).toBe('Custom Icon');
|
|
215
|
+
});
|
|
216
|
+
|
|
217
|
+
it('prioritizes icon slot over icon prop', () => {
|
|
218
|
+
const wrapper = mount(IconBullet, {
|
|
219
|
+
props: {
|
|
220
|
+
icon: 'mdi-home'
|
|
221
|
+
},
|
|
222
|
+
slots: {
|
|
223
|
+
icon: '<div class="custom-icon">Slot Icon</div>'
|
|
224
|
+
},
|
|
225
|
+
global: {
|
|
226
|
+
stubs: {
|
|
227
|
+
'v-icon': {
|
|
228
|
+
template: '<i class="v-icon" :icon="icon" :size="size">{{ icon }}</i>',
|
|
229
|
+
props: ['icon', 'size']
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
});
|
|
234
|
+
|
|
235
|
+
expect(wrapper.find('.custom-icon').exists()).toBe(true);
|
|
236
|
+
expect(wrapper.find('.v-icon').exists()).toBe(false);
|
|
237
|
+
});
|
|
238
|
+
|
|
239
|
+
it('renders complex icon slot content', () => {
|
|
240
|
+
const wrapper = mount(IconBullet, {
|
|
241
|
+
slots: {
|
|
242
|
+
icon: '<svg width="24" height="24"><circle cx="12" cy="12" r="10" /></svg>'
|
|
243
|
+
}
|
|
244
|
+
});
|
|
245
|
+
|
|
246
|
+
expect(wrapper.find('svg').exists()).toBe(true);
|
|
247
|
+
expect(wrapper.find('circle').exists()).toBe(true);
|
|
248
|
+
});
|
|
249
|
+
});
|
|
250
|
+
|
|
251
|
+
describe('Layout and Styling', () => {
|
|
252
|
+
it('applies correct gap to container', () => {
|
|
253
|
+
// Component has gap: 24px in styles
|
|
254
|
+
const container = wrapper.find('.container');
|
|
255
|
+
expect(container.exists()).toBe(true);
|
|
256
|
+
});
|
|
257
|
+
|
|
258
|
+
it('applies correct width constraints', () => {
|
|
259
|
+
// Component has width: 400px, min-width: 300px, max-width: 400px
|
|
260
|
+
const container = wrapper.find('.container');
|
|
261
|
+
expect(container.exists()).toBe(true);
|
|
262
|
+
});
|
|
263
|
+
|
|
264
|
+
it('applies correct padding', () => {
|
|
265
|
+
// Component has padding-left: 50px, padding-right: 40px
|
|
266
|
+
const container = wrapper.find('.container');
|
|
267
|
+
expect(container.exists()).toBe(true);
|
|
268
|
+
});
|
|
269
|
+
|
|
270
|
+
it('applies correct text container gap', () => {
|
|
271
|
+
// Component has gap: 11px for text-container
|
|
272
|
+
const textContainer = wrapper.find('.text-container');
|
|
273
|
+
expect(textContainer.exists()).toBe(true);
|
|
274
|
+
});
|
|
275
|
+
});
|
|
276
|
+
|
|
277
|
+
describe('Edge Cases', () => {
|
|
278
|
+
it('handles empty strings for all props', () => {
|
|
279
|
+
const wrapper = mount(IconBullet, {
|
|
280
|
+
props: {
|
|
281
|
+
header: '',
|
|
282
|
+
subHeader: '',
|
|
283
|
+
content: '',
|
|
284
|
+
icon: ''
|
|
285
|
+
}
|
|
286
|
+
});
|
|
287
|
+
|
|
288
|
+
expect(wrapper.find('h3').exists()).toBe(false);
|
|
289
|
+
expect(wrapper.find('p.p-large').exists()).toBe(false);
|
|
290
|
+
expect(wrapper.find('.v-icon').exists()).toBe(false);
|
|
291
|
+
});
|
|
292
|
+
|
|
293
|
+
it('handles special characters in header', () => {
|
|
294
|
+
const wrapper = mount(IconBullet, {
|
|
295
|
+
props: {
|
|
296
|
+
header: 'Header with <>&"\'',
|
|
297
|
+
subHeader: 'Sub with special @#$%'
|
|
298
|
+
}
|
|
299
|
+
});
|
|
300
|
+
|
|
301
|
+
expect(wrapper.find('h3').text()).toBe('Header with <>&"\'');
|
|
302
|
+
expect(wrapper.find('p.p-large').text()).toBe('Sub with special @#$%');
|
|
303
|
+
});
|
|
304
|
+
|
|
305
|
+
it('handles very long text content', () => {
|
|
306
|
+
const longText = 'a'.repeat(500);
|
|
307
|
+
const wrapper = mount(IconBullet, {
|
|
308
|
+
props: {
|
|
309
|
+
header: longText,
|
|
310
|
+
subHeader: longText
|
|
311
|
+
}
|
|
312
|
+
});
|
|
313
|
+
|
|
314
|
+
expect(wrapper.find('h3').text()).toHaveLength(500);
|
|
315
|
+
expect(wrapper.find('p.p-large').text()).toHaveLength(500);
|
|
316
|
+
});
|
|
317
|
+
});
|
|
318
|
+
|
|
319
|
+
describe('Component Integration', () => {
|
|
320
|
+
it('can be mounted without any props', () => {
|
|
321
|
+
expect(() => {
|
|
322
|
+
mount(IconBullet);
|
|
323
|
+
}).not.toThrow();
|
|
324
|
+
});
|
|
325
|
+
|
|
326
|
+
it('renders consistently on multiple mounts', () => {
|
|
327
|
+
const wrapper1 = mount(IconBullet, { props: defaultProps });
|
|
328
|
+
const wrapper2 = mount(IconBullet, { props: defaultProps });
|
|
329
|
+
|
|
330
|
+
expect(wrapper1.html()).toBe(wrapper2.html());
|
|
331
|
+
});
|
|
332
|
+
|
|
333
|
+
it('combines all features correctly', () => {
|
|
334
|
+
const wrapper = mount(IconBullet, {
|
|
335
|
+
props: {
|
|
336
|
+
header: 'Main Title',
|
|
337
|
+
subHeader: 'Subtitle',
|
|
338
|
+
icon: 'mdi-check',
|
|
339
|
+
iconSize: '48'
|
|
340
|
+
},
|
|
341
|
+
global: {
|
|
342
|
+
stubs: {
|
|
343
|
+
'v-icon': {
|
|
344
|
+
template: '<i class="v-icon" :icon="icon" :size="size">{{ icon }}</i>',
|
|
345
|
+
props: ['icon', 'size']
|
|
346
|
+
}
|
|
347
|
+
}
|
|
348
|
+
}
|
|
349
|
+
});
|
|
350
|
+
|
|
351
|
+
expect(wrapper.find('h3').text()).toBe('Main Title');
|
|
352
|
+
expect(wrapper.find('p.p-large').text()).toBe('Subtitle');
|
|
353
|
+
expect(wrapper.find('.v-icon').text()).toBe('mdi-check');
|
|
354
|
+
expect(wrapper.find('.v-icon').attributes('size')).toBe('48');
|
|
355
|
+
});
|
|
356
|
+
});
|
|
357
357
|
});
|