nodejs-quickstart-structure 1.18.1 → 1.19.1

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 (235) hide show
  1. package/CHANGELOG.md +309 -294
  2. package/LICENSE +15 -15
  3. package/README.md +2 -1
  4. package/lib/generator.js +139 -139
  5. package/lib/modules/app-setup.js +401 -401
  6. package/lib/modules/caching-setup.js +76 -73
  7. package/lib/modules/config-files.js +151 -151
  8. package/lib/modules/database-setup.js +116 -116
  9. package/lib/modules/kafka-setup.js +249 -191
  10. package/lib/modules/project-setup.js +32 -31
  11. package/lib/prompts.js +100 -100
  12. package/package.json +78 -67
  13. package/templates/clean-architecture/js/src/domain/models/User.js +9 -9
  14. package/templates/clean-architecture/js/src/errors/ApiError.js +14 -14
  15. package/templates/clean-architecture/js/src/errors/BadRequestError.js +11 -10
  16. package/templates/clean-architecture/js/src/errors/BadRequestError.spec.js.ejs +22 -21
  17. package/templates/clean-architecture/js/src/errors/NotFoundError.js +11 -10
  18. package/templates/clean-architecture/js/src/errors/NotFoundError.spec.js.ejs +22 -21
  19. package/templates/clean-architecture/js/src/index.js.ejs +55 -55
  20. package/templates/clean-architecture/js/src/infrastructure/config/env.js.ejs +47 -47
  21. package/templates/clean-architecture/js/src/infrastructure/log/logger.js +36 -36
  22. package/templates/clean-architecture/js/src/infrastructure/log/logger.spec.js.ejs +63 -63
  23. package/templates/clean-architecture/js/src/infrastructure/repositories/UserRepository.js.ejs +69 -39
  24. package/templates/clean-architecture/js/src/infrastructure/repositories/UserRepository.spec.js.ejs +142 -81
  25. package/templates/clean-architecture/js/src/infrastructure/webserver/middleware/errorMiddleware.js +30 -30
  26. package/templates/clean-architecture/js/src/infrastructure/webserver/server.js.ejs +89 -89
  27. package/templates/clean-architecture/js/src/infrastructure/webserver/swagger.js.ejs +6 -6
  28. package/templates/clean-architecture/js/src/interfaces/controllers/userController.js.ejs +156 -75
  29. package/templates/clean-architecture/js/src/interfaces/controllers/userController.spec.js.ejs +234 -138
  30. package/templates/clean-architecture/js/src/interfaces/graphql/context.js.ejs +13 -13
  31. package/templates/clean-architecture/js/src/interfaces/graphql/context.spec.js.ejs +31 -31
  32. package/templates/clean-architecture/js/src/interfaces/graphql/index.js.ejs +5 -5
  33. package/templates/clean-architecture/js/src/interfaces/graphql/resolvers/index.js.ejs +6 -6
  34. package/templates/clean-architecture/js/src/interfaces/graphql/resolvers/user.resolvers.js.ejs +27 -21
  35. package/templates/clean-architecture/js/src/interfaces/graphql/resolvers/user.resolvers.spec.js.ejs +66 -49
  36. package/templates/clean-architecture/js/src/interfaces/graphql/typeDefs/index.js.ejs +6 -6
  37. package/templates/clean-architecture/js/src/interfaces/graphql/typeDefs/user.types.js.ejs +19 -17
  38. package/templates/clean-architecture/js/src/interfaces/routes/api.js +12 -10
  39. package/templates/clean-architecture/js/src/interfaces/routes/api.spec.js.ejs +38 -38
  40. package/templates/clean-architecture/js/src/usecases/CreateUser.js +14 -14
  41. package/templates/clean-architecture/js/src/usecases/CreateUser.spec.js.ejs +51 -51
  42. package/templates/clean-architecture/js/src/usecases/DeleteUser.js +11 -0
  43. package/templates/clean-architecture/js/src/usecases/DeleteUser.spec.js.ejs +47 -0
  44. package/templates/clean-architecture/js/src/usecases/GetAllUsers.js +12 -12
  45. package/templates/clean-architecture/js/src/usecases/GetAllUsers.spec.js.ejs +61 -61
  46. package/templates/clean-architecture/js/src/usecases/UpdateUser.js +11 -0
  47. package/templates/clean-architecture/js/src/usecases/UpdateUser.spec.js.ejs +48 -0
  48. package/templates/clean-architecture/js/src/utils/errorMessages.js +14 -0
  49. package/templates/clean-architecture/js/src/utils/httpCodes.js +9 -9
  50. package/templates/clean-architecture/ts/src/config/env.ts.ejs +46 -46
  51. package/templates/clean-architecture/ts/src/config/swagger.ts.ejs +6 -6
  52. package/templates/clean-architecture/ts/src/domain/user.ts +7 -7
  53. package/templates/clean-architecture/ts/src/errors/ApiError.ts +15 -15
  54. package/templates/clean-architecture/ts/src/errors/BadRequestError.spec.ts.ejs +22 -21
  55. package/templates/clean-architecture/ts/src/errors/BadRequestError.ts +9 -8
  56. package/templates/clean-architecture/ts/src/errors/NotFoundError.spec.ts.ejs +22 -21
  57. package/templates/clean-architecture/ts/src/errors/NotFoundError.ts +9 -8
  58. package/templates/clean-architecture/ts/src/index.ts.ejs +139 -139
  59. package/templates/clean-architecture/ts/src/infrastructure/log/logger.spec.ts.ejs +63 -63
  60. package/templates/clean-architecture/ts/src/infrastructure/log/logger.ts +36 -36
  61. package/templates/clean-architecture/ts/src/infrastructure/repositories/UserRepository.spec.ts.ejs +175 -85
  62. package/templates/clean-architecture/ts/src/infrastructure/repositories/userRepository.ts.ejs +74 -0
  63. package/templates/clean-architecture/ts/src/interfaces/controllers/userController.spec.ts.ejs +331 -185
  64. package/templates/clean-architecture/ts/src/interfaces/controllers/userController.ts.ejs +173 -84
  65. package/templates/clean-architecture/ts/src/interfaces/graphql/context.spec.ts.ejs +32 -32
  66. package/templates/clean-architecture/ts/src/interfaces/graphql/context.ts.ejs +17 -17
  67. package/templates/clean-architecture/ts/src/interfaces/graphql/index.ts.ejs +3 -3
  68. package/templates/clean-architecture/ts/src/interfaces/graphql/resolvers/index.ts.ejs +4 -4
  69. package/templates/clean-architecture/ts/src/interfaces/graphql/resolvers/user.resolvers.spec.ts.ejs +68 -51
  70. package/templates/clean-architecture/ts/src/interfaces/graphql/resolvers/user.resolvers.ts.ejs +29 -21
  71. package/templates/clean-architecture/ts/src/interfaces/graphql/typeDefs/index.ts.ejs +4 -4
  72. package/templates/clean-architecture/ts/src/interfaces/graphql/typeDefs/user.types.ts.ejs +17 -15
  73. package/templates/clean-architecture/ts/src/interfaces/routes/userRoutes.spec.ts.ejs +40 -40
  74. package/templates/clean-architecture/ts/src/interfaces/routes/userRoutes.ts +13 -11
  75. package/templates/clean-architecture/ts/src/usecases/createUser.spec.ts.ejs +51 -51
  76. package/templates/clean-architecture/ts/src/usecases/createUser.ts +13 -13
  77. package/templates/clean-architecture/ts/src/usecases/deleteUser.spec.ts.ejs +47 -0
  78. package/templates/clean-architecture/ts/src/usecases/deleteUser.ts +9 -0
  79. package/templates/clean-architecture/ts/src/usecases/getAllUsers.spec.ts.ejs +63 -63
  80. package/templates/clean-architecture/ts/src/usecases/getAllUsers.ts +10 -10
  81. package/templates/clean-architecture/ts/src/usecases/updateUser.spec.ts.ejs +48 -0
  82. package/templates/clean-architecture/ts/src/usecases/updateUser.ts +9 -0
  83. package/templates/clean-architecture/ts/src/utils/errorMessages.ts +12 -0
  84. package/templates/clean-architecture/ts/src/utils/errorMiddleware.ts.ejs +27 -27
  85. package/templates/clean-architecture/ts/src/utils/httpCodes.ts +7 -7
  86. package/templates/common/.cursorrules.ejs +60 -60
  87. package/templates/common/.dockerignore +12 -12
  88. package/templates/common/.env.example.ejs +41 -41
  89. package/templates/common/.gitattributes +46 -0
  90. package/templates/common/.gitlab-ci.yml.ejs +86 -86
  91. package/templates/common/.lintstagedrc +6 -6
  92. package/templates/common/.prettierrc +7 -7
  93. package/templates/common/Dockerfile +73 -73
  94. package/templates/common/Jenkinsfile.ejs +87 -87
  95. package/templates/common/README.md.ejs +294 -270
  96. package/templates/common/SECURITY.md +20 -20
  97. package/templates/common/_github/workflows/ci.yml.ejs +46 -46
  98. package/templates/common/_github/workflows/security.yml.ejs +36 -36
  99. package/templates/common/_gitignore +5 -5
  100. package/templates/common/_husky/pre-commit +4 -4
  101. package/templates/common/caching/clean/js/CreateUser.js.ejs +29 -29
  102. package/templates/common/caching/clean/js/DeleteUser.js.ejs +27 -0
  103. package/templates/common/caching/clean/js/GetAllUsers.js.ejs +37 -37
  104. package/templates/common/caching/clean/js/UpdateUser.js.ejs +27 -0
  105. package/templates/common/caching/clean/ts/createUser.ts.ejs +27 -27
  106. package/templates/common/caching/clean/ts/deleteUser.ts.ejs +24 -0
  107. package/templates/common/caching/clean/ts/getAllUsers.ts.ejs +34 -34
  108. package/templates/common/caching/clean/ts/updateUser.ts.ejs +25 -0
  109. package/templates/common/caching/js/memoryCache.js.ejs +60 -60
  110. package/templates/common/caching/js/memoryCache.spec.js.ejs +101 -101
  111. package/templates/common/caching/js/redisClient.js.ejs +75 -75
  112. package/templates/common/caching/js/redisClient.spec.js.ejs +147 -147
  113. package/templates/common/caching/ts/memoryCache.spec.ts.ejs +102 -102
  114. package/templates/common/caching/ts/memoryCache.ts.ejs +73 -64
  115. package/templates/common/caching/ts/redisClient.spec.ts.ejs +157 -157
  116. package/templates/common/caching/ts/redisClient.ts.ejs +89 -80
  117. package/templates/common/database/js/database.js.ejs +19 -19
  118. package/templates/common/database/js/database.spec.js.ejs +56 -56
  119. package/templates/common/database/js/models/User.js.ejs +79 -53
  120. package/templates/common/database/js/models/User.js.mongoose.ejs +23 -19
  121. package/templates/common/database/js/models/User.spec.js.ejs +94 -84
  122. package/templates/common/database/js/mongoose.js.ejs +33 -33
  123. package/templates/common/database/js/mongoose.spec.js.ejs +43 -43
  124. package/templates/common/database/ts/database.spec.ts.ejs +56 -56
  125. package/templates/common/database/ts/database.ts.ejs +21 -21
  126. package/templates/common/database/ts/models/User.spec.ts.ejs +100 -84
  127. package/templates/common/database/ts/models/User.ts.ejs +87 -61
  128. package/templates/common/database/ts/models/User.ts.mongoose.ejs +30 -25
  129. package/templates/common/database/ts/mongoose.spec.ts.ejs +42 -42
  130. package/templates/common/database/ts/mongoose.ts.ejs +28 -28
  131. package/templates/common/docker-compose.yml.ejs +159 -159
  132. package/templates/common/ecosystem.config.js.ejs +40 -40
  133. package/templates/common/eslint.config.mjs.ejs +77 -77
  134. package/templates/common/health/js/healthRoute.js.ejs +50 -47
  135. package/templates/common/health/js/healthRoute.spec.js.ejs +70 -70
  136. package/templates/common/health/ts/healthRoute.spec.ts.ejs +76 -76
  137. package/templates/common/health/ts/healthRoute.ts.ejs +49 -46
  138. package/templates/common/jest.config.js.ejs +32 -32
  139. package/templates/common/jest.e2e.config.js.ejs +8 -8
  140. package/templates/common/kafka/js/config/kafka.js +9 -9
  141. package/templates/common/kafka/js/config/kafka.spec.js.ejs +27 -27
  142. package/templates/common/kafka/js/messaging/baseConsumer.js.ejs +30 -30
  143. package/templates/common/kafka/js/messaging/baseConsumer.spec.js.ejs +58 -58
  144. package/templates/common/kafka/js/messaging/userEventSchema.js.ejs +12 -11
  145. package/templates/common/kafka/js/messaging/userEventSchema.spec.js.ejs +27 -27
  146. package/templates/common/kafka/js/messaging/welcomeEmailConsumer.js.ejs +44 -31
  147. package/templates/common/kafka/js/messaging/welcomeEmailConsumer.spec.js.ejs +86 -49
  148. package/templates/common/kafka/js/services/kafkaService.js.ejs +93 -93
  149. package/templates/common/kafka/js/services/kafkaService.spec.js.ejs +106 -106
  150. package/templates/common/kafka/js/utils/kafkaEvents.js.ejs +7 -0
  151. package/templates/common/kafka/ts/config/kafka.spec.ts.ejs +27 -27
  152. package/templates/common/kafka/ts/config/kafka.ts +7 -7
  153. package/templates/common/kafka/ts/messaging/baseConsumer.spec.ts.ejs +50 -50
  154. package/templates/common/kafka/ts/messaging/baseConsumer.ts.ejs +27 -27
  155. package/templates/common/kafka/ts/messaging/userEventSchema.spec.ts.ejs +51 -51
  156. package/templates/common/kafka/ts/messaging/userEventSchema.ts.ejs +12 -11
  157. package/templates/common/kafka/ts/messaging/welcomeEmailConsumer.spec.ts.ejs +86 -49
  158. package/templates/common/kafka/ts/messaging/welcomeEmailConsumer.ts.ejs +38 -25
  159. package/templates/common/kafka/ts/services/kafkaService.spec.ts.ejs +81 -81
  160. package/templates/common/kafka/ts/services/kafkaService.ts.ejs +95 -95
  161. package/templates/common/kafka/ts/utils/kafkaEvents.ts.ejs +5 -0
  162. package/templates/common/migrate-mongo-config.js.ejs +31 -31
  163. package/templates/common/migrations/init.js.ejs +23 -23
  164. package/templates/common/package.json.ejs +119 -118
  165. package/templates/common/prompts/add-feature.md.ejs +26 -26
  166. package/templates/common/prompts/project-context.md.ejs +43 -43
  167. package/templates/common/prompts/troubleshoot.md.ejs +28 -28
  168. package/templates/common/public/css/style.css +147 -147
  169. package/templates/common/scripts/run-e2e.js.ejs +63 -63
  170. package/templates/common/shutdown/js/gracefulShutdown.js.ejs +65 -61
  171. package/templates/common/shutdown/js/gracefulShutdown.spec.js.ejs +149 -160
  172. package/templates/common/shutdown/ts/gracefulShutdown.spec.ts.ejs +179 -158
  173. package/templates/common/shutdown/ts/gracefulShutdown.ts.ejs +59 -55
  174. package/templates/common/sonar-project.properties.ejs +27 -27
  175. package/templates/common/src/tests/e2e/e2e.users.test.js.ejs +120 -49
  176. package/templates/common/src/tests/e2e/e2e.users.test.ts.ejs +120 -49
  177. package/templates/common/src/utils/errorMiddleware.spec.js.ejs +79 -79
  178. package/templates/common/src/utils/errorMiddleware.spec.ts.ejs +94 -94
  179. package/templates/common/swagger.yml.ejs +118 -66
  180. package/templates/common/tsconfig.json +22 -22
  181. package/templates/common/views/ejs/index.ejs +55 -55
  182. package/templates/common/views/pug/index.pug +40 -40
  183. package/templates/db/mysql/V1__Initial_Setup.sql.ejs +10 -9
  184. package/templates/db/postgres/V1__Initial_Setup.sql.ejs +10 -9
  185. package/templates/mvc/js/src/config/env.js.ejs +46 -46
  186. package/templates/mvc/js/src/config/swagger.js.ejs +6 -6
  187. package/templates/mvc/js/src/controllers/userController.js.ejs +246 -105
  188. package/templates/mvc/js/src/controllers/userController.spec.js.ejs +481 -209
  189. package/templates/mvc/js/src/errors/ApiError.js +14 -14
  190. package/templates/mvc/js/src/errors/BadRequestError.js +11 -10
  191. package/templates/mvc/js/src/errors/BadRequestError.spec.js.ejs +22 -21
  192. package/templates/mvc/js/src/errors/NotFoundError.js +11 -10
  193. package/templates/mvc/js/src/errors/NotFoundError.spec.js.ejs +22 -21
  194. package/templates/mvc/js/src/graphql/context.js.ejs +7 -7
  195. package/templates/mvc/js/src/graphql/context.spec.js.ejs +29 -29
  196. package/templates/mvc/js/src/graphql/index.js.ejs +5 -5
  197. package/templates/mvc/js/src/graphql/resolvers/index.js.ejs +6 -6
  198. package/templates/mvc/js/src/graphql/resolvers/user.resolvers.js.ejs +25 -19
  199. package/templates/mvc/js/src/graphql/resolvers/user.resolvers.spec.js.ejs +64 -47
  200. package/templates/mvc/js/src/graphql/typeDefs/index.js.ejs +6 -6
  201. package/templates/mvc/js/src/graphql/typeDefs/user.types.js.ejs +19 -17
  202. package/templates/mvc/js/src/index.js.ejs +136 -136
  203. package/templates/mvc/js/src/routes/api.js +10 -8
  204. package/templates/mvc/js/src/routes/api.spec.js.ejs +41 -36
  205. package/templates/mvc/js/src/utils/errorMessages.js +14 -0
  206. package/templates/mvc/js/src/utils/errorMiddleware.js +29 -29
  207. package/templates/mvc/js/src/utils/httpCodes.js +9 -9
  208. package/templates/mvc/js/src/utils/logger.js +40 -40
  209. package/templates/mvc/js/src/utils/logger.spec.js.ejs +63 -63
  210. package/templates/mvc/ts/src/config/env.ts.ejs +45 -45
  211. package/templates/mvc/ts/src/config/swagger.ts.ejs +6 -6
  212. package/templates/mvc/ts/src/controllers/userController.spec.ts.ejs +481 -203
  213. package/templates/mvc/ts/src/controllers/userController.ts.ejs +248 -107
  214. package/templates/mvc/ts/src/errors/ApiError.ts +15 -15
  215. package/templates/mvc/ts/src/errors/BadRequestError.spec.ts.ejs +22 -21
  216. package/templates/mvc/ts/src/errors/BadRequestError.ts +9 -8
  217. package/templates/mvc/ts/src/errors/NotFoundError.spec.ts.ejs +27 -21
  218. package/templates/mvc/ts/src/errors/NotFoundError.ts +9 -8
  219. package/templates/mvc/ts/src/graphql/context.spec.ts.ejs +30 -30
  220. package/templates/mvc/ts/src/graphql/context.ts.ejs +12 -12
  221. package/templates/mvc/ts/src/graphql/index.ts.ejs +3 -3
  222. package/templates/mvc/ts/src/graphql/resolvers/index.ts.ejs +4 -4
  223. package/templates/mvc/ts/src/graphql/resolvers/user.resolvers.spec.ts.ejs +68 -51
  224. package/templates/mvc/ts/src/graphql/resolvers/user.resolvers.ts.ejs +29 -21
  225. package/templates/mvc/ts/src/graphql/typeDefs/index.ts.ejs +4 -4
  226. package/templates/mvc/ts/src/graphql/typeDefs/user.types.ts.ejs +17 -15
  227. package/templates/mvc/ts/src/index.ts.ejs +156 -153
  228. package/templates/mvc/ts/src/routes/api.spec.ts.ejs +59 -40
  229. package/templates/mvc/ts/src/routes/api.ts +12 -10
  230. package/templates/mvc/ts/src/utils/errorMessages.ts +12 -0
  231. package/templates/mvc/ts/src/utils/errorMiddleware.ts.ejs +27 -27
  232. package/templates/mvc/ts/src/utils/httpCodes.ts +7 -7
  233. package/templates/mvc/ts/src/utils/logger.spec.ts.ejs +63 -63
  234. package/templates/mvc/ts/src/utils/logger.ts +36 -36
  235. package/templates/clean-architecture/ts/src/infrastructure/repositories/UserRepository.ts.ejs +0 -37
