create-fluxstack 1.0.12 → 1.0.14

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 (215) hide show
  1. package/.env.example +29 -29
  2. package/app/client/README.md +69 -69
  3. package/app/client/index.html +14 -13
  4. package/app/client/src/App.tsx +157 -524
  5. package/app/client/src/components/ErrorBoundary.tsx +107 -0
  6. package/app/client/src/components/ErrorDisplay.css +365 -0
  7. package/app/client/src/components/ErrorDisplay.tsx +258 -0
  8. package/app/client/src/components/FluxStackConfig.tsx +1321 -0
  9. package/app/client/src/components/HybridLiveCounter.tsx +140 -0
  10. package/app/client/src/components/LiveClock.tsx +286 -0
  11. package/app/client/src/components/MainLayout.tsx +390 -0
  12. package/app/client/src/components/SidebarNavigation.tsx +391 -0
  13. package/app/client/src/components/StateDemo.tsx +178 -0
  14. package/app/client/src/components/SystemMonitor.tsx +1038 -0
  15. package/app/client/src/components/Teste.tsx +104 -0
  16. package/app/client/src/components/UserProfile.tsx +809 -0
  17. package/app/client/src/hooks/useAuth.ts +39 -0
  18. package/app/client/src/hooks/useNotifications.ts +56 -0
  19. package/app/client/src/lib/eden-api.ts +189 -53
  20. package/app/client/src/lib/errors.ts +340 -0
  21. package/app/client/src/lib/hooks/useErrorHandler.ts +258 -0
  22. package/app/client/src/lib/index.ts +45 -0
  23. package/app/client/src/main.tsx +3 -2
  24. package/app/client/src/pages/ApiDocs.tsx +182 -0
  25. package/app/client/src/pages/Demo.tsx +174 -0
  26. package/app/client/src/pages/HybridLive.tsx +263 -0
  27. package/app/client/src/pages/Overview.tsx +155 -0
  28. package/app/client/src/store/README.md +43 -0
  29. package/app/client/src/store/index.ts +16 -0
  30. package/app/client/src/store/slices/uiSlice.ts +151 -0
  31. package/app/client/src/store/slices/userSlice.ts +161 -0
  32. package/app/client/src/test/README.md +257 -0
  33. package/app/client/src/test/setup.ts +70 -0
  34. package/app/client/src/test/types.ts +12 -0
  35. package/app/client/src/vite-env.d.ts +1 -1
  36. package/app/client/tsconfig.app.json +44 -43
  37. package/app/client/tsconfig.json +7 -7
  38. package/app/client/tsconfig.node.json +25 -25
  39. package/app/client/zustand-setup.md +65 -0
  40. package/app/server/controllers/users.controller.ts +68 -68
  41. package/app/server/index.ts +9 -1
  42. package/app/server/live/CounterComponent.ts +191 -0
  43. package/app/server/live/FluxStackConfig.ts +529 -0
  44. package/app/server/live/LiveClockComponent.ts +214 -0
  45. package/app/server/live/SidebarNavigation.ts +156 -0
  46. package/app/server/live/SystemMonitor.ts +594 -0
  47. package/app/server/live/SystemMonitorIntegration.ts +151 -0
  48. package/app/server/live/TesteComponent.ts +87 -0
  49. package/app/server/live/UserProfileComponent.ts +135 -0
  50. package/app/server/live/register-components.ts +28 -0
  51. package/app/server/middleware/auth.ts +136 -0
  52. package/app/server/middleware/errorHandling.ts +250 -0
  53. package/app/server/middleware/index.ts +10 -0
  54. package/app/server/middleware/rateLimit.ts +193 -0
  55. package/app/server/middleware/requestLogging.ts +215 -0
  56. package/app/server/middleware/validation.ts +270 -0
  57. package/app/server/routes/index.ts +14 -2
  58. package/app/server/routes/upload.ts +92 -0
  59. package/app/server/routes/users.routes.ts +2 -9
  60. package/app/server/services/NotificationService.ts +302 -0
  61. package/app/server/services/UserService.ts +222 -0
  62. package/app/server/services/index.ts +46 -0
  63. package/core/cli/commands/plugin-deps.ts +263 -0
  64. package/core/cli/generators/README.md +339 -0
  65. package/core/cli/generators/component.ts +770 -0
  66. package/core/cli/generators/controller.ts +299 -0
  67. package/core/cli/generators/index.ts +144 -0
  68. package/core/cli/generators/interactive.ts +228 -0
  69. package/core/cli/generators/prompts.ts +83 -0
  70. package/core/cli/generators/route.ts +513 -0
  71. package/core/cli/generators/service.ts +465 -0
  72. package/core/cli/generators/template-engine.ts +154 -0
  73. package/core/cli/generators/types.ts +71 -0
  74. package/core/cli/generators/utils.ts +192 -0
  75. package/core/cli/index.ts +69 -0
  76. package/core/cli/plugin-discovery.ts +16 -85
  77. package/core/client/fluxstack.ts +17 -0
  78. package/core/client/hooks/index.ts +7 -0
  79. package/core/client/hooks/state-validator.ts +130 -0
  80. package/core/client/hooks/useAuth.ts +49 -0
  81. package/core/client/hooks/useChunkedUpload.ts +258 -0
  82. package/core/client/hooks/useHybridLiveComponent.ts +967 -0
  83. package/core/client/hooks/useWebSocket.ts +373 -0
  84. package/core/client/index.ts +47 -0
  85. package/core/client/state/createStore.ts +193 -0
  86. package/core/client/state/index.ts +15 -0
  87. package/core/config/env-dynamic.ts +1 -1
  88. package/core/config/env.ts +2 -1
  89. package/core/config/loader.ts +8 -32
  90. package/core/config/runtime-config.ts +3 -3
  91. package/core/config/schema.ts +84 -49
  92. package/core/framework/server.ts +30 -0
  93. package/core/index.ts +25 -0
  94. package/core/live/ComponentRegistry.ts +399 -0
  95. package/core/live/types.ts +164 -0
  96. package/core/plugins/built-in/live-components/commands/create-live-component.ts +1201 -0
  97. package/core/plugins/built-in/live-components/index.ts +27 -0
  98. package/core/plugins/built-in/logger/index.ts +1 -1
  99. package/core/plugins/built-in/monitoring/index.ts +1 -1
  100. package/core/plugins/built-in/static/index.ts +1 -1
  101. package/core/plugins/built-in/swagger/index.ts +1 -1
  102. package/core/plugins/built-in/vite/index.ts +1 -1
  103. package/core/plugins/dependency-manager.ts +384 -0
  104. package/core/plugins/index.ts +5 -1
  105. package/core/plugins/manager.ts +7 -3
  106. package/core/plugins/registry.ts +88 -10
  107. package/core/plugins/types.ts +11 -11
  108. package/core/server/framework.ts +43 -0
  109. package/core/server/index.ts +11 -1
  110. package/core/server/live/ComponentRegistry.ts +1017 -0
  111. package/core/server/live/FileUploadManager.ts +272 -0
  112. package/core/server/live/LiveComponentPerformanceMonitor.ts +930 -0
  113. package/core/server/live/SingleConnectionManager.ts +0 -0
  114. package/core/server/live/StateSignature.ts +644 -0
  115. package/core/server/live/WebSocketConnectionManager.ts +688 -0
  116. package/core/server/live/websocket-plugin.ts +435 -0
  117. package/core/server/middleware/errorHandling.ts +141 -0
  118. package/core/server/middleware/index.ts +16 -0
  119. package/core/server/plugins/static-files-plugin.ts +232 -0
  120. package/core/server/services/BaseService.ts +95 -0
  121. package/core/server/services/ServiceContainer.ts +144 -0
  122. package/core/server/services/index.ts +9 -0
  123. package/core/templates/create-project.ts +46 -2
  124. package/core/testing/index.ts +10 -0
  125. package/core/testing/setup.ts +74 -0
  126. package/core/types/build.ts +38 -14
  127. package/core/types/types.ts +319 -0
  128. package/core/utils/env-runtime.ts +7 -0
  129. package/core/utils/errors/handlers.ts +264 -39
  130. package/core/utils/errors/index.ts +528 -18
  131. package/core/utils/errors/middleware.ts +114 -0
  132. package/core/utils/logger/formatters.ts +222 -0
  133. package/core/utils/logger/index.ts +167 -48
  134. package/core/utils/logger/middleware.ts +253 -0
  135. package/core/utils/logger/performance.ts +384 -0
  136. package/core/utils/logger/transports.ts +365 -0
  137. package/create-fluxstack.ts +296 -296
  138. package/fluxstack.config.ts +17 -1
  139. package/package-template.json +66 -66
  140. package/package.json +31 -6
  141. package/public/README.md +16 -0
  142. package/vite.config.ts +29 -14
  143. package/.claude/settings.local.json +0 -74
  144. package/.github/workflows/ci-build-tests.yml +0 -480
  145. package/.github/workflows/dependency-management.yml +0 -324
  146. package/.github/workflows/release-validation.yml +0 -355
  147. package/.kiro/specs/fluxstack-architecture-optimization/design.md +0 -700
  148. package/.kiro/specs/fluxstack-architecture-optimization/requirements.md +0 -127
  149. package/.kiro/specs/fluxstack-architecture-optimization/tasks.md +0 -330
  150. package/CLAUDE.md +0 -200
  151. package/Dockerfile +0 -58
  152. package/Dockerfile.backend +0 -52
  153. package/Dockerfile.frontend +0 -54
  154. package/README-Docker.md +0 -85
  155. package/ai-context/00-QUICK-START.md +0 -86
  156. package/ai-context/README.md +0 -88
  157. package/ai-context/development/eden-treaty-guide.md +0 -362
  158. package/ai-context/development/patterns.md +0 -382
  159. package/ai-context/development/plugins-guide.md +0 -572
  160. package/ai-context/examples/crud-complete.md +0 -626
  161. package/ai-context/project/architecture.md +0 -399
  162. package/ai-context/project/overview.md +0 -213
  163. package/ai-context/recent-changes/eden-treaty-refactor.md +0 -281
  164. package/ai-context/recent-changes/type-inference-fix.md +0 -223
  165. package/ai-context/reference/environment-vars.md +0 -384
  166. package/ai-context/reference/troubleshooting.md +0 -407
  167. package/app/client/src/components/TestPage.tsx +0 -453
  168. package/bun.lock +0 -1063
  169. package/bunfig.toml +0 -16
  170. package/core/__tests__/integration.test.ts +0 -227
  171. package/core/build/index.ts +0 -186
  172. package/core/config/__tests__/config-loader.test.ts +0 -591
  173. package/core/config/__tests__/config-merger.test.ts +0 -657
  174. package/core/config/__tests__/env-converter.test.ts +0 -372
  175. package/core/config/__tests__/env-processor.test.ts +0 -431
  176. package/core/config/__tests__/env.test.ts +0 -452
  177. package/core/config/__tests__/integration.test.ts +0 -418
  178. package/core/config/__tests__/loader.test.ts +0 -331
  179. package/core/config/__tests__/schema.test.ts +0 -129
  180. package/core/config/__tests__/validator.test.ts +0 -318
  181. package/core/framework/__tests__/server.test.ts +0 -233
  182. package/core/plugins/__tests__/built-in.test.ts.disabled +0 -366
  183. package/core/plugins/__tests__/manager.test.ts +0 -398
  184. package/core/plugins/__tests__/monitoring.test.ts +0 -401
  185. package/core/plugins/__tests__/registry.test.ts +0 -335
  186. package/core/utils/__tests__/errors.test.ts +0 -139
  187. package/core/utils/__tests__/helpers.test.ts +0 -297
  188. package/core/utils/__tests__/logger.test.ts +0 -141
  189. package/create-test-app.ts +0 -156
  190. package/docker-compose.microservices.yml +0 -75
  191. package/docker-compose.simple.yml +0 -57
  192. package/docker-compose.yml +0 -71
  193. package/eslint.config.js +0 -23
  194. package/flux-cli.ts +0 -214
  195. package/nginx-lb.conf +0 -37
  196. package/publish.sh +0 -63
  197. package/run-clean.ts +0 -26
  198. package/run-env-tests.ts +0 -313
  199. package/tailwind.config.js +0 -34
  200. package/tests/__mocks__/api.ts +0 -56
  201. package/tests/fixtures/users.ts +0 -69
  202. package/tests/integration/api/users.routes.test.ts +0 -221
  203. package/tests/setup.ts +0 -29
  204. package/tests/unit/app/client/App-simple.test.tsx +0 -56
  205. package/tests/unit/app/client/App.test.tsx.skip +0 -237
  206. package/tests/unit/app/client/eden-api.test.ts +0 -186
  207. package/tests/unit/app/client/simple.test.tsx +0 -23
  208. package/tests/unit/app/controllers/users.controller.test.ts +0 -150
  209. package/tests/unit/core/create-project.test.ts.skip +0 -95
  210. package/tests/unit/core/framework.test.ts +0 -144
  211. package/tests/unit/core/plugins/logger.test.ts.skip +0 -268
  212. package/tests/unit/core/plugins/vite.test.ts.disabled +0 -188
  213. package/tests/utils/test-helpers.ts +0 -61
  214. package/vitest.config.ts +0 -50
  215. package/workspace.json +0 -6
