@zap-wunschlachen/wl-shared-components 1.0.38 → 1.0.40
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 +33 -33
- 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/background.svg +60 -60
- package/public/style.css +187 -187
- package/public/technologies.svg +22 -22
- package/src/assets/css/base.css +234 -232
- package/src/assets/css/variables.css +112 -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 -118
- package/src/components/Button/Button.vue +174 -174
- package/src/components/CheckBox/CheckBox.css +214 -214
- package/src/components/CheckBox/Checkbox.vue +138 -138
- 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 -38
- 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/{calendar.vue → Calendar.vue} +17 -17
- 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/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 -253
- 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 -71
- 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 -316
- 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 -218
- package/src/components/index.ts +29 -29
- 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 +116 -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 -469
- package/tests/unit/components/Accordion/AccordionGroup.spec.ts +228 -228
- package/tests/unit/components/Accordion/AccordionGroup.spec.ts.skip +342 -342
- package/tests/unit/components/Accordion/AccordionItem.spec.ts +292 -292
- package/tests/unit/components/Accordion/AccordionItem.spec.ts.skip +383 -383
- package/tests/unit/components/Appointment/AnamneseNotification.spec.ts +176 -176
- 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 -177
- 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 -313
- package/tests/unit/components/ErrorPage/ErrorPageLogo.spec.ts +153 -153
- 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 -61
- 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 -228
- package/tests/unit/components/Icons/MiniLogo.spec.ts +38 -38
- package/tests/unit/components/Icons/RingNotification.spec.ts +393 -393
- package/tests/unit/components/Icons/SolidArrowRight.spec.ts +49 -49
- 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 -197
- package/tests/unit/components/MaintenanceBanner/MaintenanceBanner.spec.ts +302 -302
- 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 -318
- package/tsconfig.json +26 -26
- package/vite.config.ts +29 -29
- package/vitest.config.ts +83 -83
|
@@ -1,183 +1,183 @@
|
|
|
1
|
-
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
2
|
-
|
|
3
|
-
// Mock CSS imports BEFORE any component imports
|
|
4
|
-
vi.mock('@/assets/css/base.css', () => ({}));
|
|
5
|
-
vi.mock('@/assets/css/variables.css', () => ({}));
|
|
6
|
-
vi.mock('vuetify/lib/components/VCode/VCode.css', () => ({}));
|
|
7
|
-
|
|
8
|
-
import { createApp } from 'vue';
|
|
9
|
-
import { WlSharedComponents } from '@/index';
|
|
10
|
-
import * as components from '@/components';
|
|
11
|
-
|
|
12
|
-
// Mock i18n
|
|
13
|
-
vi.mock('@/i18n/i18n', () => ({
|
|
14
|
-
createInternalI18n: vi.fn(() => ({
|
|
15
|
-
install: vi.fn(),
|
|
16
|
-
})),
|
|
17
|
-
}));
|
|
18
|
-
|
|
19
|
-
describe.skip('src/index.ts', () => {
|
|
20
|
-
let app: any;
|
|
21
|
-
let mockUse: any;
|
|
22
|
-
let mockComponent: any;
|
|
23
|
-
|
|
24
|
-
beforeEach(() => {
|
|
25
|
-
mockUse = vi.fn();
|
|
26
|
-
mockComponent = vi.fn();
|
|
27
|
-
app = {
|
|
28
|
-
use: mockUse,
|
|
29
|
-
component: mockComponent,
|
|
30
|
-
config: {
|
|
31
|
-
globalProperties: {}
|
|
32
|
-
}
|
|
33
|
-
};
|
|
34
|
-
});
|
|
35
|
-
|
|
36
|
-
describe('WlSharedComponents', () => {
|
|
37
|
-
it('exports WlSharedComponents with install function', () => {
|
|
38
|
-
expect(WlSharedComponents).toBeDefined();
|
|
39
|
-
expect(WlSharedComponents.install).toBeInstanceOf(Function);
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
it('install function sets up i18n when not already present', () => {
|
|
43
|
-
const { createInternalI18n } = require('@/i18n/i18n');
|
|
44
|
-
const mockI18n = { install: vi.fn() };
|
|
45
|
-
createInternalI18n.mockReturnValue(mockI18n);
|
|
46
|
-
|
|
47
|
-
WlSharedComponents.install(app);
|
|
48
|
-
|
|
49
|
-
expect(createInternalI18n).toHaveBeenCalled();
|
|
50
|
-
expect(app.use).toHaveBeenCalledWith(mockI18n);
|
|
51
|
-
});
|
|
52
|
-
|
|
53
|
-
it('install function does not set up i18n when already present', () => {
|
|
54
|
-
app.config.globalProperties.$i18n = {};
|
|
55
|
-
const { createInternalI18n } = require('@/i18n/i18n');
|
|
56
|
-
|
|
57
|
-
WlSharedComponents.install(app);
|
|
58
|
-
|
|
59
|
-
expect(createInternalI18n).not.toHaveBeenCalled();
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
it('registers all components with WL prefix', () => {
|
|
63
|
-
WlSharedComponents.install(app);
|
|
64
|
-
|
|
65
|
-
// Check that components are registered with WL prefix
|
|
66
|
-
const componentEntries = Object.entries(components);
|
|
67
|
-
expect(componentEntries.length).toBeGreaterThan(0);
|
|
68
|
-
|
|
69
|
-
componentEntries.forEach(([componentName, component]) => {
|
|
70
|
-
expect(app.component).toHaveBeenCalledWith(`WL${componentName}`, component);
|
|
71
|
-
});
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
it('handles app without config gracefully', () => {
|
|
75
|
-
const appWithoutConfig = {
|
|
76
|
-
use: mockUse,
|
|
77
|
-
component: mockComponent
|
|
78
|
-
};
|
|
79
|
-
|
|
80
|
-
expect(() => {
|
|
81
|
-
WlSharedComponents.install(appWithoutConfig);
|
|
82
|
-
}).not.toThrow();
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
it('handles app without globalProperties gracefully', () => {
|
|
86
|
-
const appWithoutGlobalProps = {
|
|
87
|
-
use: mockUse,
|
|
88
|
-
component: mockComponent,
|
|
89
|
-
config: {}
|
|
90
|
-
};
|
|
91
|
-
|
|
92
|
-
expect(() => {
|
|
93
|
-
WlSharedComponents.install(appWithoutGlobalProps);
|
|
94
|
-
}).not.toThrow();
|
|
95
|
-
});
|
|
96
|
-
});
|
|
97
|
-
|
|
98
|
-
describe('Component Exports', () => {
|
|
99
|
-
it('exports all components from components module', () => {
|
|
100
|
-
const componentNames = Object.keys(components);
|
|
101
|
-
|
|
102
|
-
expect(componentNames.length).toBeGreaterThan(0);
|
|
103
|
-
|
|
104
|
-
// Check that some expected components are exported
|
|
105
|
-
expect(componentNames).toContain('Button');
|
|
106
|
-
expect(componentNames).toContain('Input');
|
|
107
|
-
expect(componentNames).toContain('Select');
|
|
108
|
-
expect(componentNames).toContain('DateInput');
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
it('all exported components are valid Vue components', () => {
|
|
112
|
-
Object.entries(components).forEach(([name, component]) => {
|
|
113
|
-
expect(component).toBeDefined();
|
|
114
|
-
expect(typeof component).toBe('object');
|
|
115
|
-
// Vue components should have these properties
|
|
116
|
-
expect(component).toHaveProperty('__name');
|
|
117
|
-
});
|
|
118
|
-
});
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
describe('CSS Imports', () => {
|
|
122
|
-
it('imports required CSS files', async () => {
|
|
123
|
-
// CSS imports are mocked, but we can verify the module loads without error
|
|
124
|
-
expect(() => require('@/index')).not.toThrow();
|
|
125
|
-
});
|
|
126
|
-
});
|
|
127
|
-
|
|
128
|
-
describe('Integration with Vue App', () => {
|
|
129
|
-
it('can be installed on a real Vue app instance', () => {
|
|
130
|
-
const realApp = createApp({});
|
|
131
|
-
|
|
132
|
-
expect(() => {
|
|
133
|
-
WlSharedComponents.install(realApp);
|
|
134
|
-
}).not.toThrow();
|
|
135
|
-
});
|
|
136
|
-
|
|
137
|
-
it('installs i18n plugin when creating real app', () => {
|
|
138
|
-
const realApp = createApp({});
|
|
139
|
-
const originalUse = realApp.use;
|
|
140
|
-
const useSpy = vi.spyOn(realApp, 'use');
|
|
141
|
-
|
|
142
|
-
WlSharedComponents.install(realApp);
|
|
143
|
-
|
|
144
|
-
expect(useSpy).toHaveBeenCalled();
|
|
145
|
-
|
|
146
|
-
useSpy.mockRestore();
|
|
147
|
-
});
|
|
148
|
-
});
|
|
149
|
-
|
|
150
|
-
describe('Component Registration', () => {
|
|
151
|
-
it('uses correct component prefix', () => {
|
|
152
|
-
WlSharedComponents.install(app);
|
|
153
|
-
|
|
154
|
-
const calls = app.component.mock.calls;
|
|
155
|
-
calls.forEach(([componentName]) => {
|
|
156
|
-
expect(componentName).toMatch(/^WL/);
|
|
157
|
-
});
|
|
158
|
-
});
|
|
159
|
-
|
|
160
|
-
it('registers components with their original names prefixed', () => {
|
|
161
|
-
WlSharedComponents.install(app);
|
|
162
|
-
|
|
163
|
-
// Check specific component registrations
|
|
164
|
-
expect(app.component).toHaveBeenCalledWith('WLButton', components.Button);
|
|
165
|
-
expect(app.component).toHaveBeenCalledWith('WLInput', components.Input);
|
|
166
|
-
expect(app.component).toHaveBeenCalledWith('WLSelect', components.Select);
|
|
167
|
-
});
|
|
168
|
-
});
|
|
169
|
-
|
|
170
|
-
describe('Error Handling', () => {
|
|
171
|
-
it('handles null app gracefully', () => {
|
|
172
|
-
expect(() => {
|
|
173
|
-
WlSharedComponents.install(null);
|
|
174
|
-
}).toThrow();
|
|
175
|
-
});
|
|
176
|
-
|
|
177
|
-
it('handles undefined app gracefully', () => {
|
|
178
|
-
expect(() => {
|
|
179
|
-
WlSharedComponents.install(undefined);
|
|
180
|
-
}).toThrow();
|
|
181
|
-
});
|
|
182
|
-
});
|
|
1
|
+
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
2
|
+
|
|
3
|
+
// Mock CSS imports BEFORE any component imports
|
|
4
|
+
vi.mock('@/assets/css/base.css', () => ({}));
|
|
5
|
+
vi.mock('@/assets/css/variables.css', () => ({}));
|
|
6
|
+
vi.mock('vuetify/lib/components/VCode/VCode.css', () => ({}));
|
|
7
|
+
|
|
8
|
+
import { createApp } from 'vue';
|
|
9
|
+
import { WlSharedComponents } from '@/index';
|
|
10
|
+
import * as components from '@/components';
|
|
11
|
+
|
|
12
|
+
// Mock i18n
|
|
13
|
+
vi.mock('@/i18n/i18n', () => ({
|
|
14
|
+
createInternalI18n: vi.fn(() => ({
|
|
15
|
+
install: vi.fn(),
|
|
16
|
+
})),
|
|
17
|
+
}));
|
|
18
|
+
|
|
19
|
+
describe.skip('src/index.ts', () => {
|
|
20
|
+
let app: any;
|
|
21
|
+
let mockUse: any;
|
|
22
|
+
let mockComponent: any;
|
|
23
|
+
|
|
24
|
+
beforeEach(() => {
|
|
25
|
+
mockUse = vi.fn();
|
|
26
|
+
mockComponent = vi.fn();
|
|
27
|
+
app = {
|
|
28
|
+
use: mockUse,
|
|
29
|
+
component: mockComponent,
|
|
30
|
+
config: {
|
|
31
|
+
globalProperties: {}
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
describe('WlSharedComponents', () => {
|
|
37
|
+
it('exports WlSharedComponents with install function', () => {
|
|
38
|
+
expect(WlSharedComponents).toBeDefined();
|
|
39
|
+
expect(WlSharedComponents.install).toBeInstanceOf(Function);
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
it('install function sets up i18n when not already present', () => {
|
|
43
|
+
const { createInternalI18n } = require('@/i18n/i18n');
|
|
44
|
+
const mockI18n = { install: vi.fn() };
|
|
45
|
+
createInternalI18n.mockReturnValue(mockI18n);
|
|
46
|
+
|
|
47
|
+
WlSharedComponents.install(app);
|
|
48
|
+
|
|
49
|
+
expect(createInternalI18n).toHaveBeenCalled();
|
|
50
|
+
expect(app.use).toHaveBeenCalledWith(mockI18n);
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
it('install function does not set up i18n when already present', () => {
|
|
54
|
+
app.config.globalProperties.$i18n = {};
|
|
55
|
+
const { createInternalI18n } = require('@/i18n/i18n');
|
|
56
|
+
|
|
57
|
+
WlSharedComponents.install(app);
|
|
58
|
+
|
|
59
|
+
expect(createInternalI18n).not.toHaveBeenCalled();
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
it('registers all components with WL prefix', () => {
|
|
63
|
+
WlSharedComponents.install(app);
|
|
64
|
+
|
|
65
|
+
// Check that components are registered with WL prefix
|
|
66
|
+
const componentEntries = Object.entries(components);
|
|
67
|
+
expect(componentEntries.length).toBeGreaterThan(0);
|
|
68
|
+
|
|
69
|
+
componentEntries.forEach(([componentName, component]) => {
|
|
70
|
+
expect(app.component).toHaveBeenCalledWith(`WL${componentName}`, component);
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
it('handles app without config gracefully', () => {
|
|
75
|
+
const appWithoutConfig = {
|
|
76
|
+
use: mockUse,
|
|
77
|
+
component: mockComponent
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
expect(() => {
|
|
81
|
+
WlSharedComponents.install(appWithoutConfig);
|
|
82
|
+
}).not.toThrow();
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
it('handles app without globalProperties gracefully', () => {
|
|
86
|
+
const appWithoutGlobalProps = {
|
|
87
|
+
use: mockUse,
|
|
88
|
+
component: mockComponent,
|
|
89
|
+
config: {}
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
expect(() => {
|
|
93
|
+
WlSharedComponents.install(appWithoutGlobalProps);
|
|
94
|
+
}).not.toThrow();
|
|
95
|
+
});
|
|
96
|
+
});
|
|
97
|
+
|
|
98
|
+
describe('Component Exports', () => {
|
|
99
|
+
it('exports all components from components module', () => {
|
|
100
|
+
const componentNames = Object.keys(components);
|
|
101
|
+
|
|
102
|
+
expect(componentNames.length).toBeGreaterThan(0);
|
|
103
|
+
|
|
104
|
+
// Check that some expected components are exported
|
|
105
|
+
expect(componentNames).toContain('Button');
|
|
106
|
+
expect(componentNames).toContain('Input');
|
|
107
|
+
expect(componentNames).toContain('Select');
|
|
108
|
+
expect(componentNames).toContain('DateInput');
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
it('all exported components are valid Vue components', () => {
|
|
112
|
+
Object.entries(components).forEach(([name, component]) => {
|
|
113
|
+
expect(component).toBeDefined();
|
|
114
|
+
expect(typeof component).toBe('object');
|
|
115
|
+
// Vue components should have these properties
|
|
116
|
+
expect(component).toHaveProperty('__name');
|
|
117
|
+
});
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
|
|
121
|
+
describe('CSS Imports', () => {
|
|
122
|
+
it('imports required CSS files', async () => {
|
|
123
|
+
// CSS imports are mocked, but we can verify the module loads without error
|
|
124
|
+
expect(() => require('@/index')).not.toThrow();
|
|
125
|
+
});
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
describe('Integration with Vue App', () => {
|
|
129
|
+
it('can be installed on a real Vue app instance', () => {
|
|
130
|
+
const realApp = createApp({});
|
|
131
|
+
|
|
132
|
+
expect(() => {
|
|
133
|
+
WlSharedComponents.install(realApp);
|
|
134
|
+
}).not.toThrow();
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
it('installs i18n plugin when creating real app', () => {
|
|
138
|
+
const realApp = createApp({});
|
|
139
|
+
const originalUse = realApp.use;
|
|
140
|
+
const useSpy = vi.spyOn(realApp, 'use');
|
|
141
|
+
|
|
142
|
+
WlSharedComponents.install(realApp);
|
|
143
|
+
|
|
144
|
+
expect(useSpy).toHaveBeenCalled();
|
|
145
|
+
|
|
146
|
+
useSpy.mockRestore();
|
|
147
|
+
});
|
|
148
|
+
});
|
|
149
|
+
|
|
150
|
+
describe('Component Registration', () => {
|
|
151
|
+
it('uses correct component prefix', () => {
|
|
152
|
+
WlSharedComponents.install(app);
|
|
153
|
+
|
|
154
|
+
const calls = app.component.mock.calls;
|
|
155
|
+
calls.forEach(([componentName]) => {
|
|
156
|
+
expect(componentName).toMatch(/^WL/);
|
|
157
|
+
});
|
|
158
|
+
});
|
|
159
|
+
|
|
160
|
+
it('registers components with their original names prefixed', () => {
|
|
161
|
+
WlSharedComponents.install(app);
|
|
162
|
+
|
|
163
|
+
// Check specific component registrations
|
|
164
|
+
expect(app.component).toHaveBeenCalledWith('WLButton', components.Button);
|
|
165
|
+
expect(app.component).toHaveBeenCalledWith('WLInput', components.Input);
|
|
166
|
+
expect(app.component).toHaveBeenCalledWith('WLSelect', components.Select);
|
|
167
|
+
});
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
describe('Error Handling', () => {
|
|
171
|
+
it('handles null app gracefully', () => {
|
|
172
|
+
expect(() => {
|
|
173
|
+
WlSharedComponents.install(null);
|
|
174
|
+
}).toThrow();
|
|
175
|
+
});
|
|
176
|
+
|
|
177
|
+
it('handles undefined app gracefully', () => {
|
|
178
|
+
expect(() => {
|
|
179
|
+
WlSharedComponents.install(undefined);
|
|
180
|
+
}).toThrow();
|
|
181
|
+
});
|
|
182
|
+
});
|
|
183
183
|
});
|
|
@@ -1,152 +1,152 @@
|
|
|
1
|
-
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
|
|
2
|
-
|
|
3
|
-
// Mock all dependencies before importing main.ts
|
|
4
|
-
const mockCreateApp = vi.fn();
|
|
5
|
-
const mockApp = {
|
|
6
|
-
use: vi.fn(),
|
|
7
|
-
mount: vi.fn()
|
|
8
|
-
};
|
|
9
|
-
|
|
10
|
-
const mockCreateInternalI18n = vi.fn(() => ({}));
|
|
11
|
-
|
|
12
|
-
vi.mock('vue', async (importOriginal) => {
|
|
13
|
-
const actual = await importOriginal<typeof import('vue')>();
|
|
14
|
-
return {
|
|
15
|
-
...actual,
|
|
16
|
-
createApp: mockCreateApp
|
|
17
|
-
};
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
vi.mock('../App.vue', () => ({
|
|
21
|
-
default: {}
|
|
22
|
-
}));
|
|
23
|
-
|
|
24
|
-
vi.mock('@/plugins/vuetify', () => ({
|
|
25
|
-
default: {}
|
|
26
|
-
}));
|
|
27
|
-
|
|
28
|
-
vi.mock('@/i18n/i18n', () => ({
|
|
29
|
-
createInternalI18n: mockCreateInternalI18n
|
|
30
|
-
}));
|
|
31
|
-
|
|
32
|
-
vi.mock('@/assets/css/base.css', () => ({}));
|
|
33
|
-
vi.mock('@/assets/css/variables.css', () => ({}));
|
|
34
|
-
|
|
35
|
-
describe('src/main.ts', () => {
|
|
36
|
-
beforeEach(() => {
|
|
37
|
-
vi.clearAllMocks();
|
|
38
|
-
mockCreateApp.mockReturnValue(mockApp);
|
|
39
|
-
mockCreateInternalI18n.mockReturnValue({});
|
|
40
|
-
// Clear the module cache to ensure fresh imports
|
|
41
|
-
vi.resetModules();
|
|
42
|
-
});
|
|
43
|
-
|
|
44
|
-
describe('Application Setup', () => {
|
|
45
|
-
it('creates Vue application', async () => {
|
|
46
|
-
// Import main.ts to execute the setup
|
|
47
|
-
await import('@/main');
|
|
48
|
-
|
|
49
|
-
expect(mockCreateApp).toHaveBeenCalled();
|
|
50
|
-
expect(mockCreateApp).toHaveBeenCalledWith(expect.any(Object));
|
|
51
|
-
});
|
|
52
|
-
|
|
53
|
-
it('registers Vuetify plugin', async () => {
|
|
54
|
-
await import('@/main');
|
|
55
|
-
|
|
56
|
-
expect(mockApp.use).toHaveBeenCalledWith(expect.any(Object));
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
it('registers i18n plugin', async () => {
|
|
60
|
-
await import('@/main');
|
|
61
|
-
|
|
62
|
-
expect(mockCreateInternalI18n).toHaveBeenCalled();
|
|
63
|
-
expect(mockApp.use).toHaveBeenCalledWith(expect.any(Object));
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
it('mounts application to #app', async () => {
|
|
67
|
-
await import('@/main');
|
|
68
|
-
|
|
69
|
-
expect(mockApp.mount).toHaveBeenCalledWith('#app');
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
it('follows correct initialization order', async () => {
|
|
73
|
-
await import('@/main');
|
|
74
|
-
|
|
75
|
-
const useCalls = mockApp.use.mock.calls;
|
|
76
|
-
expect(useCalls.length).toBe(2); // Vuetify + i18n
|
|
77
|
-
|
|
78
|
-
// Mount should be called after use()
|
|
79
|
-
expect(mockApp.mount).toHaveBeenCalledAfter(mockApp.use as any);
|
|
80
|
-
});
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
describe('Plugin Registration', () => {
|
|
84
|
-
it('uses vuetify plugin first', async () => {
|
|
85
|
-
await import('@/main');
|
|
86
|
-
|
|
87
|
-
expect(mockApp.use).toHaveBeenCalledWith(expect.any(Object));
|
|
88
|
-
});
|
|
89
|
-
|
|
90
|
-
it('uses i18n plugin second', async () => {
|
|
91
|
-
await import('@/main');
|
|
92
|
-
|
|
93
|
-
expect(mockApp.use).toHaveBeenCalledTimes(2);
|
|
94
|
-
});
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
describe('CSS Imports', () => {
|
|
98
|
-
it('imports base CSS without errors', async () => {
|
|
99
|
-
// CSS imports are mocked, so we can verify the module loads without error
|
|
100
|
-
expect(() => import('@/main')).not.toThrow();
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
it('imports variables CSS without errors', async () => {
|
|
104
|
-
// CSS imports are mocked, so we can verify the module loads without error
|
|
105
|
-
expect(() => import('@/main')).not.toThrow();
|
|
106
|
-
});
|
|
107
|
-
});
|
|
108
|
-
|
|
109
|
-
describe('Module Loading', () => {
|
|
110
|
-
it('loads main module without errors', async () => {
|
|
111
|
-
await expect(import('@/main')).resolves.toBeDefined();
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
it('imports App component', async () => {
|
|
115
|
-
await import('@/main');
|
|
116
|
-
|
|
117
|
-
// Since App component is mocked, just verify main.ts loaded successfully
|
|
118
|
-
expect(mockCreateApp).toHaveBeenCalledWith(expect.any(Object));
|
|
119
|
-
});
|
|
120
|
-
});
|
|
121
|
-
|
|
122
|
-
describe('Error Handling', () => {
|
|
123
|
-
it('can handle createApp being called', async () => {
|
|
124
|
-
// Test that createApp is called without throwing
|
|
125
|
-
await import('@/main');
|
|
126
|
-
expect(mockCreateApp).toHaveBeenCalled();
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
it('can handle app.use being called', async () => {
|
|
130
|
-
// Test that app.use is called without throwing
|
|
131
|
-
await import('@/main');
|
|
132
|
-
expect(mockApp.use).toHaveBeenCalled();
|
|
133
|
-
});
|
|
134
|
-
|
|
135
|
-
it('can handle app.mount being called', async () => {
|
|
136
|
-
// Test that app.mount is called without throwing
|
|
137
|
-
await import('@/main');
|
|
138
|
-
expect(mockApp.mount).toHaveBeenCalled();
|
|
139
|
-
});
|
|
140
|
-
});
|
|
141
|
-
|
|
142
|
-
describe('Development Setup', () => {
|
|
143
|
-
it('sets up development environment correctly', async () => {
|
|
144
|
-
await import('@/main');
|
|
145
|
-
|
|
146
|
-
// Verify that the setup completes without throwing
|
|
147
|
-
expect(mockCreateApp).toHaveBeenCalled();
|
|
148
|
-
expect(mockApp.use).toHaveBeenCalled();
|
|
149
|
-
expect(mockApp.mount).toHaveBeenCalled();
|
|
150
|
-
});
|
|
151
|
-
});
|
|
1
|
+
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
|
|
2
|
+
|
|
3
|
+
// Mock all dependencies before importing main.ts
|
|
4
|
+
const mockCreateApp = vi.fn();
|
|
5
|
+
const mockApp = {
|
|
6
|
+
use: vi.fn(),
|
|
7
|
+
mount: vi.fn()
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
const mockCreateInternalI18n = vi.fn(() => ({}));
|
|
11
|
+
|
|
12
|
+
vi.mock('vue', async (importOriginal) => {
|
|
13
|
+
const actual = await importOriginal<typeof import('vue')>();
|
|
14
|
+
return {
|
|
15
|
+
...actual,
|
|
16
|
+
createApp: mockCreateApp
|
|
17
|
+
};
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
vi.mock('../App.vue', () => ({
|
|
21
|
+
default: {}
|
|
22
|
+
}));
|
|
23
|
+
|
|
24
|
+
vi.mock('@/plugins/vuetify', () => ({
|
|
25
|
+
default: {}
|
|
26
|
+
}));
|
|
27
|
+
|
|
28
|
+
vi.mock('@/i18n/i18n', () => ({
|
|
29
|
+
createInternalI18n: mockCreateInternalI18n
|
|
30
|
+
}));
|
|
31
|
+
|
|
32
|
+
vi.mock('@/assets/css/base.css', () => ({}));
|
|
33
|
+
vi.mock('@/assets/css/variables.css', () => ({}));
|
|
34
|
+
|
|
35
|
+
describe('src/main.ts', () => {
|
|
36
|
+
beforeEach(() => {
|
|
37
|
+
vi.clearAllMocks();
|
|
38
|
+
mockCreateApp.mockReturnValue(mockApp);
|
|
39
|
+
mockCreateInternalI18n.mockReturnValue({});
|
|
40
|
+
// Clear the module cache to ensure fresh imports
|
|
41
|
+
vi.resetModules();
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
describe('Application Setup', () => {
|
|
45
|
+
it('creates Vue application', async () => {
|
|
46
|
+
// Import main.ts to execute the setup
|
|
47
|
+
await import('@/main');
|
|
48
|
+
|
|
49
|
+
expect(mockCreateApp).toHaveBeenCalled();
|
|
50
|
+
expect(mockCreateApp).toHaveBeenCalledWith(expect.any(Object));
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
it('registers Vuetify plugin', async () => {
|
|
54
|
+
await import('@/main');
|
|
55
|
+
|
|
56
|
+
expect(mockApp.use).toHaveBeenCalledWith(expect.any(Object));
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
it('registers i18n plugin', async () => {
|
|
60
|
+
await import('@/main');
|
|
61
|
+
|
|
62
|
+
expect(mockCreateInternalI18n).toHaveBeenCalled();
|
|
63
|
+
expect(mockApp.use).toHaveBeenCalledWith(expect.any(Object));
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
it('mounts application to #app', async () => {
|
|
67
|
+
await import('@/main');
|
|
68
|
+
|
|
69
|
+
expect(mockApp.mount).toHaveBeenCalledWith('#app');
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
it('follows correct initialization order', async () => {
|
|
73
|
+
await import('@/main');
|
|
74
|
+
|
|
75
|
+
const useCalls = mockApp.use.mock.calls;
|
|
76
|
+
expect(useCalls.length).toBe(2); // Vuetify + i18n
|
|
77
|
+
|
|
78
|
+
// Mount should be called after use()
|
|
79
|
+
expect(mockApp.mount).toHaveBeenCalledAfter(mockApp.use as any);
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
describe('Plugin Registration', () => {
|
|
84
|
+
it('uses vuetify plugin first', async () => {
|
|
85
|
+
await import('@/main');
|
|
86
|
+
|
|
87
|
+
expect(mockApp.use).toHaveBeenCalledWith(expect.any(Object));
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
it('uses i18n plugin second', async () => {
|
|
91
|
+
await import('@/main');
|
|
92
|
+
|
|
93
|
+
expect(mockApp.use).toHaveBeenCalledTimes(2);
|
|
94
|
+
});
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
describe('CSS Imports', () => {
|
|
98
|
+
it('imports base CSS without errors', async () => {
|
|
99
|
+
// CSS imports are mocked, so we can verify the module loads without error
|
|
100
|
+
expect(() => import('@/main')).not.toThrow();
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
it('imports variables CSS without errors', async () => {
|
|
104
|
+
// CSS imports are mocked, so we can verify the module loads without error
|
|
105
|
+
expect(() => import('@/main')).not.toThrow();
|
|
106
|
+
});
|
|
107
|
+
});
|
|
108
|
+
|
|
109
|
+
describe('Module Loading', () => {
|
|
110
|
+
it('loads main module without errors', async () => {
|
|
111
|
+
await expect(import('@/main')).resolves.toBeDefined();
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
it('imports App component', async () => {
|
|
115
|
+
await import('@/main');
|
|
116
|
+
|
|
117
|
+
// Since App component is mocked, just verify main.ts loaded successfully
|
|
118
|
+
expect(mockCreateApp).toHaveBeenCalledWith(expect.any(Object));
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
describe('Error Handling', () => {
|
|
123
|
+
it('can handle createApp being called', async () => {
|
|
124
|
+
// Test that createApp is called without throwing
|
|
125
|
+
await import('@/main');
|
|
126
|
+
expect(mockCreateApp).toHaveBeenCalled();
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
it('can handle app.use being called', async () => {
|
|
130
|
+
// Test that app.use is called without throwing
|
|
131
|
+
await import('@/main');
|
|
132
|
+
expect(mockApp.use).toHaveBeenCalled();
|
|
133
|
+
});
|
|
134
|
+
|
|
135
|
+
it('can handle app.mount being called', async () => {
|
|
136
|
+
// Test that app.mount is called without throwing
|
|
137
|
+
await import('@/main');
|
|
138
|
+
expect(mockApp.mount).toHaveBeenCalled();
|
|
139
|
+
});
|
|
140
|
+
});
|
|
141
|
+
|
|
142
|
+
describe('Development Setup', () => {
|
|
143
|
+
it('sets up development environment correctly', async () => {
|
|
144
|
+
await import('@/main');
|
|
145
|
+
|
|
146
|
+
// Verify that the setup completes without throwing
|
|
147
|
+
expect(mockCreateApp).toHaveBeenCalled();
|
|
148
|
+
expect(mockApp.use).toHaveBeenCalled();
|
|
149
|
+
expect(mockApp.mount).toHaveBeenCalled();
|
|
150
|
+
});
|
|
151
|
+
});
|
|
152
152
|
});
|