create-fluxstack 1.0.13 → 1.0.15

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 (214) 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/runtime-config.ts +3 -3
  90. package/core/config/schema.ts +84 -49
  91. package/core/framework/server.ts +30 -0
  92. package/core/index.ts +25 -0
  93. package/core/live/ComponentRegistry.ts +399 -0
  94. package/core/live/types.ts +164 -0
  95. package/core/plugins/built-in/live-components/commands/create-live-component.ts +1201 -0
  96. package/core/plugins/built-in/live-components/index.ts +27 -0
  97. package/core/plugins/built-in/logger/index.ts +1 -1
  98. package/core/plugins/built-in/monitoring/index.ts +1 -1
  99. package/core/plugins/built-in/static/index.ts +1 -1
  100. package/core/plugins/built-in/swagger/index.ts +1 -1
  101. package/core/plugins/built-in/vite/index.ts +1 -1
  102. package/core/plugins/dependency-manager.ts +384 -0
  103. package/core/plugins/index.ts +5 -1
  104. package/core/plugins/manager.ts +7 -3
  105. package/core/plugins/registry.ts +88 -10
  106. package/core/plugins/types.ts +11 -11
  107. package/core/server/framework.ts +43 -0
  108. package/core/server/index.ts +11 -1
  109. package/core/server/live/ComponentRegistry.ts +1017 -0
  110. package/core/server/live/FileUploadManager.ts +272 -0
  111. package/core/server/live/LiveComponentPerformanceMonitor.ts +930 -0
  112. package/core/server/live/SingleConnectionManager.ts +0 -0
  113. package/core/server/live/StateSignature.ts +644 -0
  114. package/core/server/live/WebSocketConnectionManager.ts +688 -0
  115. package/core/server/live/websocket-plugin.ts +435 -0
  116. package/core/server/middleware/errorHandling.ts +141 -0
  117. package/core/server/middleware/index.ts +16 -0
  118. package/core/server/plugins/static-files-plugin.ts +232 -0
  119. package/core/server/services/BaseService.ts +95 -0
  120. package/core/server/services/ServiceContainer.ts +144 -0
  121. package/core/server/services/index.ts +9 -0
  122. package/core/templates/create-project.ts +196 -33
  123. package/core/testing/index.ts +10 -0
  124. package/core/testing/setup.ts +74 -0
  125. package/core/types/build.ts +38 -14
  126. package/core/types/types.ts +319 -0
  127. package/core/utils/env-runtime.ts +7 -0
  128. package/core/utils/errors/handlers.ts +264 -39
  129. package/core/utils/errors/index.ts +528 -18
  130. package/core/utils/errors/middleware.ts +114 -0
  131. package/core/utils/logger/formatters.ts +222 -0
  132. package/core/utils/logger/index.ts +167 -48
  133. package/core/utils/logger/middleware.ts +253 -0
  134. package/core/utils/logger/performance.ts +384 -0
  135. package/core/utils/logger/transports.ts +365 -0
  136. package/create-fluxstack.ts +296 -296
  137. package/fluxstack.config.ts +17 -1
  138. package/package-template.json +66 -66
  139. package/package.json +31 -6
  140. package/public/README.md +16 -0
  141. package/vite.config.ts +29 -14
  142. package/.claude/settings.local.json +0 -74
  143. package/.github/workflows/ci-build-tests.yml +0 -480
  144. package/.github/workflows/dependency-management.yml +0 -324
  145. package/.github/workflows/release-validation.yml +0 -355
  146. package/.kiro/specs/fluxstack-architecture-optimization/design.md +0 -700
  147. package/.kiro/specs/fluxstack-architecture-optimization/requirements.md +0 -127
  148. package/.kiro/specs/fluxstack-architecture-optimization/tasks.md +0 -330
  149. package/CLAUDE.md +0 -200
  150. package/Dockerfile +0 -58
  151. package/Dockerfile.backend +0 -52
  152. package/Dockerfile.frontend +0 -54
  153. package/README-Docker.md +0 -85
  154. package/ai-context/00-QUICK-START.md +0 -86
  155. package/ai-context/README.md +0 -88
  156. package/ai-context/development/eden-treaty-guide.md +0 -362
  157. package/ai-context/development/patterns.md +0 -382
  158. package/ai-context/development/plugins-guide.md +0 -572
  159. package/ai-context/examples/crud-complete.md +0 -626
  160. package/ai-context/project/architecture.md +0 -399
  161. package/ai-context/project/overview.md +0 -213
  162. package/ai-context/recent-changes/eden-treaty-refactor.md +0 -281
  163. package/ai-context/recent-changes/type-inference-fix.md +0 -223
  164. package/ai-context/reference/environment-vars.md +0 -384
  165. package/ai-context/reference/troubleshooting.md +0 -407
  166. package/app/client/src/components/TestPage.tsx +0 -453
  167. package/bun.lock +0 -1063
  168. package/bunfig.toml +0 -16
  169. package/core/__tests__/integration.test.ts +0 -227
  170. package/core/build/index.ts +0 -186
  171. package/core/config/__tests__/config-loader.test.ts +0 -554
  172. package/core/config/__tests__/config-merger.test.ts +0 -657
  173. package/core/config/__tests__/env-converter.test.ts +0 -372
  174. package/core/config/__tests__/env-processor.test.ts +0 -431
  175. package/core/config/__tests__/env.test.ts +0 -452
  176. package/core/config/__tests__/integration.test.ts +0 -418
  177. package/core/config/__tests__/loader.test.ts +0 -331
  178. package/core/config/__tests__/schema.test.ts +0 -129
  179. package/core/config/__tests__/validator.test.ts +0 -318
  180. package/core/framework/__tests__/server.test.ts +0 -233
  181. package/core/plugins/__tests__/built-in.test.ts.disabled +0 -366
  182. package/core/plugins/__tests__/manager.test.ts +0 -398
  183. package/core/plugins/__tests__/monitoring.test.ts +0 -401
  184. package/core/plugins/__tests__/registry.test.ts +0 -335
  185. package/core/utils/__tests__/errors.test.ts +0 -139
  186. package/core/utils/__tests__/helpers.test.ts +0 -297
  187. package/core/utils/__tests__/logger.test.ts +0 -141
  188. package/create-test-app.ts +0 -156
  189. package/docker-compose.microservices.yml +0 -75
  190. package/docker-compose.simple.yml +0 -57
  191. package/docker-compose.yml +0 -71
  192. package/eslint.config.js +0 -23
  193. package/flux-cli.ts +0 -214
  194. package/nginx-lb.conf +0 -37
  195. package/publish.sh +0 -63
  196. package/run-clean.ts +0 -26
  197. package/run-env-tests.ts +0 -313
  198. package/tailwind.config.js +0 -34
  199. package/tests/__mocks__/api.ts +0 -56
  200. package/tests/fixtures/users.ts +0 -69
  201. package/tests/integration/api/users.routes.test.ts +0 -221
  202. package/tests/setup.ts +0 -29
  203. package/tests/unit/app/client/App-simple.test.tsx +0 -56
  204. package/tests/unit/app/client/App.test.tsx.skip +0 -237
  205. package/tests/unit/app/client/eden-api.test.ts +0 -186
  206. package/tests/unit/app/client/simple.test.tsx +0 -23
  207. package/tests/unit/app/controllers/users.controller.test.ts +0 -150
  208. package/tests/unit/core/create-project.test.ts.skip +0 -95
  209. package/tests/unit/core/framework.test.ts +0 -144
  210. package/tests/unit/core/plugins/logger.test.ts.skip +0 -268
  211. package/tests/unit/core/plugins/vite.test.ts.disabled +0 -188
  212. package/tests/utils/test-helpers.ts +0 -61
  213. package/vitest.config.ts +0 -50
  214. package/workspace.json +0 -6