@@ -1,401 +0,0 @@
1
- /**
2
- * Tests for Monitoring Plugin
3
- */
4
-
5
- import { describe, it, expect, beforeEach, vi, afterEach } from 'vitest'
6
- import { monitoringPlugin } from '../built-in/monitoring'
7
- import type { PluginContext, RequestContext, ResponseContext, ErrorContext } from '../types'
8
- import type { Logger } from '../../utils/logger/index'
9
- import type { FluxStackConfig } from '../../config/schema'
10
-
11
- // Mock logger
12
- const mockLogger: Logger = {
13
- debug: vi.fn(),
14
- info: vi.fn(),
15
- warn: vi.fn(),
16
- error: vi.fn(),
17
- child: vi.fn(() => mockLogger),
18
- time: vi.fn(),
19
- timeEnd: vi.fn(),
20
- request: vi.fn()
21
- }
22
-
23
- // Mock utils
24
- const mockUtils = {
25
- createTimer: vi.fn(() => ({ end: vi.fn(() => 100) })),
26
- formatBytes: vi.fn((bytes: number) => `${bytes} bytes`),
27
- isProduction: vi.fn(() => false),
28
- isDevelopment: vi.fn(() => true),
29
- getEnvironment: vi.fn(() => 'development'),
30
- createHash: vi.fn(() => 'hash123'),
31
- deepMerge: vi.fn((a, b) => ({ ...a, ...b })),
32
- validateSchema: vi.fn(() => ({ valid: true, errors: [] }))
33
- }
34
-
35
- // Mock config
36
- const mockConfig: FluxStackConfig = {
37
- app: { name: 'test-app', version: '1.0.0' },
38
- server: {
39
- port: 3000,
40
- host: 'localhost',
41
- apiPrefix: '/api',
42
- cors: {
43
- origins: ['*'],
44
- methods: ['GET', 'POST'],
45
- headers: ['Content-Type']
46
- },
47
- middleware: []
48
- },
49
- client: {
50
- port: 5173,
51
- proxy: { target: 'http://localhost:3000' },
52
- build: {
53
- sourceMaps: true,
54
- minify: false,
55
- target: 'esnext',
56
- outDir: 'dist/client'
57
- }
58
- },
59
- build: {
60
- target: 'bun',
61
- outDir: 'dist',
62
- optimization: {
63
- minify: false,
64
- treeshake: false,
65
- compress: false,
66
- splitChunks: false,
67
- bundleAnalyzer: false
68
- },
69
- sourceMaps: true,
70
- clean: true
71
- },
72
- plugins: {
73
- enabled: [],
74
- disabled: [],
75
- config: {
76
- monitoring: {
77
- enabled: true,
78
- httpMetrics: true,
79
- systemMetrics: true,
80
- customMetrics: true,
81
- collectInterval: 1000, // Faster for testing
82
- retentionPeriod: 5000,
83
- exporters: [
84
- {
85
- type: 'console',
86
- interval: 2000,
87
- enabled: true
88
- }
89
- ],
90
- thresholds: {
91
- responseTime: 500,
92
- errorRate: 0.1,
93
- memoryUsage: 0.9,
94
- cpuUsage: 0.9
95
- }
96
- }
97
- }
98
- },
99
- logging: {
100
- level: 'info',
101
- format: 'pretty',
102
- transports: []
103
- },
104
- monitoring: {
105
- enabled: true,
106
- metrics: {
107
- enabled: true,
108
- collectInterval: 5000,
109
- httpMetrics: true,
110
- systemMetrics: true,
111
- customMetrics: true
112
- },
113
- profiling: {
114
- enabled: false,
115
- sampleRate: 0.1,
116
- memoryProfiling: false,
117
- cpuProfiling: false
118
- },
119
- exporters: []
120
- }
121
- }
122
-
123
- describe('Monitoring Plugin', () => {
124
- let context: PluginContext
125
-
126
- beforeEach(() => {
127
- context = {
128
- config: mockConfig,
129
- logger: mockLogger,
130
- app: { use: vi.fn(), get: vi.fn() },
131
- utils: mockUtils
132
- }
133
- vi.clearAllMocks()
134
- })
135
-
136
- afterEach(() => {
137
- // Clean up any intervals that might have been created
138
- const intervals = (context as any).monitoringIntervals as NodeJS.Timeout[]
139
- if (intervals) {
140
- intervals.forEach(interval => clearInterval(interval))
141
- }
142
- })
143
-
144
- describe('Plugin Structure', () => {
145
- it('should have correct metadata', () => {
146
- expect(monitoringPlugin.name).toBe('monitoring')
147
- expect(monitoringPlugin.version).toBe('1.0.0')
148
- expect(monitoringPlugin.priority).toBe('high')
149
- expect(monitoringPlugin.category).toBe('monitoring')
150
- expect(monitoringPlugin.tags).toContain('monitoring')
151
- expect(monitoringPlugin.tags).toContain('metrics')
152
- expect(monitoringPlugin.tags).toContain('performance')
153
- expect(monitoringPlugin.configSchema).toBeDefined()
154
- expect(monitoringPlugin.defaultConfig).toBeDefined()
155
- })
156
-
157
- it('should have all required lifecycle hooks', () => {
158
- expect(monitoringPlugin.setup).toBeDefined()
159
- expect(monitoringPlugin.onServerStart).toBeDefined()
160
- expect(monitoringPlugin.onServerStop).toBeDefined()
161
- expect(monitoringPlugin.onRequest).toBeDefined()
162
- expect(monitoringPlugin.onResponse).toBeDefined()
163
- expect(monitoringPlugin.onError).toBeDefined()
164
- })
165
- })
166
-
167
- describe('Plugin Setup', () => {
168
- it('should setup successfully when enabled', async () => {
169
- await monitoringPlugin.setup!(context)
170
-
171
- expect(mockLogger.info).toHaveBeenCalledWith('Initializing monitoring plugin', expect.any(Object))
172
- expect(mockLogger.info).toHaveBeenCalledWith('Monitoring plugin initialized successfully')
173
- expect((context as any).metricsRegistry).toBeDefined()
174
- })
175
-
176
- it('should skip setup when disabled', async () => {
177
- const disabledConfig = {
178
- ...mockConfig,
179
- plugins: {
180
- ...mockConfig.plugins,
181
- config: {
182
- monitoring: {
183
- enabled: false
184
- }
185
- }
186
- }
187
- }
188
-
189
- const disabledContext = { ...context, config: disabledConfig }
190
- await monitoringPlugin.setup!(disabledContext)
191
-
192
- expect(mockLogger.info).toHaveBeenCalledWith('Monitoring plugin disabled by configuration')
193
- expect((disabledContext as any).metricsRegistry).toBeUndefined()
194
- })
195
-
196
- it('should initialize metrics registry', async () => {
197
- await monitoringPlugin.setup!(context)
198
-
199
- const registry = (context as any).metricsRegistry
200
- expect(registry).toBeDefined()
201
- expect(registry.counters).toBeInstanceOf(Map)
202
- expect(registry.gauges).toBeInstanceOf(Map)
203
- expect(registry.histograms).toBeInstanceOf(Map)
204
- })
205
- })
206
-
207
- describe('Server Lifecycle', () => {
208
- beforeEach(async () => {
209
- await monitoringPlugin.setup!(context)
210
- })
211
-
212
- it('should handle server start', async () => {
213
- await monitoringPlugin.onServerStart!(context)
214
-
215
- expect(mockLogger.info).toHaveBeenCalledWith(
216
- 'Monitoring plugin: Server monitoring started',
217
- expect.objectContaining({
218
- pid: expect.any(Number),
219
- nodeVersion: expect.any(String),
220
- platform: expect.any(String)
221
- })
222
- )
223
-
224
- // Check that server start metric was recorded
225
- const registry = (context as any).metricsRegistry
226
- expect(registry.counters.size).toBeGreaterThan(0)
227
- })
228
-
229
- it('should handle server stop', async () => {
230
- await monitoringPlugin.onServerStop!(context)
231
-
232
- expect(mockLogger.info).toHaveBeenCalledWith('Monitoring plugin: Server monitoring stopped')
233
-
234
- // Check that server stop metric was recorded
235
- const registry = (context as any).metricsRegistry
236
- expect(registry.counters.size).toBeGreaterThan(0)
237
- })
238
- })
239
-
240
- describe('HTTP Metrics', () => {
241
- beforeEach(async () => {
242
- await monitoringPlugin.setup!(context)
243
- })
244
-
245
- it('should record request metrics', async () => {
246
- const requestContext: RequestContext = {
247
- request: new Request('http://localhost:3000/test'),
248
- path: '/test',
249
- method: 'GET',
250
- headers: { 'content-length': '100' },
251
- query: {},
252
- params: {},
253
- startTime: Date.now()
254
- }
255
-
256
- // Add metrics registry to request context for testing
257
- ;(requestContext as any).metricsRegistry = (context as any).metricsRegistry
258
-
259
- await monitoringPlugin.onRequest!(requestContext)
260
-
261
- const registry = (context as any).metricsRegistry
262
- expect(registry.counters.size).toBeGreaterThan(0)
263
- expect(registry.histograms.size).toBeGreaterThan(0)
264
- })
265
-
266
- it('should record response metrics', async () => {
267
- const responseContext: ResponseContext = {
268
- request: new Request('http://localhost:3000/test'),
269
- path: '/test',
270
- method: 'GET',
271
- headers: {},
272
- query: {},
273
- params: {},
274
- startTime: Date.now() - 100,
275
- response: new Response('OK'),
276
- statusCode: 200,
277
- duration: 100,
278
- size: 50
279
- }
280
-
281
- // Add metrics registry to response context for testing
282
- ;(responseContext as any).metricsRegistry = (context as any).metricsRegistry
283
-
284
- await monitoringPlugin.onResponse!(responseContext)
285
-
286
- const registry = (context as any).metricsRegistry
287
- expect(registry.counters.size).toBeGreaterThan(0)
288
- expect(registry.histograms.size).toBeGreaterThan(0)
289
- })
290
-
291
- it('should record error metrics', async () => {
292
- const errorContext: ErrorContext = {
293
- request: new Request('http://localhost:3000/test'),
294
- path: '/test',
295
- method: 'GET',
296
- headers: {},
297
- query: {},
298
- params: {},
299
- startTime: Date.now() - 100,
300
- error: new Error('Test error'),
301
- duration: 100,
302
- handled: false
303
- }
304
-
305
- // Add metrics registry to error context for testing
306
- ;(errorContext as any).metricsRegistry = (context as any).metricsRegistry
307
-
308
- await monitoringPlugin.onError!(errorContext)
309
-
310
- const registry = (context as any).metricsRegistry
311
- expect(registry.counters.size).toBeGreaterThan(0)
312
- expect(registry.histograms.size).toBeGreaterThan(0)
313
- })
314
- })
315
-
316
- describe('System Metrics', () => {
317
- it('should collect system metrics', async () => {
318
- await monitoringPlugin.setup!(context)
319
-
320
- // Wait a bit for system metrics to be collected
321
- await new Promise(resolve => setTimeout(resolve, 1100))
322
-
323
- const registry = (context as any).metricsRegistry
324
- expect(registry.gauges.size).toBeGreaterThan(0)
325
-
326
- // Check for specific system metrics
327
- const gaugeKeys = Array.from(registry.gauges.keys()) as string[]
328
- expect(gaugeKeys.some(key => key.includes('process_memory'))).toBe(true)
329
- expect(gaugeKeys.some(key => key.includes('process_cpu'))).toBe(true)
330
- expect(gaugeKeys.some(key => key.includes('process_uptime'))).toBe(true)
331
- })
332
- })
333
-
334
- describe('Metrics Export', () => {
335
- it('should export metrics to console', async () => {
336
- await monitoringPlugin.setup!(context)
337
-
338
- // Wait for export interval
339
- await new Promise(resolve => setTimeout(resolve, 2100))
340
-
341
- // Should have logged metrics
342
- expect(mockLogger.info).toHaveBeenCalledWith(
343
- 'Metrics snapshot',
344
- expect.objectContaining({
345
- timestamp: expect.any(String),
346
- counters: expect.any(Number),
347
- gauges: expect.any(Number),
348
- histograms: expect.any(Number),
349
- metrics: expect.any(Object)
350
- })
351
- )
352
- })
353
- })
354
-
355
- describe('Configuration', () => {
356
- it('should use default configuration when none provided', async () => {
357
- const contextWithoutConfig = {
358
- ...context,
359
- config: {
360
- ...mockConfig,
361
- plugins: {
362
- ...mockConfig.plugins,
363
- config: {}
364
- }
365
- }
366
- }
367
-
368
- await monitoringPlugin.setup!(contextWithoutConfig)
369
-
370
- // Should still initialize with defaults
371
- expect((contextWithoutConfig as any).metricsRegistry).toBeDefined()
372
- })
373
-
374
- it('should merge custom configuration with defaults', async () => {
375
- const customConfig = {
376
- ...mockConfig,
377
- plugins: {
378
- ...mockConfig.plugins,
379
- config: {
380
- monitoring: {
381
- enabled: true,
382
- httpMetrics: false,
383
- systemMetrics: true
384
- }
385
- }
386
- }
387
- }
388
-
389
- const customContext = { ...context, config: customConfig }
390
- await monitoringPlugin.setup!(customContext)
391
-
392
- expect(mockLogger.info).toHaveBeenCalledWith(
393
- 'Initializing monitoring plugin',
394
- expect.objectContaining({
395
- httpMetrics: false,
396
- systemMetrics: true
397
- })
398
- )
399
- })
400
- })
401
- })