@@ -1,70 +1,70 @@
1
- const request = require('supertest');
2
- const express = require('express');
3
- <% if (architecture === 'MVC') { -%>
4
- const healthRoute = require('@/routes/healthRoute');
5
- <% } else { -%>
6
- const healthRoute = require('@/interfaces/routes/healthRoute');
7
- <% } -%>
8
- const HTTP_STATUS = require('@/utils/httpCodes');
9
-
10
- <%_ if (database === 'MongoDB') { -%>
11
- jest.mock('mongoose', () => {
12
- return {
13
- connection: {
14
- readyState: 1,
15
- db: {
16
- admin: jest.fn().mockReturnValue({
17
- ping: jest.fn().mockResolvedValue(true)
18
- })
19
- }
20
- }
21
- };
22
- });
23
- <%_ } else if (database !== 'None') { -%>
24
- jest.mock('<% if (architecture === "MVC") { %>@/config/database<% } else { %>@/infrastructure/database/database<% } %>', () => {
25
- return {
26
- authenticate: jest.fn()
27
- };
28
- });
29
- <%_ } -%>
30
-
31
- describe('Health Route', () => {
32
- let app;
33
-
34
- beforeEach(() => {
35
- app = express();
36
- app.use('/health', healthRoute);
37
- jest.clearAllMocks();
38
- });
39
-
40
- it('should return 200 OK with UP status', async () => {
41
- const res = await request(app).get('/health');
42
- expect(res.status).toBe(HTTP_STATUS.OK);
43
- expect(res.body.status).toBe('UP');
44
- expect(res.body.database).toBe('<% if (database === "None") { %>None<% } else { %>connected<% } %>');
45
- });
46
-
47
- <%_ if (database === 'MongoDB') { -%>
48
- it('should handle database ping failure and return 500', async () => {
49
- const mongoose = require('mongoose');
50
- mongoose.connection.db.admin.mockReturnValueOnce({
51
- ping: jest.fn().mockRejectedValueOnce(new Error('DB Error'))
52
- });
53
-
54
- const res = await request(app).get('/health');
55
- expect(res.status).toBe(HTTP_STATUS.INTERNAL_SERVER_ERROR);
56
- expect(res.body.status).toBe('DOWN');
57
- expect(res.body.database).toBe('error');
58
- });
59
- <%_ } else if (database !== 'None') { -%>
60
- it('should handle database authentication failure and return 500', async () => {
61
- const sequelize = require('<% if (architecture === "MVC") { %>@/config/database<% } else { %>@/infrastructure/database/database<% } %>');
62
- sequelize.authenticate.mockRejectedValueOnce(new Error('DB Error'));
63
-
64
- const res = await request(app).get('/health');
65
- expect(res.status).toBe(HTTP_STATUS.INTERNAL_SERVER_ERROR);
66
- expect(res.body.status).toBe('DOWN');
67
- expect(res.body.database).toBe('error');
68
- });
69
- <%_ } -%>
70
- });
1
+ const request = require('supertest');
2
+ const express = require('express');
3
+ <% if (architecture === 'MVC') { -%>
4
+ const healthRoute = require('@/routes/healthRoute');
5
+ <% } else { -%>
6
+ const healthRoute = require('@/interfaces/routes/healthRoute');
7
+ <% } -%>
8
+ const HTTP_STATUS = require('@/utils/httpCodes');
9
+
10
+ <%_ if (database === 'MongoDB') { -%>
11
+ jest.mock('mongoose', () => {
12
+ return {
13
+ connection: {
14
+ readyState: 1,
15
+ db: {
16
+ admin: jest.fn().mockReturnValue({
17
+ ping: jest.fn().mockResolvedValue(true)
18
+ })
19
+ }
20
+ }
21
+ };
22
+ });
23
+ <%_ } else if (database !== 'None') { -%>
24
+ jest.mock('<% if (architecture === "MVC") { %>@/config/database<% } else { %>@/infrastructure/database/database<% } %>', () => {
25
+ return {
26
+ authenticate: jest.fn()
27
+ };
28
+ });
29
+ <%_ } -%>
30
+
31
+ describe('Health Route', () => {
32
+ let app;
33
+
34
+ beforeEach(() => {
35
+ app = express();
36
+ app.use('/health', healthRoute);
37
+ jest.clearAllMocks();
38
+ });
39
+
40
+ it('should return 200 OK with UP status', async () => {
41
+ const res = await request(app).get('/health');
42
+ expect(res.status).toBe(HTTP_STATUS.OK);
43
+ expect(res.body.status).toBe('UP');
44
+ expect(res.body.database).toBe('<% if (database === "None") { %>None<% } else { %>connected<% } %>');
45
+ });
46
+
47
+ <%_ if (database === 'MongoDB') { -%>
48
+ it('should handle database ping failure and return 500', async () => {
49
+ const mongoose = require('mongoose');
50
+ mongoose.connection.db.admin.mockReturnValueOnce({
51
+ ping: jest.fn().mockRejectedValueOnce(new Error('DB Error'))
52
+ });
53
+
54
+ const res = await request(app).get('/health');
55
+ expect(res.status).toBe(HTTP_STATUS.INTERNAL_SERVER_ERROR);
56
+ expect(res.body.status).toBe('DOWN');
57
+ expect(res.body.database).toBe('error');
58
+ });
59
+ <%_ } else if (database !== 'None') { -%>
60
+ it('should handle database authentication failure and return 500', async () => {
61
+ const sequelize = require('<% if (architecture === "MVC") { %>@/config/database<% } else { %>@/infrastructure/database/database<% } %>');
62
+ sequelize.authenticate.mockRejectedValueOnce(new Error('DB Error'));
63
+
64
+ const res = await request(app).get('/health');
65
+ expect(res.status).toBe(HTTP_STATUS.INTERNAL_SERVER_ERROR);
66
+ expect(res.body.status).toBe('DOWN');
67
+ expect(res.body.database).toBe('error');
68
+ });
69
+ <%_ } -%>
70
+ });
@@ -1,76 +1,76 @@
1
- import request from 'supertest';
2
- import express from 'express';
3
- <% if (architecture === 'MVC') { -%>
4
- import healthRoute from '@/routes/healthRoute';
5
- <% } else { -%>
6
- import healthRoute from '@/interfaces/routes/healthRoute';
7
- <% } -%>
8
- import { HTTP_STATUS } from '@/utils/httpCodes';
9
- <%_ if (database === 'MongoDB') { -%>
10
- import mongoose from 'mongoose';
11
- <%_ } else if (database !== 'None') { -%>
12
- import sequelize from '<% if (architecture === "MVC") { %>@/config/database<% } else { %>@/infrastructure/database/database<% } %>';
13
- <%_ } -%>
14
-
15
- <%_ if (database === 'MongoDB') { -%>
16
- jest.mock('mongoose', () => {
17
- return {
18
- connection: {
19
- readyState: 1,
20
- db: {
21
- admin: jest.fn().mockReturnValue({
22
- ping: jest.fn().mockResolvedValue(true)
23
- })
24
- }
25
- }
26
- };
27
- });
28
- <%_ } else if (database !== 'None') { -%>
29
- jest.mock('<% if (architecture === "MVC") { %>@/config/database<% } else { %>@/infrastructure/database/database<% } %>', () => {
30
- return {
31
- __esModule: true,
32
- default: {
33
- authenticate: jest.fn()
34
- }
35
- };
36
- });
37
- <%_ } -%>
38
-
39
- describe('Health Route', () => {
40
- let app: express.Express;
41
-
42
- beforeEach(() => {
43
- app = express();
44
- app.use('/health', healthRoute);
45
- jest.clearAllMocks();
46
- });
47
-
48
- it('should return 200 OK with UP status', async () => {
49
- const res = await request(app).get('/health');
50
- expect(res.status).toBe(HTTP_STATUS.OK);
51
- expect(res.body.status).toBe('UP');
52
- expect(res.body.database).toBe('<% if (database === "None") { %>None<% } else { %>connected<% } %>');
53
- });
54
-
55
- <%_ if (database === 'MongoDB') { -%>
56
- it('should handle database ping failure and return 500', async () => {
57
- ((mongoose.connection.db as any).admin as jest.Mock).mockReturnValueOnce({
58
- ping: jest.fn().mockRejectedValueOnce(new Error('DB Error'))
59
- });
60
-
61
- const res = await request(app).get('/health');
62
- expect(res.status).toBe(HTTP_STATUS.INTERNAL_SERVER_ERROR);
63
- expect(res.body.status).toBe('DOWN');
64
- expect(res.body.database).toBe('error');
65
- });
66
- <%_ } else if (database !== 'None') { -%>
67
- it('should handle database authentication failure and return 500', async () => {
68
- (sequelize.authenticate as jest.Mock).mockRejectedValueOnce(new Error('DB Error'));
69
-
70
- const res = await request(app).get('/health');
71
- expect(res.status).toBe(HTTP_STATUS.INTERNAL_SERVER_ERROR);
72
- expect(res.body.status).toBe('DOWN');
73
- expect(res.body.database).toBe('error');
74
- });
75
- <%_ } -%>
76
- });
1
+ import request from 'supertest';
2
+ import express from 'express';
3
+ <% if (architecture === 'MVC') { -%>
4
+ import healthRoute from '@/routes/healthRoute';
5
+ <% } else { -%>
6
+ import healthRoute from '@/interfaces/routes/healthRoute';
7
+ <% } -%>
8
+ import { HTTP_STATUS } from '@/utils/httpCodes';
9
+ <%_ if (database === 'MongoDB') { -%>
10
+ import mongoose from 'mongoose';
11
+ <%_ } else if (database !== 'None') { -%>
12
+ import sequelize from '<% if (architecture === "MVC") { %>@/config/database<% } else { %>@/infrastructure/database/database<% } %>';
13
+ <%_ } -%>
14
+
15
+ <%_ if (database === 'MongoDB') { -%>
16
+ jest.mock('mongoose', () => {
17
+ return {
18
+ connection: {
19
+ readyState: 1,
20
+ db: {
21
+ admin: jest.fn().mockReturnValue({
22
+ ping: jest.fn().mockResolvedValue(true)
23
+ })
24
+ }
25
+ }
26
+ };
27
+ });
28
+ <%_ } else if (database !== 'None') { -%>
29
+ jest.mock('<% if (architecture === "MVC") { %>@/config/database<% } else { %>@/infrastructure/database/database<% } %>', () => {
30
+ return {
31
+ __esModule: true,
32
+ default: {
33
+ authenticate: jest.fn()
34
+ }
35
+ };
36
+ });
37
+ <%_ } -%>
38
+
39
+ describe('Health Route', () => {
40
+ let app: express.Express;
41
+
42
+ beforeEach(() => {
43
+ app = express();
44
+ app.use('/health', healthRoute);
45
+ jest.clearAllMocks();
46
+ });
47
+
48
+ it('should return 200 OK with UP status', async () => {
49
+ const res = await request(app).get('/health');
50
+ expect(res.status).toBe(HTTP_STATUS.OK);
51
+ expect(res.body.status).toBe('UP');
52
+ expect(res.body.database).toBe('<% if (database === "None") { %>None<% } else { %>connected<% } %>');
53
+ });
54
+
55
+ <%_ if (database === 'MongoDB') { -%>
56
+ it('should handle database ping failure and return 500', async () => {
57
+ ((mongoose.connection.db as any).admin as jest.Mock).mockReturnValueOnce({
58
+ ping: jest.fn().mockRejectedValueOnce(new Error('DB Error'))
59
+ });
60
+
61
+ const res = await request(app).get('/health');
62
+ expect(res.status).toBe(HTTP_STATUS.INTERNAL_SERVER_ERROR);
63
+ expect(res.body.status).toBe('DOWN');
64
+ expect(res.body.database).toBe('error');
65
+ });
66
+ <%_ } else if (database !== 'None') { -%>
67
+ it('should handle database authentication failure and return 500', async () => {
68
+ (sequelize.authenticate as jest.Mock).mockRejectedValueOnce(new Error('DB Error'));
69
+
70
+ const res = await request(app).get('/health');
71
+ expect(res.status).toBe(HTTP_STATUS.INTERNAL_SERVER_ERROR);
72
+ expect(res.body.status).toBe('DOWN');
73
+ expect(res.body.database).toBe('error');
74
+ });
75
+ <%_ } -%>
76
+ });
@@ -1,46 +1,49 @@
1
- import { Router, Request, Response } from 'express';
2
- import logger from '<% if (architecture === "MVC") { %>@/utils/logger<% } else { %>@/infrastructure/log/logger<% } %>';
3
- import { HTTP_STATUS } from '@/utils/httpCodes';
4
- <%_ if (database === 'MongoDB') { -%>
5
- import mongoose from 'mongoose';
6
- <%_ } else if (database !== 'None') { -%>
7
- import sequelize from '<% if (architecture === "MVC") { %>@/config/database<% } else { %>@/infrastructure/database/database<% } %>';
8
- <%_ } -%>
9
-
10
- const router = Router();
11
-
12
- router.get('/', async (req: Request, res: Response) => {
13
- const healthData: Record<string, unknown> = {
14
- status: 'UP',
15
- uptime: process.uptime(),
16
- memory: process.memoryUsage(),
17
- database: 'disconnected',
18
- timestamp: Date.now()
19
- };
20
- logger.info('Health Check');
21
-
22
- <%_ if (database !== 'None') { -%>
23
- try {
24
- <%_ if (database === 'MongoDB') { -%>
25
- if (mongoose.connection.readyState === 1) {
26
- await mongoose.connection.db?.admin().ping();
27
- healthData.database = 'connected';
28
- }
29
- <%_ } else { -%>
30
- await sequelize.authenticate();
31
- healthData.database = 'connected';
32
- <%_ } -%>
33
- } catch (err) {
34
- healthData.database = 'error';
35
- healthData.status = 'DOWN';
36
- logger.error('Health Check Database Ping Failed:', err);
37
- return res.status(HTTP_STATUS.INTERNAL_SERVER_ERROR).json(healthData);
38
- }
39
- <%_ } else { -%>
40
- healthData.database = 'None';
41
- <%_ } -%>
42
-
43
- res.status(HTTP_STATUS.OK).json(healthData);
44
- });
45
-
46
- export default router;
1
+ import { Router, Request, Response } from 'express';
2
+ import logger from '<% if (architecture === "MVC") { %>@/utils/logger<% } else { %>@/infrastructure/log/logger<% } %>';
3
+ import { HTTP_STATUS } from '@/utils/httpCodes';
4
+ <%_ if (database !== 'None') { -%>
5
+ import { ERROR_MESSAGES } from '@/utils/errorMessages';
6
+ <%_ } -%>
7
+ <%_ if (database === 'MongoDB') { -%>
8
+ import mongoose from 'mongoose';
9
+ <%_ } else if (database !== 'None') { -%>
10
+ import sequelize from '<% if (architecture === "MVC") { %>@/config/database<% } else { %>@/infrastructure/database/database<% } %>';
11
+ <%_ } -%>
12
+
13
+ const router = Router();
14
+
15
+ router.get('/', async (req: Request, res: Response) => {
16
+ const healthData: Record<string, unknown> = {
17
+ status: 'UP',
18
+ uptime: process.uptime(),
19
+ memory: process.memoryUsage(),
20
+ database: 'disconnected',
21
+ timestamp: Date.now()
22
+ };
23
+ logger.info('Health Check');
24
+
25
+ <%_ if (database !== 'None') { -%>
26
+ try {
27
+ <%_ if (database === 'MongoDB') { -%>
28
+ if (mongoose.connection.readyState === 1) {
29
+ await mongoose.connection.db?.admin().ping();
30
+ healthData.database = 'connected';
31
+ }
32
+ <%_ } else { -%>
33
+ await sequelize.authenticate();
34
+ healthData.database = 'connected';
35
+ <%_ } -%>
36
+ } catch (err) {
37
+ healthData.database = 'error';
38
+ healthData.status = 'DOWN';
39
+ logger.error(`${ERROR_MESSAGES.DATABASE_PING_FAILED}:`, err);
40
+ return res.status(HTTP_STATUS.INTERNAL_SERVER_ERROR).json(healthData);
41
+ }
42
+ <%_ } else { -%>
43
+ healthData.database = 'None';
44
+ <%_ } -%>
45
+
46
+ res.status(HTTP_STATUS.OK).json(healthData);
47
+ });
48
+
49
+ export default router;
@@ -1,32 +1,32 @@
1
- module.exports = {
2
- testEnvironment: 'node',
3
- coverageDirectory: 'coverage',
4
- collectCoverageFrom: ['src/**/*.{js,ts}'],
5
- testMatch: ['**/*.test.ts', '**/*.test.js', '**/*.spec.ts', '**/*.spec.js'],
6
- testPathIgnorePatterns: ['/node_modules/', '/tests/e2e/'],
7
- <% if (language === 'TypeScript') { %>preset: 'ts-jest',<% } %>
8
- moduleNameMapper: {
9
- '^@/(.*)$': '<rootDir>/src/$1',
10
- },
11
- coveragePathIgnorePatterns: [
12
- "/node_modules/",
13
- "/dist/",
14
- "src/index",
15
- "src/app",
16
- "src/config/env",
17
- "src/infrastructure/config/env",
18
- "src/config/swagger",
19
- "src/infrastructure/webserver/swagger",
20
- "src/infrastructure/webserver/server",
21
- "src/utils/logger",
22
- "src/infrastructure/log/logger"
23
- ],
24
- coverageThreshold: {
25
- global: {
26
- branches: 70,
27
- functions: 80,
28
- lines: 80,
29
- statements: 80
30
- }
31
- }
32
- };
1
+ module.exports = {
2
+ testEnvironment: 'node',
3
+ coverageDirectory: 'coverage',
4
+ collectCoverageFrom: ['src/**/*.{js,ts}'],
5
+ testMatch: ['**/*.test.ts', '**/*.test.js', '**/*.spec.ts', '**/*.spec.js'],
6
+ testPathIgnorePatterns: ['/node_modules/', '/tests/e2e/'],
7
+ <% if (language === 'TypeScript') { %>preset: 'ts-jest',<% } %>
8
+ moduleNameMapper: {
9
+ '^@/(.*)$': '<rootDir>/src/$1',
10
+ },
11
+ coveragePathIgnorePatterns: [
12
+ "/node_modules/",
13
+ "/dist/",
14
+ "src/index",
15
+ "src/app",
16
+ "src/config/env",
17
+ "src/infrastructure/config/env",
18
+ "src/config/swagger",
19
+ "src/infrastructure/webserver/swagger",
20
+ "src/infrastructure/webserver/server",
21
+ "src/utils/logger",
22
+ "src/infrastructure/log/logger"
23
+ ],
24
+ coverageThreshold: {
25
+ global: {
26
+ branches: 70,
27
+ functions: 80,
28
+ lines: 80,
29
+ statements: 80
30
+ }
31
+ }
32
+ };
@@ -1,8 +1,8 @@
1
- <%_ if (language === 'TypeScript') { _%>/* eslint-disable @typescript-eslint/no-require-imports */<%_ } _%>
2
- module.exports = {
3
- ...require('./jest.config'),
4
- testMatch: ['<rootDir>/tests/e2e/**/*.test.ts', '<rootDir>/tests/e2e/**/*.test.js'],
5
- testPathIgnorePatterns: ['/node_modules/'],
6
- testTimeout: 30000,
7
- clearMocks: true
8
- };
1
+ <%_ if (language === 'TypeScript') { -%>/* eslint-disable @typescript-eslint/no-require-imports */<%_ } -%>
2
+ module.exports = {
3
+ ...require('./jest.config'),
4
+ testMatch: ['<rootDir>/tests/e2e/**/*.test.ts', '<rootDir>/tests/e2e/**/*.test.js'],
5
+ testPathIgnorePatterns: ['/node_modules/'],
6
+ testTimeout: 30000,
7
+ clearMocks: true
8
+ };
@@ -1,9 +1,9 @@
1
- const { Kafka } = require('kafkajs');
2
- const { env } = require('./env');
3
-
4
- const kafka = new Kafka({
5
- clientId: 'nodejs-service',
6
- brokers: [env.KAFKA_BROKER]
7
- });
8
-
9
- module.exports = { kafka };
1
+ const { Kafka } = require('kafkajs');
2
+ const { env } = require('./env');
3
+
4
+ const kafka = new Kafka({
5
+ clientId: 'nodejs-service',
6
+ brokers: [env.KAFKA_BROKER]
7
+ });
8
+
9
+ module.exports = { kafka };
@@ -1,27 +1,27 @@
1
- const { Kafka } = require('kafkajs');
2
-
3
- jest.mock('kafkajs', () => {
4
- return {
5
- Kafka: jest.fn().mockImplementation(() => ({
6
- producer: jest.fn(),
7
- consumer: jest.fn(),
8
- })),
9
- };
10
- });
11
-
12
- jest.mock('<% if (architecture === "MVC") { %>@/config/env<% } else { %>@/infrastructure/config/env<% } %>', () => ({
13
- env: {
14
- KAFKA_BROKER: 'localhost:9092'
15
- }
16
- }));
17
-
18
- describe('Kafka Configuration', () => {
19
- beforeEach(() => {
20
- jest.clearAllMocks();
21
- });
22
-
23
- it('should initialize Kafka', () => {
24
- require('<% if (architecture === "MVC") { %>@/config/kafka<% } else { %>@/infrastructure/config/kafka<% } %>');
25
- expect(Kafka).toHaveBeenCalled();
26
- });
27
- });
1
+ const { Kafka } = require('kafkajs');
2
+
3
+ jest.mock('kafkajs', () => {
4
+ return {
5
+ Kafka: jest.fn().mockImplementation(() => ({
6
+ producer: jest.fn(),
7
+ consumer: jest.fn(),
8
+ })),
9
+ };
10
+ });
11
+
12
+ jest.mock('<% if (architecture === "MVC") { %>@/config/env<% } else { %>@/infrastructure/config/env<% } %>', () => ({
13
+ env: {
14
+ KAFKA_BROKER: 'localhost:9092'
15
+ }
16
+ }));
17
+
18
+ describe('Kafka Configuration', () => {
19
+ beforeEach(() => {
20
+ jest.clearAllMocks();
21
+ });
22
+
23
+ it('should initialize Kafka', () => {
24
+ require('<% if (architecture === "MVC") { %>@/config/kafka<% } else { %>@/infrastructure/config/kafka<% } %>');
25
+ expect(Kafka).toHaveBeenCalled();
26
+ });
27
+ });
@@ -1,30 +1,30 @@
1
- const logger = require('<% if (architecture === "Clean Architecture") { %>../../infrastructure/log/logger<% } else { %>../utils/logger<% } %>');
2
-
3
- class BaseConsumer {
4
- constructor() {
5
- if (this.constructor === BaseConsumer) {
6
- throw new Error("Abstract class 'BaseConsumer' cannot be instantiated.");
7
- }
8
- }
9
-
10
- get topic() { throw new Error("Property 'topic' must be implemented"); }
11
- get groupId() { throw new Error("Property 'groupId' must be implemented"); }
12
-
13
- async onMessage({ message }) {
14
- try {
15
- const rawValue = message.value?.toString();
16
- if (!rawValue) return;
17
-
18
- const data = JSON.parse(rawValue);
19
- await this.handle(data);
20
- } catch (error) {
21
- logger.error(`[Kafka] Error processing message on topic ${this.topic}:`, error);
22
- }
23
- }
24
-
25
- async handle(data) {
26
- throw new Error("Method 'handle()' must be implemented");
27
- }
28
- }
29
-
30
- module.exports = BaseConsumer;
1
+ const logger = require('<%- loggerPath %>');
2
+
3
+ class BaseConsumer {
4
+ constructor() {
5
+ if (this.constructor === BaseConsumer) {
6
+ throw new Error("Abstract class 'BaseConsumer' cannot be instantiated.");
7
+ }
8
+ }
9
+
10
+ get topic() { throw new Error("Property 'topic' must be implemented"); }
11
+ get groupId() { throw new Error("Property 'groupId' must be implemented"); }
12
+
13
+ async onMessage({ message }) {
14
+ try {
15
+ const rawValue = message.value?.toString();
16
+ if (!rawValue) return;
17
+
18
+ const data = JSON.parse(rawValue);
19
+ await this.handle(data);
20
+ } catch (error) {
21
+ logger.error(`[Kafka] Error processing message on topic ${this.topic}:`, error);
22
+ }
23
+ }
24
+
25
+ async handle(data) {
26
+ throw new Error("Method 'handle()' must be implemented");
27
+ }
28
+ }
29
+
30
+ module.exports = BaseConsumer;