@l4yercak3/cli 1.3.1 → 2.0.0-alpha.0

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 (357) hide show
  1. package/README.md +10 -220
  2. package/dist/api/client.d.ts +12 -0
  3. package/dist/api/client.d.ts.map +1 -0
  4. package/dist/api/client.js +37 -0
  5. package/dist/api/client.js.map +1 -0
  6. package/dist/api/platform.d.ts +161 -0
  7. package/dist/api/platform.d.ts.map +1 -0
  8. package/dist/api/platform.js +70 -0
  9. package/dist/api/platform.js.map +1 -0
  10. package/dist/bin/sevenlayers.d.ts +3 -0
  11. package/dist/bin/sevenlayers.d.ts.map +1 -0
  12. package/dist/bin/sevenlayers.js +198 -0
  13. package/dist/bin/sevenlayers.js.map +1 -0
  14. package/dist/commands/agent/catalog.d.ts +5 -0
  15. package/dist/commands/agent/catalog.d.ts.map +1 -0
  16. package/dist/commands/agent/catalog.js +142 -0
  17. package/dist/commands/agent/catalog.js.map +1 -0
  18. package/dist/commands/agent/drift.d.ts +5 -0
  19. package/dist/commands/agent/drift.d.ts.map +1 -0
  20. package/dist/commands/agent/drift.js +113 -0
  21. package/dist/commands/agent/drift.js.map +1 -0
  22. package/dist/commands/agent/init.d.ts +5 -0
  23. package/dist/commands/agent/init.d.ts.map +1 -0
  24. package/dist/commands/agent/init.js +75 -0
  25. package/dist/commands/agent/init.js.map +1 -0
  26. package/dist/commands/agent/permissions.d.ts +5 -0
  27. package/dist/commands/agent/permissions.d.ts.map +1 -0
  28. package/dist/commands/agent/permissions.js +88 -0
  29. package/dist/commands/agent/permissions.js.map +1 -0
  30. package/dist/commands/agent/runner.d.ts +14 -0
  31. package/dist/commands/agent/runner.d.ts.map +1 -0
  32. package/dist/commands/agent/runner.js +59 -0
  33. package/dist/commands/agent/runner.js.map +1 -0
  34. package/dist/commands/agent/shared.d.ts +13 -0
  35. package/dist/commands/agent/shared.d.ts.map +1 -0
  36. package/dist/commands/agent/shared.js +31 -0
  37. package/dist/commands/agent/shared.js.map +1 -0
  38. package/dist/commands/agent/template.d.ts +5 -0
  39. package/dist/commands/agent/template.d.ts.map +1 -0
  40. package/dist/commands/agent/template.js +104 -0
  41. package/dist/commands/agent/template.js.map +1 -0
  42. package/dist/commands/app/connect.d.ts +7 -0
  43. package/dist/commands/app/connect.d.ts.map +1 -0
  44. package/dist/commands/app/connect.js +12 -0
  45. package/dist/commands/app/connect.js.map +1 -0
  46. package/dist/commands/app/init.d.ts +7 -0
  47. package/dist/commands/app/init.d.ts.map +1 -0
  48. package/dist/commands/app/init.js +12 -0
  49. package/dist/commands/app/init.js.map +1 -0
  50. package/dist/commands/app/link.d.ts +3 -0
  51. package/dist/commands/app/link.d.ts.map +1 -0
  52. package/dist/commands/app/link.js +92 -0
  53. package/dist/commands/app/link.js.map +1 -0
  54. package/dist/commands/app/pages.d.ts +15 -0
  55. package/dist/commands/app/pages.d.ts.map +1 -0
  56. package/dist/commands/app/pages.js +180 -0
  57. package/dist/commands/app/pages.js.map +1 -0
  58. package/dist/commands/app/register.d.ts +3 -0
  59. package/dist/commands/app/register.d.ts.map +1 -0
  60. package/dist/commands/app/register.js +120 -0
  61. package/dist/commands/app/register.js.map +1 -0
  62. package/dist/commands/app/remote.d.ts +14 -0
  63. package/dist/commands/app/remote.d.ts.map +1 -0
  64. package/dist/commands/app/remote.js +44 -0
  65. package/dist/commands/app/remote.js.map +1 -0
  66. package/dist/commands/app/setup.d.ts +3 -0
  67. package/dist/commands/app/setup.d.ts.map +1 -0
  68. package/dist/commands/app/setup.js +299 -0
  69. package/dist/commands/app/setup.js.map +1 -0
  70. package/dist/commands/app/shared.d.ts +9 -0
  71. package/dist/commands/app/shared.d.ts.map +1 -0
  72. package/dist/commands/app/shared.js +122 -0
  73. package/dist/commands/app/shared.js.map +1 -0
  74. package/dist/commands/app/sync.d.ts +7 -0
  75. package/dist/commands/app/sync.d.ts.map +1 -0
  76. package/dist/commands/app/sync.js +107 -0
  77. package/dist/commands/app/sync.js.map +1 -0
  78. package/dist/commands/booking/check.d.ts +3 -0
  79. package/dist/commands/booking/check.d.ts.map +1 -0
  80. package/dist/commands/booking/check.js +68 -0
  81. package/dist/commands/booking/check.js.map +1 -0
  82. package/dist/commands/booking/setup.d.ts +3 -0
  83. package/dist/commands/booking/setup.d.ts.map +1 -0
  84. package/dist/commands/booking/setup.js +95 -0
  85. package/dist/commands/booking/setup.js.map +1 -0
  86. package/dist/commands/booking/shared.d.ts +31 -0
  87. package/dist/commands/booking/shared.d.ts.map +1 -0
  88. package/dist/commands/booking/shared.js +112 -0
  89. package/dist/commands/booking/shared.js.map +1 -0
  90. package/dist/commands/booking/smoke.d.ts +3 -0
  91. package/dist/commands/booking/smoke.d.ts.map +1 -0
  92. package/dist/commands/booking/smoke.js +101 -0
  93. package/dist/commands/booking/smoke.js.map +1 -0
  94. package/dist/commands/cms/bind.d.ts +3 -0
  95. package/dist/commands/cms/bind.d.ts.map +1 -0
  96. package/dist/commands/cms/bind.js +212 -0
  97. package/dist/commands/cms/bind.js.map +1 -0
  98. package/dist/commands/cms/content.d.ts +40 -0
  99. package/dist/commands/cms/content.d.ts.map +1 -0
  100. package/dist/commands/cms/content.js +169 -0
  101. package/dist/commands/cms/content.js.map +1 -0
  102. package/dist/commands/cms/doctor.d.ts +3 -0
  103. package/dist/commands/cms/doctor.d.ts.map +1 -0
  104. package/dist/commands/cms/doctor.js +69 -0
  105. package/dist/commands/cms/doctor.js.map +1 -0
  106. package/dist/commands/cms/migrate.d.ts +3 -0
  107. package/dist/commands/cms/migrate.d.ts.map +1 -0
  108. package/dist/commands/cms/migrate.js +78 -0
  109. package/dist/commands/cms/migrate.js.map +1 -0
  110. package/dist/commands/cms/registry.d.ts +3 -0
  111. package/dist/commands/cms/registry.d.ts.map +1 -0
  112. package/dist/commands/cms/registry.js +161 -0
  113. package/dist/commands/cms/registry.js.map +1 -0
  114. package/dist/commands/cms/seed.d.ts +3 -0
  115. package/dist/commands/cms/seed.d.ts.map +1 -0
  116. package/dist/commands/cms/seed.js +102 -0
  117. package/dist/commands/cms/seed.js.map +1 -0
  118. package/dist/commands/cms/shared.d.ts +22 -0
  119. package/dist/commands/cms/shared.d.ts.map +1 -0
  120. package/dist/commands/cms/shared.js +82 -0
  121. package/dist/commands/cms/shared.js.map +1 -0
  122. package/dist/commands/doctor/target.d.ts +3 -0
  123. package/dist/commands/doctor/target.d.ts.map +1 -0
  124. package/dist/commands/doctor/target.js +46 -0
  125. package/dist/commands/doctor/target.js.map +1 -0
  126. package/dist/commands/env/list.d.ts +3 -0
  127. package/dist/commands/env/list.d.ts.map +1 -0
  128. package/dist/commands/env/list.js +28 -0
  129. package/dist/commands/env/list.js.map +1 -0
  130. package/dist/commands/env/set.d.ts +3 -0
  131. package/dist/commands/env/set.d.ts.map +1 -0
  132. package/dist/commands/env/set.js +36 -0
  133. package/dist/commands/env/set.js.map +1 -0
  134. package/dist/commands/env/use.d.ts +3 -0
  135. package/dist/commands/env/use.d.ts.map +1 -0
  136. package/dist/commands/env/use.js +15 -0
  137. package/dist/commands/env/use.js.map +1 -0
  138. package/dist/commands/legacy/connect.d.ts +3 -0
  139. package/dist/commands/legacy/connect.d.ts.map +1 -0
  140. package/dist/commands/legacy/connect.js +8 -0
  141. package/dist/commands/legacy/connect.js.map +1 -0
  142. package/dist/commands/legacy/pages.d.ts +3 -0
  143. package/dist/commands/legacy/pages.d.ts.map +1 -0
  144. package/dist/commands/legacy/pages.js +16 -0
  145. package/dist/commands/legacy/pages.js.map +1 -0
  146. package/dist/commands/legacy/spread.d.ts +3 -0
  147. package/dist/commands/legacy/spread.d.ts.map +1 -0
  148. package/dist/commands/legacy/spread.js +8 -0
  149. package/dist/commands/legacy/spread.js.map +1 -0
  150. package/dist/commands/legacy/sync.d.ts +3 -0
  151. package/dist/commands/legacy/sync.d.ts.map +1 -0
  152. package/dist/commands/legacy/sync.js +8 -0
  153. package/dist/commands/legacy/sync.js.map +1 -0
  154. package/dist/config/env-diff.d.ts +10 -0
  155. package/dist/config/env-diff.d.ts.map +1 -0
  156. package/dist/config/env-diff.js +24 -0
  157. package/dist/config/env-diff.js.map +1 -0
  158. package/dist/config/env-parser.d.ts +20 -0
  159. package/dist/config/env-parser.d.ts.map +1 -0
  160. package/dist/config/env-parser.js +70 -0
  161. package/dist/config/env-parser.js.map +1 -0
  162. package/dist/config/env-writer.d.ts +22 -0
  163. package/dist/config/env-writer.d.ts.map +1 -0
  164. package/dist/config/env-writer.js +172 -0
  165. package/dist/config/env-writer.js.map +1 -0
  166. package/dist/config/profile-store.d.ts +29 -0
  167. package/dist/config/profile-store.d.ts.map +1 -0
  168. package/dist/config/profile-store.js +257 -0
  169. package/dist/config/profile-store.js.map +1 -0
  170. package/dist/core/args.d.ts +11 -0
  171. package/dist/core/args.d.ts.map +1 -0
  172. package/dist/core/args.js +106 -0
  173. package/dist/core/args.js.map +1 -0
  174. package/dist/core/colors.d.ts +6 -0
  175. package/dist/core/colors.d.ts.map +1 -0
  176. package/dist/core/colors.js +29 -0
  177. package/dist/core/colors.js.map +1 -0
  178. package/dist/safety/target-guard.d.ts +16 -0
  179. package/dist/safety/target-guard.d.ts.map +1 -0
  180. package/dist/safety/target-guard.js +55 -0
  181. package/dist/safety/target-guard.js.map +1 -0
  182. package/dist/testing/booking-smoke.d.ts +17 -0
  183. package/dist/testing/booking-smoke.d.ts.map +1 -0
  184. package/dist/testing/booking-smoke.js +43 -0
  185. package/dist/testing/booking-smoke.js.map +1 -0
  186. package/dist/tests/agent-commands.test.d.ts +2 -0
  187. package/dist/tests/agent-commands.test.d.ts.map +1 -0
  188. package/dist/tests/agent-commands.test.js +180 -0
  189. package/dist/tests/agent-commands.test.js.map +1 -0
  190. package/dist/tests/agent-governance.test.d.ts +2 -0
  191. package/dist/tests/agent-governance.test.d.ts.map +1 -0
  192. package/dist/tests/agent-governance.test.js +233 -0
  193. package/dist/tests/agent-governance.test.js.map +1 -0
  194. package/dist/tests/app-commands.test.d.ts +2 -0
  195. package/dist/tests/app-commands.test.d.ts.map +1 -0
  196. package/dist/tests/app-commands.test.js +462 -0
  197. package/dist/tests/app-commands.test.js.map +1 -0
  198. package/dist/tests/booking-commands.test.d.ts +2 -0
  199. package/dist/tests/booking-commands.test.d.ts.map +1 -0
  200. package/dist/tests/booking-commands.test.js +204 -0
  201. package/dist/tests/booking-commands.test.js.map +1 -0
  202. package/dist/tests/booking-smoke.test.d.ts +2 -0
  203. package/dist/tests/booking-smoke.test.d.ts.map +1 -0
  204. package/dist/tests/booking-smoke.test.js +183 -0
  205. package/dist/tests/booking-smoke.test.js.map +1 -0
  206. package/dist/tests/cms-commands.test.d.ts +2 -0
  207. package/dist/tests/cms-commands.test.d.ts.map +1 -0
  208. package/dist/tests/cms-commands.test.js +254 -0
  209. package/dist/tests/cms-commands.test.js.map +1 -0
  210. package/dist/tests/cms-ops.test.d.ts +2 -0
  211. package/dist/tests/cms-ops.test.d.ts.map +1 -0
  212. package/dist/tests/cms-ops.test.js +125 -0
  213. package/dist/tests/cms-ops.test.js.map +1 -0
  214. package/dist/tests/env-writer.test.d.ts +2 -0
  215. package/dist/tests/env-writer.test.d.ts.map +1 -0
  216. package/dist/tests/env-writer.test.js +90 -0
  217. package/dist/tests/env-writer.test.js.map +1 -0
  218. package/dist/tests/profile-store.test.d.ts +2 -0
  219. package/dist/tests/profile-store.test.d.ts.map +1 -0
  220. package/dist/tests/profile-store.test.js +88 -0
  221. package/dist/tests/profile-store.test.js.map +1 -0
  222. package/dist/tests/target-guard.test.d.ts +2 -0
  223. package/dist/tests/target-guard.test.d.ts.map +1 -0
  224. package/dist/tests/target-guard.test.js +132 -0
  225. package/dist/tests/target-guard.test.js.map +1 -0
  226. package/dist/ui/logo.d.ts +2 -0
  227. package/dist/ui/logo.d.ts.map +1 -0
  228. package/dist/ui/logo.js +22 -0
  229. package/dist/ui/logo.js.map +1 -0
  230. package/package.json +17 -53
  231. package/.claude/settings.local.json +0 -36
  232. package/.cursor/rules.md +0 -203
  233. package/.eslintrc.js +0 -31
  234. package/CLAUDE.md +0 -100
  235. package/bin/cli.js +0 -116
  236. package/docs/ADDING_FRAMEWORK_DETECTORS.md +0 -391
  237. package/docs/ADDING_NEW_PROJECT_TYPE.md +0 -156
  238. package/docs/ARCHITECTURE_RELATIONSHIPS.md +0 -411
  239. package/docs/CLI_AUTHENTICATION.md +0 -214
  240. package/docs/CLI_PAGE_DETECTION_REQUIREMENTS.md +0 -519
  241. package/docs/CRM-PIPELINES-SEQUENCES-SPEC.md +0 -429
  242. package/docs/DETECTOR_ARCHITECTURE.md +0 -326
  243. package/docs/DEVELOPMENT.md +0 -194
  244. package/docs/IMPLEMENTATION_PHASES.md +0 -468
  245. package/docs/INTEGRATION_PATHS_ARCHITECTURE.md +0 -1543
  246. package/docs/OAUTH_CLARIFICATION.md +0 -258
  247. package/docs/OAUTH_SETUP_GUIDE_TEMPLATE.md +0 -211
  248. package/docs/PHASE_0_PROGRESS.md +0 -120
  249. package/docs/PHASE_1_COMPLETE.md +0 -366
  250. package/docs/PHASE_SUMMARY.md +0 -149
  251. package/docs/PLAN.md +0 -511
  252. package/docs/README.md +0 -56
  253. package/docs/STRIPE_INTEGRATION.md +0 -447
  254. package/docs/SUMMARY.md +0 -230
  255. package/docs/UPDATED_PLAN.md +0 -447
  256. package/docs/mcp_server/MCP_EXTENSION_GUIDE.md +0 -1313
  257. package/docs/mcp_server/MCP_SERVER_ARCHITECTURE.md +0 -1481
  258. package/docs/mcp_server/applicationOntology.ts +0 -817
  259. package/docs/mcp_server/cliApplications.ts +0 -639
  260. package/docs/mcp_server/crmOntology.ts +0 -1063
  261. package/docs/mcp_server/eventOntology.ts +0 -1183
  262. package/docs/mcp_server/formsOntology.ts +0 -1401
  263. package/docs/mcp_server/ontologySchemas.ts +0 -185
  264. package/docs/mcp_server/schema.ts +0 -250
  265. package/docs/microsass_production_machine/CLI_API_REFERENCE.md +0 -1197
  266. package/docs/microsass_production_machine/CLI_PRODUCT_VISION.md +0 -676
  267. package/docs/microsass_production_machine/CLI_REQUIREMENTS.md +0 -606
  268. package/docs/microsass_production_machine/CONNECTED_APPLICATIONS_SPEC.md +0 -390
  269. package/docs/microsass_production_machine/IMPLEMENTATION_ROADMAP.md +0 -725
  270. package/docs/microsass_production_machine/OBJECT_MAPPINGS.md +0 -808
  271. package/docs/microsass_production_machine/REFERENCE_IMPLEMENTATION.md +0 -532
  272. package/src/api/backend-client.js +0 -449
  273. package/src/commands/api-keys.js +0 -119
  274. package/src/commands/connect.js +0 -243
  275. package/src/commands/login.js +0 -332
  276. package/src/commands/logout.js +0 -30
  277. package/src/commands/mcp-server.js +0 -85
  278. package/src/commands/mcp-setup.js +0 -686
  279. package/src/commands/pages.js +0 -317
  280. package/src/commands/scaffold.js +0 -409
  281. package/src/commands/spread.js +0 -861
  282. package/src/commands/status.js +0 -62
  283. package/src/commands/sync.js +0 -169
  284. package/src/commands/upgrade.js +0 -48
  285. package/src/config/config-manager.js +0 -206
  286. package/src/detectors/api-client-detector.js +0 -85
  287. package/src/detectors/base-detector.js +0 -77
  288. package/src/detectors/database-detector.js +0 -245
  289. package/src/detectors/expo-detector.js +0 -166
  290. package/src/detectors/github-detector.js +0 -74
  291. package/src/detectors/index.js +0 -106
  292. package/src/detectors/mapping-suggestor.js +0 -119
  293. package/src/detectors/model-detector.js +0 -318
  294. package/src/detectors/nextjs-detector.js +0 -139
  295. package/src/detectors/oauth-detector.js +0 -122
  296. package/src/detectors/page-detector.js +0 -480
  297. package/src/detectors/registry.js +0 -121
  298. package/src/generators/api-client-generator.js +0 -223
  299. package/src/generators/api-only/client.js +0 -683
  300. package/src/generators/api-only/index.js +0 -96
  301. package/src/generators/api-only/types.js +0 -618
  302. package/src/generators/api-only/webhooks.js +0 -377
  303. package/src/generators/env-generator.js +0 -191
  304. package/src/generators/expo-auth-generator.js +0 -1009
  305. package/src/generators/gitignore-generator.js +0 -92
  306. package/src/generators/index.js +0 -166
  307. package/src/generators/manifest-generator.js +0 -154
  308. package/src/generators/mcp-guide-generator.js +0 -256
  309. package/src/generators/nextauth-generator.js +0 -247
  310. package/src/generators/oauth-guide-generator.js +0 -277
  311. package/src/generators/quickstart/components/index.js +0 -1699
  312. package/src/generators/quickstart/components-mobile/index.js +0 -1440
  313. package/src/generators/quickstart/database/convex.js +0 -1257
  314. package/src/generators/quickstart/database/index.js +0 -34
  315. package/src/generators/quickstart/database/supabase.js +0 -1132
  316. package/src/generators/quickstart/hooks/index.js +0 -1065
  317. package/src/generators/quickstart/index.js +0 -191
  318. package/src/generators/quickstart/pages/index.js +0 -1466
  319. package/src/generators/quickstart/screens/index.js +0 -1498
  320. package/src/logo.js +0 -116
  321. package/src/mcp/auth.js +0 -127
  322. package/src/mcp/registry/domains/applications.js +0 -516
  323. package/src/mcp/registry/domains/benefits.js +0 -798
  324. package/src/mcp/registry/domains/codegen.js +0 -894
  325. package/src/mcp/registry/domains/core.js +0 -324
  326. package/src/mcp/registry/domains/crm.js +0 -591
  327. package/src/mcp/registry/domains/events.js +0 -649
  328. package/src/mcp/registry/domains/forms.js +0 -696
  329. package/src/mcp/registry/index.js +0 -164
  330. package/src/mcp/server.js +0 -116
  331. package/src/utils/file-utils.js +0 -117
  332. package/src/utils/init-helpers.js +0 -243
  333. package/src/utils/prompt-utils.js +0 -195
  334. package/templates/CLAUDE.md +0 -86
  335. package/tests/api-client-detector.test.js +0 -214
  336. package/tests/api-client-generator.test.js +0 -176
  337. package/tests/backend-client.test.js +0 -640
  338. package/tests/base-detector.test.js +0 -101
  339. package/tests/commands/login.test.js +0 -143
  340. package/tests/commands/logout.test.js +0 -84
  341. package/tests/commands/status.test.js +0 -167
  342. package/tests/config-manager.test.js +0 -321
  343. package/tests/database-detector.test.js +0 -221
  344. package/tests/detector-index.test.js +0 -209
  345. package/tests/detector-registry.test.js +0 -93
  346. package/tests/env-generator.test.js +0 -278
  347. package/tests/expo-detector.test.js +0 -263
  348. package/tests/file-utils.test.js +0 -194
  349. package/tests/generators-index.test.js +0 -454
  350. package/tests/github-detector.test.js +0 -145
  351. package/tests/gitignore-generator.test.js +0 -109
  352. package/tests/logo.test.js +0 -96
  353. package/tests/nextauth-generator.test.js +0 -255
  354. package/tests/nextjs-detector.test.js +0 -235
  355. package/tests/oauth-detector.test.js +0 -264
  356. package/tests/oauth-guide-generator.test.js +0 -273
  357. package/tests/page-detector.test.js +0 -371