@@ -1,452 +0,0 @@
1
- /**
2
- * Tests for Environment Configuration System
3
- */
4
-
5
- import { describe, it, expect, beforeEach, afterEach } from 'vitest'
6
- import {
7
- getEnvironmentInfo,
8
- EnvConverter,
9
- EnvironmentProcessor,
10
- ConfigMerger,
11
- EnvironmentConfigApplier,
12
- isDevelopment,
13
- isProduction,
14
- isTest,
15
- getEnvironmentRecommendations
16
- } from '../env'
17
- import { defaultFluxStackConfig } from '../schema'
18
-
19
- describe('Environment Configuration System', () => {
20
- const originalEnv = { ...process.env }
21
-
22
- beforeEach(() => {
23
- // Clean environment
24
- Object.keys(process.env).forEach(key => {
25
- if (key.startsWith('FLUXSTACK_') || key.startsWith('TEST_')) {
26
- delete process.env[key]
27
- }
28
- })
29
- })
30
-
31
- afterEach(() => {
32
- // Restore original environment
33
- process.env = { ...originalEnv }
34
- })
35
-
36
- describe('getEnvironmentInfo', () => {
37
- it('should return development info by default', () => {
38
- delete process.env.NODE_ENV
39
- const info = getEnvironmentInfo()
40
-
41
- expect(info.name).toBe('development')
42
- expect(info.isDevelopment).toBe(true)
43
- expect(info.isProduction).toBe(false)
44
- expect(info.isTest).toBe(false)
45
- expect(info.nodeEnv).toBe('development')
46
- })
47
-
48
- it('should detect production environment', () => {
49
- process.env.NODE_ENV = 'production'
50
- const info = getEnvironmentInfo()
51
-
52
- expect(info.name).toBe('production')
53
- expect(info.isDevelopment).toBe(false)
54
- expect(info.isProduction).toBe(true)
55
- expect(info.isTest).toBe(false)
56
- })
57
-
58
- it('should detect test environment', () => {
59
- process.env.NODE_ENV = 'test'
60
- const info = getEnvironmentInfo()
61
-
62
- expect(info.name).toBe('test')
63
- expect(info.isDevelopment).toBe(false)
64
- expect(info.isProduction).toBe(false)
65
- expect(info.isTest).toBe(true)
66
- })
67
- })
68
-
69
- describe('EnvConverter', () => {
70
- describe('toNumber', () => {
71
- it('should convert valid numbers', () => {
72
- expect(EnvConverter.toNumber('123', 0)).toBe(123)
73
- expect(EnvConverter.toNumber('0', 100)).toBe(0)
74
- expect(EnvConverter.toNumber('-50', 0)).toBe(-50)
75
- })
76
-
77
- it('should return default for invalid numbers', () => {
78
- expect(EnvConverter.toNumber('abc', 42)).toBe(42)
79
- expect(EnvConverter.toNumber('', 100)).toBe(100)
80
- expect(EnvConverter.toNumber(undefined, 200)).toBe(200)
81
- })
82
- })
83
-
84
- describe('toBoolean', () => {
85
- it('should convert truthy values', () => {
86
- expect(EnvConverter.toBoolean('true', false)).toBe(true)
87
- expect(EnvConverter.toBoolean('1', false)).toBe(true)
88
- expect(EnvConverter.toBoolean('yes', false)).toBe(true)
89
- expect(EnvConverter.toBoolean('on', false)).toBe(true)
90
- expect(EnvConverter.toBoolean('TRUE', false)).toBe(true)
91
- })
92
-
93
- it('should convert falsy values', () => {
94
- expect(EnvConverter.toBoolean('false', true)).toBe(false)
95
- expect(EnvConverter.toBoolean('0', true)).toBe(false)
96
- expect(EnvConverter.toBoolean('no', true)).toBe(false)
97
- expect(EnvConverter.toBoolean('off', true)).toBe(false)
98
- })
99
-
100
- it('should return default for undefined', () => {
101
- expect(EnvConverter.toBoolean(undefined, true)).toBe(true)
102
- expect(EnvConverter.toBoolean(undefined, false)).toBe(false)
103
- })
104
- })
105
-
106
- describe('toArray', () => {
107
- it('should convert comma-separated values', () => {
108
- expect(EnvConverter.toArray('a,b,c')).toEqual(['a', 'b', 'c'])
109
- expect(EnvConverter.toArray('one, two, three')).toEqual(['one', 'two', 'three'])
110
- expect(EnvConverter.toArray('single')).toEqual(['single'])
111
- })
112
-
113
- it('should handle empty values', () => {
114
- expect(EnvConverter.toArray('')).toEqual([])
115
- expect(EnvConverter.toArray(undefined)).toEqual([])
116
- expect(EnvConverter.toArray('a,,b')).toEqual(['a', 'b']) // Filters empty strings
117
- })
118
- })
119
-
120
- describe('toLogLevel', () => {
121
- it('should convert valid log levels', () => {
122
- expect(EnvConverter.toLogLevel('debug', 'info')).toBe('debug')
123
- expect(EnvConverter.toLogLevel('INFO', 'debug')).toBe('info')
124
- expect(EnvConverter.toLogLevel('warn', 'info')).toBe('warn')
125
- expect(EnvConverter.toLogLevel('error', 'info')).toBe('error')
126
- })
127
-
128
- it('should return default for invalid levels', () => {
129
- expect(EnvConverter.toLogLevel('invalid', 'info')).toBe('info')
130
- expect(EnvConverter.toLogLevel(undefined, 'warn')).toBe('warn')
131
- })
132
- })
133
-
134
- describe('toObject', () => {
135
- it('should parse valid JSON', () => {
136
- expect(EnvConverter.toObject('{"key": "value"}', {})).toEqual({ key: 'value' })
137
- expect(EnvConverter.toObject('[1,2,3]', [] as any)).toEqual([1, 2, 3])
138
- })
139
-
140
- it('should return default for invalid JSON', () => {
141
- expect(EnvConverter.toObject('invalid-json', { default: true })).toEqual({ default: true })
142
- expect(EnvConverter.toObject(undefined, null)).toBe(null)
143
- })
144
- })
145
- })
146
-
147
- describe('EnvironmentProcessor', () => {
148
- it('should process basic environment variables', () => {
149
- process.env.PORT = '4000'
150
- process.env.HOST = 'example.com'
151
- process.env.FLUXSTACK_APP_NAME = 'test-app'
152
-
153
- const processor = new EnvironmentProcessor()
154
- const config = processor.processEnvironmentVariables()
155
-
156
- expect(config.server?.port).toBe(4000)
157
- expect(config.server?.host).toBe('example.com')
158
- expect(config.app?.name).toBe('test-app')
159
- })
160
-
161
- it('should process CORS configuration', () => {
162
- process.env.CORS_ORIGINS = 'http://localhost:3000,https://example.com'
163
- process.env.CORS_METHODS = 'GET,POST,PUT'
164
- process.env.CORS_CREDENTIALS = 'true'
165
-
166
- const processor = new EnvironmentProcessor()
167
- const config = processor.processEnvironmentVariables()
168
-
169
- expect(config.server?.cors?.origins).toEqual(['http://localhost:3000', 'https://example.com'])
170
- expect(config.server?.cors?.methods).toEqual(['GET', 'POST', 'PUT'])
171
- expect(config.server?.cors?.credentials).toBe(true)
172
- })
173
-
174
- it('should process build configuration', () => {
175
- process.env.BUILD_TARGET = 'node'
176
- process.env.BUILD_MINIFY = 'false'
177
- process.env.BUILD_SOURCEMAPS = 'true'
178
-
179
- const processor = new EnvironmentProcessor()
180
- const config = processor.processEnvironmentVariables()
181
-
182
- expect(config.build?.target).toBe('node')
183
- expect(config.build?.optimization?.minify).toBe(false)
184
- expect(config.build?.sourceMaps).toBe(true)
185
- })
186
-
187
- it('should process optional database configuration', () => {
188
- process.env.DATABASE_URL = 'postgresql://localhost:5432/test'
189
- process.env.DATABASE_SSL = 'true'
190
- process.env.DATABASE_POOL_SIZE = '10'
191
-
192
- const processor = new EnvironmentProcessor()
193
- const config = processor.processEnvironmentVariables()
194
-
195
- expect(config.database?.url).toBe('postgresql://localhost:5432/test')
196
- expect(config.database?.ssl).toBe(true)
197
- expect(config.database?.poolSize).toBe(10)
198
- })
199
-
200
- it('should track precedence information', () => {
201
- process.env.PORT = '5000'
202
- process.env.FLUXSTACK_APP_NAME = 'precedence-test'
203
-
204
- const processor = new EnvironmentProcessor()
205
- processor.processEnvironmentVariables()
206
-
207
- const precedence = processor.getPrecedenceInfo()
208
-
209
- expect(precedence.has('server.port')).toBe(true)
210
- expect(precedence.has('app.name')).toBe(true)
211
- expect(precedence.get('server.port')?.source).toBe('environment')
212
- expect(precedence.get('server.port')?.priority).toBe(3)
213
- })
214
- })
215
-
216
- describe('ConfigMerger', () => {
217
- it('should merge configurations with precedence', () => {
218
- const merger = new ConfigMerger()
219
-
220
- const baseConfig = {
221
- app: { name: 'base-app', version: '1.0.0' },
222
- server: {
223
- port: 3000,
224
- host: 'localhost',
225
- apiPrefix: '/api',
226
- cors: {
227
- origins: ['*'],
228
- methods: ['GET', 'POST'],
229
- headers: ['Content-Type'],
230
- credentials: false,
231
- maxAge: 86400
232
- },
233
- middleware: []
234
- }
235
- }
236
-
237
- const envConfig = {
238
- server: {
239
- port: 4000,
240
- host: 'localhost',
241
- apiPrefix: '/api',
242
- cors: {
243
- origins: ['*'],
244
- methods: ['GET', 'POST'],
245
- headers: ['Content-Type'],
246
- credentials: false,
247
- maxAge: 86400
248
- },
249
- middleware: []
250
- },
251
- logging: {
252
- level: 'debug' as const,
253
- format: 'pretty' as const,
254
- transports: [{ type: 'console' as const, level: 'debug' as const, format: 'pretty' as const }]
255
- }
256
- }
257
-
258
- const result = merger.merge(
259
- { config: baseConfig, source: 'file' },
260
- { config: envConfig, source: 'environment' }
261
- )
262
-
263
- expect(result.app.name).toBe('base-app') // From base
264
- expect(result.server.port).toBe(4000) // Overridden by env
265
- expect(result.server.host).toBe('localhost') // From base
266
- expect(result.logging?.level).toBe('debug') // From env
267
- })
268
-
269
- it('should handle nested object merging', () => {
270
- const merger = new ConfigMerger()
271
-
272
- const config1 = {
273
- server: {
274
- port: 3000,
275
- host: 'localhost',
276
- apiPrefix: '/api',
277
- cors: {
278
- origins: ['http://localhost:3000'],
279
- methods: ['GET', 'POST'],
280
- headers: ['Content-Type'],
281
- credentials: false,
282
- maxAge: 86400
283
- },
284
- middleware: []
285
- }
286
- }
287
-
288
- const config2 = {
289
- server: {
290
- port: 3000,
291
- host: 'localhost',
292
- apiPrefix: '/api',
293
- cors: {
294
- origins: ['https://example.com'],
295
- methods: ['GET', 'POST'],
296
- headers: ['Content-Type'],
297
- credentials: true,
298
- maxAge: 86400
299
- },
300
- middleware: []
301
- }
302
- }
303
-
304
- const result = merger.merge(
305
- { config: config1, source: 'default' },
306
- { config: config2, source: 'environment' }
307
- )
308
-
309
- expect(result.server.cors.origins).toEqual(['https://example.com'])
310
- expect(result.server.cors.methods).toEqual(['GET', 'POST'])
311
- expect(result.server.cors.credentials).toBe(true)
312
- })
313
- })
314
-
315
- describe('EnvironmentConfigApplier', () => {
316
- it('should apply environment-specific configuration', () => {
317
- const applier = new EnvironmentConfigApplier()
318
-
319
- const baseConfig = {
320
- ...defaultFluxStackConfig,
321
- environments: {
322
- production: {
323
- logging: {
324
- level: 'error' as const,
325
- format: 'json' as const,
326
- transports: [{ type: 'console' as const, level: 'error' as const, format: 'json' as const }]
327
- },
328
- monitoring: {
329
- enabled: true,
330
- metrics: {
331
- enabled: true,
332
- collectInterval: 30000,
333
- httpMetrics: true,
334
- systemMetrics: true,
335
- customMetrics: false
336
- },
337
- profiling: {
338
- enabled: true,
339
- sampleRate: 0.01,
340
- memoryProfiling: true,
341
- cpuProfiling: true
342
- },
343
- exporters: ['prometheus']
344
- }
345
- }
346
- }
347
- }
348
-
349
- const result = applier.applyEnvironmentConfig(baseConfig, 'production')
350
-
351
- expect(result.logging.level).toBe('error')
352
- expect(result.monitoring.enabled).toBe(true)
353
- })
354
-
355
- it('should get available environments', () => {
356
- const applier = new EnvironmentConfigApplier()
357
-
358
- const config = {
359
- ...defaultFluxStackConfig,
360
- environments: {
361
- staging: {},
362
- production: {},
363
- custom: {}
364
- }
365
- }
366
-
367
- const environments = applier.getAvailableEnvironments(config)
368
-
369
- expect(environments).toEqual(['staging', 'production', 'custom'])
370
- })
371
-
372
- it('should validate environment configuration', () => {
373
- const applier = new EnvironmentConfigApplier()
374
-
375
- const config = {
376
- ...defaultFluxStackConfig,
377
- environments: {
378
- production: {
379
- logging: {
380
- level: 'debug' as const,
381
- format: 'json' as const,
382
- transports: [{ type: 'console' as const, level: 'debug' as const, format: 'json' as const }]
383
- } // Bad for production
384
- }
385
- }
386
- }
387
-
388
- const result = applier.validateEnvironmentConfig(config, 'production')
389
-
390
- expect(result.valid).toBe(false)
391
- expect(result.errors.some(e => e.includes('debug'))).toBe(true)
392
- })
393
- })
394
-
395
- describe('Environment Helper Functions', () => {
396
- it('should detect development environment', () => {
397
- process.env.NODE_ENV = 'development'
398
- expect(isDevelopment()).toBe(true)
399
- expect(isProduction()).toBe(false)
400
- expect(isTest()).toBe(false)
401
- })
402
-
403
- it('should detect production environment', () => {
404
- process.env.NODE_ENV = 'production'
405
- expect(isDevelopment()).toBe(false)
406
- expect(isProduction()).toBe(true)
407
- expect(isTest()).toBe(false)
408
- })
409
-
410
- it('should detect test environment', () => {
411
- process.env.NODE_ENV = 'test'
412
- expect(isDevelopment()).toBe(false)
413
- expect(isProduction()).toBe(false)
414
- expect(isTest()).toBe(true)
415
- })
416
- })
417
-
418
- describe('getEnvironmentRecommendations', () => {
419
- it('should provide development recommendations', () => {
420
- const recommendations = getEnvironmentRecommendations('development')
421
-
422
- expect(recommendations.logging?.level).toBe('debug')
423
- expect(recommendations.logging?.format).toBe('pretty')
424
- expect(recommendations.build?.optimization?.minify).toBe(false)
425
- expect(recommendations.monitoring?.enabled).toBe(false)
426
- })
427
-
428
- it('should provide production recommendations', () => {
429
- const recommendations = getEnvironmentRecommendations('production')
430
-
431
- expect(recommendations.logging?.level).toBe('warn')
432
- expect(recommendations.logging?.format).toBe('json')
433
- expect(recommendations.build?.optimization?.minify).toBe(true)
434
- expect(recommendations.monitoring?.enabled).toBe(true)
435
- })
436
-
437
- it('should provide test recommendations', () => {
438
- const recommendations = getEnvironmentRecommendations('test')
439
-
440
- expect(recommendations.logging?.level).toBe('error')
441
- expect(recommendations.server?.port).toBe(0)
442
- expect(recommendations.client?.port).toBe(0)
443
- expect(recommendations.monitoring?.enabled).toBe(false)
444
- })
445
-
446
- it('should return empty for unknown environments', () => {
447
- const recommendations = getEnvironmentRecommendations('unknown')
448
-
449
- expect(Object.keys(recommendations)).toHaveLength(0)
450
- })
451
- })
452
- })