@@ -1,263 +0,0 @@
1
- /**
2
- * Tests for Expo/React Native Project Detector
3
- */
4
-
5
- const fs = require('fs');
6
- const path = require('path');
7
-
8
- jest.mock('fs');
9
-
10
- const detector = require('../src/detectors/expo-detector');
11
-
12
- describe('ExpoDetector', () => {
13
- beforeEach(() => {
14
- jest.clearAllMocks();
15
- });
16
-
17
- describe('basic detection', () => {
18
- it('detects Expo project', () => {
19
- fs.existsSync.mockReturnValue(true);
20
- fs.readFileSync.mockReturnValue(JSON.stringify({
21
- dependencies: {
22
- expo: '^51.0.0',
23
- 'react-native': '0.74.0',
24
- },
25
- }));
26
-
27
- const result = detector.detect('/test/project');
28
-
29
- expect(result.detected).toBe(true);
30
- expect(result.confidence).toBeGreaterThan(0.8);
31
- expect(result.metadata.isExpo).toBe(true);
32
- expect(result.metadata.expoVersion).toBe('^51.0.0');
33
- });
34
-
35
- it('detects React Native project without Expo (below confidence threshold)', () => {
36
- fs.existsSync.mockReturnValue(true);
37
- fs.readFileSync.mockReturnValue(JSON.stringify({
38
- dependencies: {
39
- 'react-native': '0.74.0',
40
- },
41
- }));
42
-
43
- const result = detector.detect('/test/project');
44
-
45
- // Pure React Native has confidence of 0.85
46
- // which is above the 0.8 threshold, so it will be detected
47
- expect(result.detected).toBe(true);
48
- expect(result.confidence).toBe(0.85);
49
- });
50
-
51
- it('does not detect non-Expo/React Native project', () => {
52
- fs.existsSync.mockReturnValue(true);
53
- fs.readFileSync.mockReturnValue(JSON.stringify({
54
- dependencies: {
55
- next: '^14.0.0',
56
- react: '^18.0.0',
57
- },
58
- }));
59
-
60
- const result = detector.detect('/test/project');
61
-
62
- expect(result.detected).toBe(false);
63
- });
64
-
65
- it('does not detect when no package.json', () => {
66
- fs.existsSync.mockReturnValue(false);
67
-
68
- const result = detector.detect('/test/project');
69
-
70
- expect(result.detected).toBe(false);
71
- expect(result.confidence).toBe(0);
72
- });
73
- });
74
-
75
- describe('routerType detection', () => {
76
- it('detects expo-router', () => {
77
- fs.existsSync.mockReturnValue(true);
78
- fs.readFileSync.mockReturnValue(JSON.stringify({
79
- dependencies: {
80
- expo: '^51.0.0',
81
- 'expo-router': '^3.5.0',
82
- 'react-native': '0.74.0',
83
- },
84
- }));
85
-
86
- const result = detector.detect('/test/project');
87
-
88
- expect(result.detected).toBe(true);
89
- expect(result.metadata.routerType).toBe('expo-router');
90
- });
91
-
92
- it('detects react-navigation', () => {
93
- fs.existsSync.mockReturnValue(true);
94
- fs.readFileSync.mockReturnValue(JSON.stringify({
95
- dependencies: {
96
- expo: '^51.0.0',
97
- '@react-navigation/native': '^6.0.0',
98
- 'react-native': '0.74.0',
99
- },
100
- }));
101
-
102
- const result = detector.detect('/test/project');
103
-
104
- expect(result.detected).toBe(true);
105
- expect(result.metadata.routerType).toBe('react-navigation');
106
- });
107
-
108
- it('defaults to native when no router package is present', () => {
109
- fs.existsSync.mockReturnValue(true);
110
- fs.readFileSync.mockReturnValue(JSON.stringify({
111
- dependencies: {
112
- expo: '^51.0.0',
113
- 'react-native': '0.74.0',
114
- },
115
- }));
116
-
117
- const result = detector.detect('/test/project');
118
-
119
- expect(result.detected).toBe(true);
120
- expect(result.metadata.routerType).toBe('native');
121
- });
122
-
123
- it('NEVER returns null for routerType when project is detected', () => {
124
- // This is the critical test - routerType must never be null
125
- // when the project is successfully detected
126
- fs.existsSync.mockReturnValue(true);
127
- fs.readFileSync.mockReturnValue(JSON.stringify({
128
- dependencies: {
129
- expo: '^51.0.0',
130
- 'react-native': '0.74.0',
131
- // No router packages at all
132
- },
133
- }));
134
-
135
- const result = detector.detect('/test/project');
136
-
137
- expect(result.detected).toBe(true);
138
- // This must NEVER be null - backend requires string
139
- expect(result.metadata.routerType).not.toBeNull();
140
- expect(result.metadata.routerType).not.toBeUndefined();
141
- expect(typeof result.metadata.routerType).toBe('string');
142
- });
143
- });
144
-
145
- describe('TypeScript detection', () => {
146
- it('detects TypeScript via dependency', () => {
147
- fs.existsSync.mockReturnValue(true);
148
- fs.readFileSync.mockReturnValue(JSON.stringify({
149
- dependencies: {
150
- expo: '^51.0.0',
151
- 'react-native': '0.74.0',
152
- },
153
- devDependencies: {
154
- typescript: '^5.0.0',
155
- },
156
- }));
157
-
158
- const result = detector.detect('/test/project');
159
-
160
- expect(result.metadata.hasTypeScript).toBe(true);
161
- });
162
-
163
- it('detects TypeScript via tsconfig.json', () => {
164
- fs.existsSync.mockImplementation((p) => {
165
- if (p.includes('tsconfig.json')) return true;
166
- if (p.includes('package.json')) return true;
167
- return false;
168
- });
169
- fs.readFileSync.mockReturnValue(JSON.stringify({
170
- dependencies: {
171
- expo: '^51.0.0',
172
- 'react-native': '0.74.0',
173
- },
174
- }));
175
-
176
- const result = detector.detect('/test/project');
177
-
178
- expect(result.metadata.hasTypeScript).toBe(true);
179
- });
180
- });
181
-
182
- describe('app config detection', () => {
183
- it('detects app.json config', () => {
184
- fs.existsSync.mockImplementation((p) => {
185
- if (p.includes('app.json')) return true;
186
- if (p.includes('package.json')) return true;
187
- return false;
188
- });
189
- fs.readFileSync.mockImplementation((p) => {
190
- if (p.includes('app.json')) {
191
- return JSON.stringify({
192
- expo: {
193
- sdkVersion: '51.0.0',
194
- },
195
- });
196
- }
197
- return JSON.stringify({
198
- dependencies: {
199
- expo: '^51.0.0',
200
- 'react-native': '0.74.0',
201
- },
202
- });
203
- });
204
-
205
- const result = detector.detect('/test/project');
206
-
207
- expect(result.metadata.config).toBe('app.json');
208
- expect(result.metadata.sdkVersion).toBe('51.0.0');
209
- expect(result.confidence).toBe(0.95);
210
- });
211
-
212
- it('detects app.config.js config', () => {
213
- fs.existsSync.mockImplementation((p) => {
214
- if (p.includes('app.config.js')) return true;
215
- if (p.includes('package.json')) return true;
216
- return false;
217
- });
218
- fs.readFileSync.mockReturnValue(JSON.stringify({
219
- dependencies: {
220
- expo: '^51.0.0',
221
- 'react-native': '0.74.0',
222
- },
223
- }));
224
-
225
- const result = detector.detect('/test/project');
226
-
227
- expect(result.metadata.config).toBe('app.config.js');
228
- });
229
- });
230
-
231
- describe('features and generators', () => {
232
- it('returns supported features', () => {
233
- const features = detector.getSupportedFeatures();
234
-
235
- expect(features.oauth).toBe(true);
236
- expect(features.stripe).toBe(true);
237
- expect(features.crm).toBe(true);
238
- expect(features.projects).toBe(true);
239
- expect(features.invoices).toBe(true);
240
- });
241
-
242
- it('returns available generators', () => {
243
- const generators = detector.getAvailableGenerators();
244
-
245
- expect(generators).toContain('api-client');
246
- expect(generators).toContain('env');
247
- expect(generators).toContain('oauth-guide');
248
- // Should NOT include Next.js specific generators
249
- expect(generators).not.toContain('nextauth');
250
- });
251
- });
252
-
253
- describe('detector properties', () => {
254
- it('has correct name', () => {
255
- expect(detector.name).toBe('expo');
256
- });
257
-
258
- it('has high priority', () => {
259
- expect(detector.priority).toBe(95);
260
- // Should be higher than generic React but lower than Expo with config
261
- });
262
- });
263
- });
@@ -1,194 +0,0 @@
1
- /**
2
- * Tests for File Utilities
3
- */
4
-
5
- const crypto = require('crypto');
6
- const path = require('path');
7
-
8
- jest.mock('fs');
9
- jest.mock('inquirer');
10
-
11
- const fs = require('fs');
12
- const inquirer = require('inquirer');
13
-
14
- // Must require after mocks are set up
15
- const {
16
- GENERATED_HEADER,
17
- isGeneratedFile,
18
- checkFileOverwrite,
19
- writeFileWithBackup,
20
- ensureDir,
21
- generateProjectPathHash,
22
- } = require('../src/utils/file-utils');
23
-
24
- describe('File Utilities', () => {
25
- beforeEach(() => {
26
- jest.clearAllMocks();
27
- jest.spyOn(console, 'log').mockImplementation(() => {});
28
- });
29
-
30
- afterEach(() => {
31
- console.log.mockRestore();
32
- });
33
-
34
- describe('generateProjectPathHash', () => {
35
- it('generates SHA256 hash of absolute project path', () => {
36
- const projectPath = '/test/project/path';
37
- const expectedHash = crypto.createHash('sha256')
38
- .update(path.resolve(projectPath))
39
- .digest('hex');
40
-
41
- const result = generateProjectPathHash(projectPath);
42
-
43
- expect(result).toBe(expectedHash);
44
- expect(result).toHaveLength(64); // SHA256 produces 64 hex chars
45
- });
46
-
47
- it('generates same hash for same path', () => {
48
- const projectPath = '/consistent/path';
49
-
50
- const hash1 = generateProjectPathHash(projectPath);
51
- const hash2 = generateProjectPathHash(projectPath);
52
-
53
- expect(hash1).toBe(hash2);
54
- });
55
-
56
- it('generates different hashes for different paths', () => {
57
- const path1 = '/path/one';
58
- const path2 = '/path/two';
59
-
60
- const hash1 = generateProjectPathHash(path1);
61
- const hash2 = generateProjectPathHash(path2);
62
-
63
- expect(hash1).not.toBe(hash2);
64
- });
65
-
66
- it('handles relative paths by resolving to absolute', () => {
67
- const relativePath = './my-project';
68
- const absolutePath = path.resolve(relativePath);
69
- const expectedHash = crypto.createHash('sha256')
70
- .update(absolutePath)
71
- .digest('hex');
72
-
73
- const result = generateProjectPathHash(relativePath);
74
-
75
- expect(result).toBe(expectedHash);
76
- });
77
- });
78
-
79
- describe('isGeneratedFile', () => {
80
- it('returns false if file does not exist', () => {
81
- fs.existsSync.mockReturnValue(false);
82
-
83
- expect(isGeneratedFile('/nonexistent/file.js')).toBe(false);
84
- });
85
-
86
- it('returns true if file contains generated header', () => {
87
- fs.existsSync.mockReturnValue(true);
88
- fs.readFileSync.mockReturnValue(`// ${GENERATED_HEADER}\n// Some content`);
89
-
90
- expect(isGeneratedFile('/test/file.js')).toBe(true);
91
- });
92
-
93
- it('returns false if file does not contain generated header', () => {
94
- fs.existsSync.mockReturnValue(true);
95
- fs.readFileSync.mockReturnValue('// Manual file content\nconst x = 1;');
96
-
97
- expect(isGeneratedFile('/test/file.js')).toBe(false);
98
- });
99
-
100
- it('returns false if file read throws error', () => {
101
- fs.existsSync.mockReturnValue(true);
102
- fs.readFileSync.mockImplementation(() => {
103
- throw new Error('Read error');
104
- });
105
-
106
- expect(isGeneratedFile('/test/file.js')).toBe(false);
107
- });
108
- });
109
-
110
- describe('checkFileOverwrite', () => {
111
- it('returns write if file does not exist', async () => {
112
- fs.existsSync.mockReturnValue(false);
113
-
114
- const result = await checkFileOverwrite('/new/file.js');
115
-
116
- expect(result).toBe('write');
117
- });
118
-
119
- it('returns write if file is generated by us', async () => {
120
- fs.existsSync.mockReturnValue(true);
121
- fs.readFileSync.mockReturnValue(`// ${GENERATED_HEADER}\ncontent`);
122
-
123
- const result = await checkFileOverwrite('/test/file.js');
124
-
125
- expect(result).toBe('write');
126
- });
127
-
128
- it('returns skip if defaultAction is skip', async () => {
129
- fs.existsSync.mockReturnValue(true);
130
- fs.readFileSync.mockReturnValue('manual content');
131
-
132
- const result = await checkFileOverwrite('/test/file.js', { defaultAction: 'skip' });
133
-
134
- expect(result).toBe('skip');
135
- });
136
-
137
- it('prompts user if file exists and is not generated', async () => {
138
- fs.existsSync.mockReturnValue(true);
139
- fs.readFileSync.mockReturnValue('manual content');
140
- inquirer.prompt.mockResolvedValue({ action: 'backup' });
141
-
142
- const result = await checkFileOverwrite('/test/file.js');
143
-
144
- expect(inquirer.prompt).toHaveBeenCalled();
145
- expect(result).toBe('backup');
146
- });
147
- });
148
-
149
- describe('writeFileWithBackup', () => {
150
- it('returns null if action is skip', () => {
151
- const result = writeFileWithBackup('/test/file.js', 'content', 'skip');
152
-
153
- expect(result).toBeNull();
154
- expect(fs.writeFileSync).not.toHaveBeenCalled();
155
- });
156
-
157
- it('creates backup if action is backup', () => {
158
- fs.existsSync.mockReturnValue(true);
159
-
160
- writeFileWithBackup('/test/file.js', 'new content', 'backup');
161
-
162
- expect(fs.copyFileSync).toHaveBeenCalledWith('/test/file.js', '/test/file.js.backup');
163
- expect(fs.writeFileSync).toHaveBeenCalledWith('/test/file.js', 'new content', 'utf8');
164
- });
165
-
166
- it('writes file directly if action is write', () => {
167
- fs.existsSync.mockReturnValue(true);
168
-
169
- const result = writeFileWithBackup('/test/file.js', 'content', 'write');
170
-
171
- expect(fs.copyFileSync).not.toHaveBeenCalled();
172
- expect(fs.writeFileSync).toHaveBeenCalledWith('/test/file.js', 'content', 'utf8');
173
- expect(result).toBe('/test/file.js');
174
- });
175
- });
176
-
177
- describe('ensureDir', () => {
178
- it('creates directory if it does not exist', () => {
179
- fs.existsSync.mockReturnValue(false);
180
-
181
- ensureDir('/test/dir');
182
-
183
- expect(fs.mkdirSync).toHaveBeenCalledWith('/test/dir', { recursive: true });
184
- });
185
-
186
- it('does nothing if directory exists', () => {
187
- fs.existsSync.mockReturnValue(true);
188
-
189
- ensureDir('/test/dir');
190
-
191
- expect(fs.mkdirSync).not.toHaveBeenCalled();
192
- });
193
- });
194
- });