generator-jhipster 7.2.0 → 7.4.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 (313) hide show
  1. package/cli/environment-builder.js +1 -0
  2. package/cli/import-jdl.js +3 -2
  3. package/cli/jdl.js +1 -0
  4. package/cli/jhipster-command.js +2 -2
  5. package/cli/program.js +32 -29
  6. package/generators/app/index.js +35 -26
  7. package/generators/aws/index.js +8 -8
  8. package/generators/aws/lib/eb.js +1 -1
  9. package/generators/azure-app-service/index.js +16 -9
  10. package/generators/azure-app-service/templates/github/workflows/azure-app-service.yml.ejs +2 -2
  11. package/generators/azure-spring-cloud/index.js +16 -9
  12. package/generators/azure-spring-cloud/templates/github/workflows/azure-spring-cloud.yml.ejs +2 -2
  13. package/generators/bootstrap/index.js +57 -61
  14. package/generators/ci-cd/index.js +11 -8
  15. package/generators/ci-cd/templates/github-actions.yml.ejs +1 -1
  16. package/generators/ci-cd/templates/travis.yml.ejs +9 -4
  17. package/generators/client/__workflow/devserver-angular.json +1 -1
  18. package/generators/client/__workflow/devserver-react.json +1 -1
  19. package/generators/client/__workflow/devserver-vue.json +1 -1
  20. package/generators/client/files-angular.js +6 -0
  21. package/generators/client/files-common.js +6 -2
  22. package/generators/client/files-react.js +13 -2
  23. package/generators/client/files-vue.js +56 -6
  24. package/generators/client/index.js +114 -32
  25. package/generators/client/needle-api/needle-client-angular.js +1 -1
  26. package/generators/client/needle-api/needle-client-vue.js +57 -7
  27. package/generators/client/templates/angular/.eslintrc.json.ejs +1 -0
  28. package/generators/client/templates/angular/package.json +19 -19
  29. package/generators/client/templates/angular/package.json.ejs +2 -1
  30. package/generators/client/templates/angular/src/main/webapp/app/account/activate/activate.component.spec.ts.ejs +52 -54
  31. package/generators/client/templates/angular/src/main/webapp/app/account/activate/activate.service.spec.ts.ejs +65 -0
  32. package/generators/client/templates/angular/src/main/webapp/app/account/password/password-strength-bar/password-strength-bar.component.spec.ts.ejs +35 -37
  33. package/generators/client/templates/angular/src/main/webapp/app/account/password/password.component.spec.ts.ejs +78 -80
  34. package/generators/client/templates/angular/src/main/webapp/app/account/password/password.service.spec.ts.ejs +41 -0
  35. package/generators/client/templates/angular/src/main/webapp/app/account/password-reset/finish/password-reset-finish.component.spec.ts.ejs +73 -75
  36. package/generators/client/templates/angular/src/main/webapp/app/account/password-reset/finish/password-reset-finish.service.spec.ts.ejs +62 -0
  37. package/generators/client/templates/angular/src/main/webapp/app/account/password-reset/init/password-reset-init.component.spec.ts.ejs +44 -46
  38. package/generators/client/templates/angular/src/main/webapp/app/account/password-reset/init/password-reset-init.service.spec.ts.ejs +61 -0
  39. package/generators/client/templates/angular/src/main/webapp/app/account/register/register.component.spec.ts.ejs +116 -118
  40. package/generators/client/templates/angular/src/main/webapp/app/account/register/register.service.spec.ts.ejs +66 -0
  41. package/generators/client/templates/angular/src/main/webapp/app/account/sessions/sessions.component.spec.ts.ejs +75 -77
  42. package/generators/client/templates/angular/src/main/webapp/app/account/settings/settings.component.spec.ts.ejs +74 -76
  43. package/generators/client/templates/angular/src/main/webapp/app/admin/configuration/configuration.component.spec.ts.ejs +48 -50
  44. package/generators/client/templates/angular/src/main/webapp/app/admin/configuration/configuration.service.spec.ts.ejs +50 -52
  45. package/generators/client/templates/angular/src/main/webapp/app/admin/health/health.component.spec.ts.ejs +45 -47
  46. package/generators/client/templates/angular/src/main/webapp/app/admin/health/health.service.spec.ts.ejs +66 -0
  47. package/generators/client/templates/angular/src/main/webapp/app/admin/health/modal/health-modal.component.spec.ts.ejs +99 -101
  48. package/generators/client/templates/angular/src/main/webapp/app/admin/logs/logs.component.spec.ts.ejs +61 -63
  49. package/generators/client/templates/angular/src/main/webapp/app/admin/logs/logs.service.spec.ts.ejs +19 -21
  50. package/generators/client/templates/angular/src/main/webapp/app/admin/metrics/blocks/jvm-memory/jvm-memory.component.html.ejs +2 -2
  51. package/generators/client/templates/angular/src/main/webapp/app/admin/metrics/metrics.component.spec.ts.ejs +28 -30
  52. package/generators/client/templates/angular/src/main/webapp/app/admin/metrics/metrics.service.spec.ts.ejs +62 -64
  53. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/delete/user-management-delete-dialog.component.spec.ts.ejs +35 -37
  54. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/detail/user-management-detail.component.spec.ts.ejs +40 -42
  55. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/list/user-management.component.spec.ts.ejs +87 -89
  56. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/service/user-management.service.spec.ts.ejs +41 -43
  57. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/update/user-management-update.component.spec.ts.ejs +81 -83
  58. package/generators/client/templates/angular/src/main/webapp/app/app.module.ts.ejs +3 -0
  59. package/generators/client/templates/angular/src/main/webapp/app/core/auth/account.service.spec.ts.ejs +178 -180
  60. package/generators/client/templates/angular/src/main/webapp/app/core/config/application-config.service.ts.ejs +9 -0
  61. package/generators/client/templates/angular/src/main/webapp/app/entities/user/user.service.spec.ts.ejs +87 -89
  62. package/generators/client/templates/angular/src/main/webapp/app/home/home.component.spec.ts.ejs +93 -95
  63. package/generators/client/templates/angular/src/main/webapp/app/layouts/main/main.component.spec.ts.ejs +166 -168
  64. package/generators/client/templates/angular/src/main/webapp/app/layouts/navbar/navbar.component.spec.ts.ejs +66 -68
  65. package/generators/client/templates/angular/src/main/webapp/app/layouts/profiles/page-ribbon.component.spec.ts.ejs +27 -29
  66. package/generators/client/templates/angular/src/main/webapp/app/login/login.component.spec.ts.ejs +112 -114
  67. package/generators/client/templates/angular/src/main/webapp/app/shared/alert/alert-error.component.spec.ts.ejs +132 -134
  68. package/generators/client/templates/angular/src/main/webapp/app/shared/alert/alert.component.spec.ts.ejs +29 -31
  69. package/generators/client/templates/angular/webpack/webpack.custom.js.ejs +2 -3
  70. package/generators/client/templates/common/README.md.jhi.client.ejs +34 -0
  71. package/generators/client/templates/common/package.json +7 -7
  72. package/generators/client/templates/common/webpack/webpack.microfrontend.js.jhi.ejs +56 -0
  73. package/generators/client/templates/react/.eslintrc.json.ejs +1 -0
  74. package/generators/client/templates/react/package.json +57 -56
  75. package/generators/client/templates/react/package.json.ejs +5 -2
  76. package/generators/client/templates/react/src/main/webapp/app/app.scss.ejs +0 -3
  77. package/generators/client/templates/react/src/main/webapp/app/modules/account/password/password.tsx.ejs +2 -2
  78. package/generators/client/templates/react/src/main/webapp/app/modules/administration/configuration/configuration.tsx.ejs +2 -2
  79. package/generators/client/templates/react/src/main/webapp/app/modules/administration/gateway/gateway.tsx.ejs +2 -2
  80. package/generators/client/templates/react/src/main/webapp/app/modules/administration/metrics/metrics.tsx.ejs +6 -6
  81. package/generators/client/templates/react/src/main/webapp/app/modules/administration/user-management/user-management.tsx.ejs +8 -8
  82. package/generators/client/templates/react/src/main/webapp/app/modules/home/home.tsx.ejs +1 -1
  83. package/generators/client/templates/react/src/main/webapp/app/shared/layout/header/header.tsx.ejs +1 -1
  84. package/generators/client/templates/react/src/main/webapp/app/shared/layout/menus/account.tsx.ejs +3 -3
  85. package/generators/client/templates/react/src/main/webapp/app/shared/layout/menus/admin.tsx.ejs +7 -7
  86. package/generators/client/templates/react/src/main/webapp/app/shared/layout/menus/menu-components.tsx.ejs +1 -1
  87. package/generators/client/templates/react/webpack/webpack.dev.js.ejs +17 -1
  88. package/generators/client/templates/react/webpack/webpack.prod.js.ejs +13 -1
  89. package/generators/client/templates/vue/.eslintrc.js.ejs +8 -5
  90. package/generators/client/templates/vue/package.json +40 -49
  91. package/generators/client/templates/vue/package.json.ejs +14 -18
  92. package/generators/client/templates/vue/src/main/webapp/app/account/account.service.ts.ejs +6 -5
  93. package/generators/client/templates/vue/src/main/webapp/app/account/settings/settings.vue.ejs +7 -1
  94. package/generators/client/templates/vue/src/main/webapp/app/admin/configuration/configuration.service.ts.ejs +1 -1
  95. package/generators/client/templates/vue/src/main/webapp/app/admin/configuration/configuration.vue.ejs +1 -1
  96. package/generators/client/templates/vue/src/main/webapp/app/admin/metrics/metrics.component.ts.ejs +1 -1
  97. package/generators/client/templates/vue/src/main/webapp/app/admin/tracker/tracker.service.ts.ejs +5 -4
  98. package/generators/client/templates/vue/src/main/webapp/app/admin/user-management/user-management-edit.component.ts.ejs +9 -0
  99. package/generators/client/templates/vue/src/main/webapp/app/admin/user-management/user-management-view.component.ts.ejs +5 -0
  100. package/generators/client/templates/vue/src/main/webapp/app/admin/user-management/user-management.component.ts.ejs +5 -0
  101. package/generators/client/templates/vue/src/main/webapp/app/constants.ts.ejs +16 -6
  102. package/generators/client/templates/vue/src/main/webapp/app/core/jhi-navbar/jhi-navbar.component.ts.ejs +27 -8
  103. package/generators/client/templates/vue/src/main/webapp/app/core/jhi-navbar/jhi-navbar.vue.ejs +6 -0
  104. package/generators/client/templates/vue/src/main/webapp/app/declarations.d.ts.ejs +41 -0
  105. package/generators/client/templates/vue/src/main/webapp/app/entities/entities-menu.component.ts.ejs +34 -0
  106. package/generators/client/templates/vue/src/main/webapp/app/entities/entities-menu.vue.ejs +13 -0
  107. package/generators/client/templates/vue/src/main/webapp/app/entities/entities.component.ts.ejs +14 -0
  108. package/generators/client/templates/vue/src/main/webapp/app/entities/entities.vue.ejs +5 -0
  109. package/generators/client/templates/vue/{webpack/utils.js.ejs → src/main/webapp/app/index.ts.ejs} +1 -12
  110. package/generators/client/templates/vue/src/main/webapp/app/locale/translation.service.ts.ejs +26 -9
  111. package/generators/client/templates/vue/src/main/webapp/app/main.ts.ejs +23 -11
  112. package/generators/client/templates/vue/src/main/webapp/app/router/admin.ts.ejs +4 -4
  113. package/generators/client/templates/vue/src/main/webapp/app/router/entities.ts.ejs +45 -3
  114. package/generators/client/templates/vue/src/main/webapp/app/router/index.ts.ejs +19 -3
  115. package/generators/client/templates/vue/src/main/webapp/app/shared/alert/alert.service.ts.ejs +61 -0
  116. package/generators/client/templates/vue/src/main/webapp/app/shared/config/axios-interceptor.ts.ejs +0 -2
  117. package/generators/client/templates/vue/src/main/webapp/app/shared/data/data-utils.service.ts.ejs +3 -1
  118. package/generators/client/templates/vue/src/main/webapp/app/shims-vue.d.ts.ejs +17 -3
  119. package/generators/client/templates/vue/src/test/javascript/jest.conf.js.ejs +25 -10
  120. package/generators/client/templates/vue/src/test/javascript/spec/app/account/account.service.spec.ts.ejs +2 -2
  121. package/generators/client/templates/vue/src/test/javascript/spec/app/account/login-form/login-form.component.spec.ts.ejs +2 -2
  122. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/tracker/tracker.component.spec.ts.ejs +12 -12
  123. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/tracker/tracker.service.spec.ts.ejs +2 -1
  124. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/user-management/user-management-edit.component.spec.ts.ejs +5 -1
  125. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/user-management/user-management-view.component.spec.ts.ejs +2 -1
  126. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/user-management/user-management.component.spec.ts.ejs +5 -1
  127. package/generators/client/templates/vue/src/test/javascript/spec/app/core/jhi-navbar/jhi-navbar.component.spec.ts.ejs +10 -4
  128. package/generators/client/templates/vue/src/test/javascript/spec/app/entities/entities-menu.spec.ts.ejs +52 -0
  129. package/generators/client/templates/vue/src/test/javascript/spec/app/microfrontends/entities-menu.component.ts.ejs +4 -0
  130. package/generators/client/templates/vue/src/test/javascript/spec/app/microfrontends/entities-menu.vue.ejs +7 -0
  131. package/generators/client/templates/vue/src/test/javascript/spec/app/microfrontends/entities-router.ts.ejs +1 -0
  132. package/generators/client/templates/vue/src/test/javascript/spec/app/shared/alert/alert.service.spec.ts.ejs +124 -0
  133. package/generators/client/templates/vue/src/test/javascript/spec/app/shared/config/axios-interceptor.spec.ts.ejs +0 -1
  134. package/generators/client/templates/vue/tsconfig.json.ejs +6 -10
  135. package/generators/client/templates/vue/tsconfig.spec.json.ejs +37 -0
  136. package/generators/client/templates/vue/webpack/config.js.ejs +50 -0
  137. package/generators/client/templates/vue/webpack/vue.utils.js.ejs +33 -32
  138. package/generators/client/templates/vue/webpack/webpack.common.js.ejs +152 -126
  139. package/generators/client/templates/vue/webpack/webpack.dev.js.ejs +19 -76
  140. package/generators/client/templates/vue/webpack/webpack.microfrontend.js.jhi.vue.ejs +77 -0
  141. package/generators/client/templates/vue/webpack/webpack.prod.js.ejs +5 -41
  142. package/generators/cloudfoundry/index.js +9 -9
  143. package/generators/common/index.js +12 -10
  144. package/generators/common/templates/.husky/pre-commit +1 -1
  145. package/generators/common/templates/.prettierrc.ejs +1 -1
  146. package/generators/common/templates/README.md.jhi.ejs +21 -0
  147. package/generators/common/templates/package.json +4 -4
  148. package/generators/cypress/index.js +12 -9
  149. package/generators/cypress/templates/cypress.json.ejs +9 -2
  150. package/generators/cypress/templates/src/test/javascript/cypress/plugins/index.ts.ejs +4 -4
  151. package/generators/cypress/templates/src/test/javascript/cypress/support/commands.ts.ejs +30 -2
  152. package/generators/cypress/templates/src/test/javascript/cypress/support/entity.ts.ejs +4 -4
  153. package/generators/cypress/templates/src/test/javascript/cypress/support/index.ts.ejs +1 -1
  154. package/generators/cypress/templates/src/test/javascript/cypress/support/management.ts.ejs +1 -1
  155. package/generators/cypress/templates/src/test/javascript/cypress/support/navbar.ts.ejs +1 -1
  156. package/generators/database-changelog/index.js +33 -22
  157. package/generators/database-changelog-liquibase/index.js +12 -8
  158. package/generators/database-changelog-liquibase/templates/src/main/resources/config/liquibase/changelog/updated_entity_constraints.xml.ejs +1 -1
  159. package/generators/docker-compose/index.js +11 -12
  160. package/generators/docker-compose/templates/realm-config/jhipster-realm.json.ejs +13 -12
  161. package/generators/entities/index.js +35 -26
  162. package/generators/entities-client/index.js +10 -7
  163. package/generators/entity/index.js +49 -29
  164. package/generators/entity-client/files.js +7 -16
  165. package/generators/entity-client/index.js +74 -11
  166. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/delete/entity-management-delete-dialog.component.spec.ts.ejs +42 -44
  167. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/detail/entity-management-detail.component.spec.ts.ejs +58 -60
  168. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/entity-management.module.ts.ejs +1 -1
  169. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/list/entity-management.component.spec.ts.ejs +105 -107
  170. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/list/entity-management.component.ts.ejs +8 -1
  171. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/route/entity-management-routing-resolve.service.spec.ts.ejs +52 -54
  172. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/route/entity-management-routing.module.ts.ejs +1 -1
  173. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/service/entity.service.spec.ts.ejs +173 -175
  174. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/update/entity-management-update.component.html.ejs +2 -4
  175. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/update/entity-management-update.component.spec.ts.ejs +193 -195
  176. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/update/entity-management-update.component.ts.ejs +7 -0
  177. package/generators/entity-client/templates/common/src/test/javascript/cypress/integration/entity/entity.spec.ts.ejs +269 -109
  178. package/generators/entity-client/templates/react/src/main/webapp/app/entities/entity-delete-dialog.tsx.ejs +5 -2
  179. package/generators/entity-client/templates/react/src/main/webapp/app/entities/entity-update.tsx.ejs +17 -14
  180. package/generators/entity-client/templates/react/src/main/webapp/app/entities/entity.tsx.ejs +11 -13
  181. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity-details.component.ts.ejs +5 -0
  182. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity-update.component.ts.ejs +23 -8
  183. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity-update.vue.ejs +6 -9
  184. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity.component.ts.ejs +9 -1
  185. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity.model.ts.ejs +1 -1
  186. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity.service.ts.ejs +2 -6
  187. package/generators/entity-client/templates/vue/src/test/javascript/spec/app/entities/entity-details.component.spec.ts.ejs +2 -1
  188. package/generators/entity-client/templates/vue/src/test/javascript/spec/app/entities/entity-update.component.spec.ts.ejs +8 -1
  189. package/generators/entity-client/templates/vue/src/test/javascript/spec/app/entities/entity.component.spec.ts.ejs +8 -2
  190. package/generators/entity-client/templates/vue/src/test/javascript/spec/app/entities/entity.service.spec.ts.ejs +1 -1
  191. package/generators/entity-i18n/index.js +7 -4
  192. package/generators/entity-server/files-couchbase.js +2 -2
  193. package/generators/entity-server/files.js +35 -30
  194. package/generators/entity-server/index.js +12 -8
  195. package/generators/entity-server/templates/couchbase/src/main/java/package/repository/EntityRepository.java.ejs +2 -2
  196. package/generators/entity-server/templates/couchbase/src/main/resources/config/couchmove/changelog/entity.fts.ejs +1 -1
  197. package/generators/entity-server/templates/src/main/java/package/domain/Entity.java.jhi.ejs +6 -2
  198. package/generators/entity-server/templates/src/main/java/package/domain/enumeration/Enum.java.ejs +1 -1
  199. package/generators/entity-server/templates/src/main/java/package/repository/EntityRepository.java.ejs +2 -2
  200. package/generators/entity-server/templates/src/main/java/package/repository/EntityRepositoryInternalImpl_reactive.java.ejs +17 -30
  201. package/generators/entity-server/templates/src/main/java/package/repository/EntityRepository_reactive.java.ejs +5 -5
  202. package/generators/entity-server/templates/src/main/java/package/repository/EntitySqlHelper_reactive.java.ejs +46 -0
  203. package/generators/entity-server/templates/src/main/java/package/repository/rowmapper/EntityRowMapper.java.ejs +3 -3
  204. package/generators/entity-server/templates/src/main/java/package/repository/search/EntitySearchRepository.java.ejs +2 -2
  205. package/generators/entity-server/templates/src/main/java/package/service/EntityQueryService.java.ejs +8 -8
  206. package/generators/entity-server/templates/src/main/java/package/service/EntityService.java.ejs +4 -4
  207. package/generators/entity-server/templates/src/main/java/package/service/criteria/EntityCriteria.java.ejs +4 -4
  208. package/generators/entity-server/templates/src/main/java/package/service/dto/EntityDTO.java.ejs +7 -3
  209. package/generators/entity-server/templates/src/main/java/package/service/impl/EntityServiceImpl.java.ejs +8 -8
  210. package/generators/entity-server/templates/src/main/java/package/service/mapper/BaseEntityMapper.java.ejs +1 -1
  211. package/generators/entity-server/templates/src/main/java/package/service/mapper/EntityMapper.java.ejs +7 -3
  212. package/generators/entity-server/templates/src/main/java/package/web/rest/EntityResource.java.ejs +51 -53
  213. package/generators/entity-server/templates/src/test/java/package/domain/EntityTest.java.ejs +1 -1
  214. package/generators/entity-server/templates/src/test/java/package/repository/search/EntitySearchRepositoryMockConfiguration.java.ejs +1 -1
  215. package/generators/entity-server/templates/src/test/java/package/service/dto/EntityDTOTest.java.ejs +1 -1
  216. package/generators/entity-server/templates/src/test/java/package/service/mapper/EntityMapperTest.java.ejs +1 -1
  217. package/generators/entity-server/templates/src/test/java/package/web/rest/EntityResourceIT.java.ejs +17 -14
  218. package/generators/gae/index.js +10 -10
  219. package/generators/generator-base-blueprint.js +14 -46
  220. package/generators/generator-base-private.js +42 -22
  221. package/generators/generator-base.js +57 -20
  222. package/generators/generator-constants.js +29 -21
  223. package/generators/generator-transforms.js +39 -27
  224. package/generators/heroku/index.js +27 -48
  225. package/generators/init/constants.cjs +1 -1
  226. package/generators/init/templates/.husky/pre-commit +1 -1
  227. package/generators/java/constants.cjs +1 -1
  228. package/generators/kubernetes/files.js +3 -0
  229. package/generators/kubernetes/index.js +10 -10
  230. package/generators/kubernetes/templates/db/couchbase.yml.ejs +1 -1
  231. package/generators/kubernetes/templates/deployment.yml.ejs +8 -3
  232. package/generators/kubernetes/templates/istio/destination-rule.yml.ejs +1 -1
  233. package/generators/kubernetes/templates/istio/gateway/grafana-gateway.yml.ejs +5 -2
  234. package/generators/kubernetes/templates/istio/gateway/jhipster-grafana-gateway.yml.ejs +5 -2
  235. package/generators/kubernetes/templates/istio/gateway/kiali-gateway.yml.ejs +10 -8
  236. package/generators/kubernetes/templates/istio/gateway/zipkin-gateway.yml.ejs +5 -2
  237. package/generators/kubernetes/templates/istio/gateway.yml.ejs +7 -5
  238. package/generators/kubernetes/templates/secret/couchbase-secret.yml.ejs +9 -0
  239. package/generators/kubernetes-base.js +1 -0
  240. package/generators/kubernetes-helm/files.js +3 -8
  241. package/generators/kubernetes-helm/index.js +10 -10
  242. package/generators/kubernetes-helm/templates/README-KUBERNETES-HELM.md.ejs +0 -1
  243. package/generators/kubernetes-helm/templates/app/Chart.yml.ejs +27 -0
  244. package/generators/kubernetes-helm/templates/app/helpers.tpl.ejs +0 -11
  245. package/generators/kubernetes-helm/templates/app/requirements.yml.ejs +7 -2
  246. package/generators/kubernetes-helm/templates/app/values.yml.ejs +68 -5
  247. package/generators/kubernetes-helm/templates/csvc/Chart.yml.ejs +17 -0
  248. package/generators/kubernetes-helm/templates/csvc/requirements.yml.ejs +2 -2
  249. package/generators/kubernetes-knative/index.js +10 -10
  250. package/generators/kubernetes-knative/templates/istio/gateway.yml.ejs +6 -4
  251. package/generators/kubernetes-knative/templates/service.yml.ejs +1 -1
  252. package/generators/languages/index.js +13 -13
  253. package/generators/languages/templates/src/main/webapp/i18n/hr/reset.json.ejs +1 -2
  254. package/generators/languages/templates/src/main/webapp/i18n/vi/login.json +1 -1
  255. package/generators/maven/templates/.mvn/wrapper/maven-wrapper.properties +1 -1
  256. package/generators/openapi-client/index.js +13 -10
  257. package/generators/openshift/index.js +10 -11
  258. package/generators/openshift/templates/deployment.yml.ejs +1 -1
  259. package/generators/page/index.js +12 -10
  260. package/generators/server/__snapshots__/generator.spec.mjs.snap +12 -0
  261. package/generators/server/files-sql.js +52 -0
  262. package/generators/server/files.js +15 -0
  263. package/generators/server/index.js +100 -33
  264. package/generators/server/needle-api/needle-server-cache.js +4 -6
  265. package/generators/server/templates/.mvn/wrapper/maven-wrapper.properties +1 -1
  266. package/generators/server/templates/build.gradle.ejs +17 -1
  267. package/generators/server/templates/gradle.properties.ejs +11 -11
  268. package/generators/server/templates/npmw +1 -1
  269. package/generators/server/templates/npmw.cmd +1 -1
  270. package/generators/server/templates/pom.xml.ejs +128 -9
  271. package/generators/server/templates/settings.gradle.ejs +9 -0
  272. package/generators/server/templates/sql/reactive/src/main/java/package/repository/UserSqlHelper.java.ejs +48 -0
  273. package/generators/server/templates/src/main/docker/app.yml.ejs +2 -1
  274. package/generators/server/templates/src/main/docker/config/realm-config/jhipster-realm.json.ejs +13 -12
  275. package/generators/server/templates/src/main/java/package/aop/logging/LoggingAspect.java.ejs +1 -1
  276. package/generators/server/templates/src/main/java/package/config/DatabaseConfiguration_cassandra.java.ejs +0 -6
  277. package/generators/server/templates/src/main/java/package/config/DatabaseConfiguration_sql.java.ejs +2 -2
  278. package/generators/server/templates/src/main/java/package/config/JacksonConfiguration.java.ejs +1 -1
  279. package/generators/server/templates/src/main/java/package/config/LocaleConfiguration.java.ejs +0 -2
  280. package/generators/server/templates/src/main/java/package/config/SecurityConfiguration.java.ejs +2 -5
  281. package/generators/server/templates/src/main/java/package/config/SecurityConfiguration_reactive.java.ejs +9 -1
  282. package/generators/server/templates/src/main/java/package/config/WebConfigurer.java.ejs +0 -1
  283. package/generators/server/templates/src/main/java/package/management/SecurityMetersService.java.ejs +68 -0
  284. package/generators/server/templates/src/main/java/package/repository/UserRepository.java.ejs +0 -23
  285. package/generators/server/templates/src/main/java/package/security/PersistentTokenRememberMeServices.java.ejs +0 -2
  286. package/generators/server/templates/src/main/java/package/security/jwt/TokenProvider.java.ejs +29 -4
  287. package/generators/server/templates/src/main/java/package/security/oauth2/CustomClaimConverter.java.ejs +21 -9
  288. package/generators/server/templates/src/main/java/package/service/UserService.java.ejs +13 -5
  289. package/generators/server/templates/src/main/resources/config/application-dev.yml.ejs +1 -1
  290. package/generators/server/templates/src/main/resources/config/application-prod.yml.ejs +1 -1
  291. package/generators/server/templates/src/main/resources/config/application.yml.ejs +7 -7
  292. package/generators/server/templates/src/main/resources/static/microservices_index.html.ejs +1 -1
  293. package/generators/server/templates/src/test/java/package/management/SecurityMetersServiceTests.java.ejs +113 -0
  294. package/generators/server/templates/src/test/java/package/security/jwt/JWTFilterTest.java.ejs +6 -1
  295. package/generators/server/templates/src/test/java/package/security/jwt/TokenProviderSecurityMetersTests.java.ejs +198 -0
  296. package/generators/server/templates/src/test/java/package/security/jwt/TokenProviderTest.java.ejs +13 -3
  297. package/generators/server/templates/src/test/java/package/security/oauth2/AuthorizationHeaderUtilTest.java.ejs +16 -2
  298. package/generators/server/templates/src/test/java/package/security/oauth2/CustomClaimConverterIT.java.ejs +63 -0
  299. package/generators/spring-controller/index.js +9 -7
  300. package/generators/spring-service/index.js +10 -7
  301. package/generators/upgrade/index.js +4 -5
  302. package/generators/utils.js +2 -2
  303. package/generators/workspaces/index.js +16 -7
  304. package/jdl/jhipster/default-application-options.js +9 -7
  305. package/package.json +23 -23
  306. package/utils/entity.js +21 -4
  307. package/utils/field.js +12 -2
  308. package/utils/multi-step-transform/index.js +8 -8
  309. package/generators/client/templates/react/.npmrc.ejs +0 -1
  310. package/generators/client/templates/vue/webpack/dev.env.js.ejs +0 -17
  311. package/generators/client/templates/vue/webpack/env.js.ejs +0 -67
  312. package/generators/client/templates/vue/webpack/loader.conf.js.ejs +0 -20
  313. package/generators/client/templates/vue/webpack/prod.env.js.ejs +0 -15
@@ -31,57 +31,55 @@ import { <%= entityAngularName %>Service } from '../service/<%= entityFileName %
31
31
 
32
32
  import { <%= entityAngularName %>DeleteDialogComponent } from './<%= entityFileName %>-delete-dialog.component';
33
33
 
34
- describe('Component Tests', () => {
35
- describe('<%= entityAngularName %> Management Delete Component', () => {
36
- let comp: <%= entityAngularName %>DeleteDialogComponent;
37
- let fixture: ComponentFixture<<%= entityAngularName %>DeleteDialogComponent>;
38
- let service: <%= entityAngularName %>Service;
39
- let mockActiveModal: NgbActiveModal;
34
+ describe('<%= entityAngularName %> Management Delete Component', () => {
35
+ let comp: <%= entityAngularName %>DeleteDialogComponent;
36
+ let fixture: ComponentFixture<<%= entityAngularName %>DeleteDialogComponent>;
37
+ let service: <%= entityAngularName %>Service;
38
+ let mockActiveModal: NgbActiveModal;
40
39
 
41
- beforeEach(() => {
42
- TestBed.configureTestingModule({
43
- imports: [HttpClientTestingModule],
44
- declarations: [<%= entityAngularName %>DeleteDialogComponent],
45
- providers: [NgbActiveModal]
46
- })
47
- .overrideTemplate(<%= entityAngularName %>DeleteDialogComponent, '')
48
- .compileComponents();
49
- fixture = TestBed.createComponent(<%= entityAngularName %>DeleteDialogComponent);
50
- comp = fixture.componentInstance;
51
- service = TestBed.inject(<%= entityAngularName %>Service);
52
- mockActiveModal = TestBed.inject(NgbActiveModal);
53
- });
40
+ beforeEach(() => {
41
+ TestBed.configureTestingModule({
42
+ imports: [HttpClientTestingModule],
43
+ declarations: [<%= entityAngularName %>DeleteDialogComponent],
44
+ providers: [NgbActiveModal]
45
+ })
46
+ .overrideTemplate(<%= entityAngularName %>DeleteDialogComponent, '')
47
+ .compileComponents();
48
+ fixture = TestBed.createComponent(<%= entityAngularName %>DeleteDialogComponent);
49
+ comp = fixture.componentInstance;
50
+ service = TestBed.inject(<%= entityAngularName %>Service);
51
+ mockActiveModal = TestBed.inject(NgbActiveModal);
52
+ });
54
53
 
55
- describe('confirmDelete', () => {
56
- it('Should call delete service on confirmDelete',
57
- inject([],
58
- fakeAsync(() => {
59
- // GIVEN
60
- jest.spyOn(service, 'delete').mockReturnValue(of(new HttpResponse({})));
54
+ describe('confirmDelete', () => {
55
+ it('Should call delete service on confirmDelete',
56
+ inject([],
57
+ fakeAsync(() => {
58
+ // GIVEN
59
+ jest.spyOn(service, 'delete').mockReturnValue(of(new HttpResponse({})));
61
60
 
62
- // WHEN
63
- comp.confirmDelete(<%- tsKeyId %>);
64
- tick();
61
+ // WHEN
62
+ comp.confirmDelete(<%- tsKeyId %>);
63
+ tick();
65
64
 
66
- // THEN
67
- expect(service.delete).toHaveBeenCalledWith(<%- tsKeyId %>);
68
- expect(mockActiveModal.close).toHaveBeenCalledWith('deleted');
69
- })
70
- )
71
- );
65
+ // THEN
66
+ expect(service.delete).toHaveBeenCalledWith(<%- tsKeyId %>);
67
+ expect(mockActiveModal.close).toHaveBeenCalledWith('deleted');
68
+ })
69
+ )
70
+ );
72
71
 
73
- it('Should not call delete service on clear', () => {
74
- // GIVEN
75
- jest.spyOn(service, 'delete');
72
+ it('Should not call delete service on clear', () => {
73
+ // GIVEN
74
+ jest.spyOn(service, 'delete');
76
75
 
77
- // WHEN
78
- comp.cancel();
76
+ // WHEN
77
+ comp.cancel();
79
78
 
80
- // THEN
81
- expect(service.delete).not.toHaveBeenCalled();
82
- expect(mockActiveModal.close).not.toHaveBeenCalled();
83
- expect(mockActiveModal.dismiss).toHaveBeenCalled();
84
- });
79
+ // THEN
80
+ expect(service.delete).not.toHaveBeenCalled();
81
+ expect(mockActiveModal.close).not.toHaveBeenCalled();
82
+ expect(mockActiveModal.dismiss).toHaveBeenCalled();
85
83
  });
86
84
  });
87
85
  });
@@ -30,78 +30,76 @@ import { DataUtils } from 'app/core/util/data-util.service';
30
30
 
31
31
  import { <%= entityAngularName %>DetailComponent } from './<%= entityFileName %>-detail.component';
32
32
 
33
- describe('Component Tests', () => {
34
- describe('<%= entityAngularName %> Management Detail Component', () => {
35
- let comp: <%= entityAngularName %>DetailComponent;
36
- let fixture: ComponentFixture<<%= entityAngularName %>DetailComponent>;
33
+ describe('<%= entityAngularName %> Management Detail Component', () => {
34
+ let comp: <%= entityAngularName %>DetailComponent;
35
+ let fixture: ComponentFixture<<%= entityAngularName %>DetailComponent>;
37
36
  <%_ if (fieldsContainBlob) { _%>
38
- let dataUtils: DataUtils;
37
+ let dataUtils: DataUtils;
39
38
  <%_ } _%>
40
39
 
41
- beforeEach(() => {
42
- TestBed.configureTestingModule({
43
- declarations: [<%= entityAngularName %>DetailComponent],
44
- providers: [
45
- {
46
- provide: ActivatedRoute,
47
- useValue: { data: of({ <%= entityInstance %>: <%- testEntity %> }) }
48
- }
49
- ]
50
- })
51
- .overrideTemplate(<%= entityAngularName %>DetailComponent, '')
52
- .compileComponents();
53
- fixture = TestBed.createComponent(<%= entityAngularName %>DetailComponent);
54
- comp = fixture.componentInstance;
40
+ beforeEach(() => {
41
+ TestBed.configureTestingModule({
42
+ declarations: [<%= entityAngularName %>DetailComponent],
43
+ providers: [
44
+ {
45
+ provide: ActivatedRoute,
46
+ useValue: { data: of({ <%= entityInstance %>: <%- testEntity %> }) }
47
+ }
48
+ ]
49
+ })
50
+ .overrideTemplate(<%= entityAngularName %>DetailComponent, '')
51
+ .compileComponents();
52
+ fixture = TestBed.createComponent(<%= entityAngularName %>DetailComponent);
53
+ comp = fixture.componentInstance;
55
54
  <%_ if (fieldsContainBlob) { _%>
56
- dataUtils = TestBed.inject(DataUtils);
57
- jest.spyOn(window, 'open').mockImplementation(() => null);
55
+ dataUtils = TestBed.inject(DataUtils);
56
+ jest.spyOn(window, 'open').mockImplementation(() => null);
58
57
  <%_ } _%>
59
- });
58
+ });
60
59
 
61
- describe('OnInit', () => {
62
- it('Should load <%= entityInstance %> on init', () => {
63
- // WHEN
64
- comp.ngOnInit();
60
+ describe('OnInit', () => {
61
+ it('Should load <%= entityInstance %> on init', () => {
62
+ // WHEN
63
+ comp.ngOnInit();
65
64
 
66
- // THEN
67
- expect(comp.<%= entityInstance %>).toEqual(expect.objectContaining(<%- testEntity %>));
68
- });
65
+ // THEN
66
+ expect(comp.<%= entityInstance %>).toEqual(expect.objectContaining(<%- testEntity %>));
69
67
  });
68
+ });
70
69
 
71
70
  <%_ if (fieldsContainBlob) { _%>
72
- describe('byteSize', () => {
73
- it('Should call byteSize from DataUtils', () => {
74
- // GIVEN
75
- jest.spyOn(dataUtils, 'byteSize');
76
- const fakeBase64 = 'fake base64';
77
-
78
- // WHEN
79
- comp.byteSize(fakeBase64);
80
-
81
- // THEN
82
- expect(dataUtils.byteSize).toBeCalledWith(fakeBase64);
83
- });
71
+ describe('byteSize', () => {
72
+ it('Should call byteSize from DataUtils', () => {
73
+ // GIVEN
74
+ jest.spyOn(dataUtils, 'byteSize');
75
+ const fakeBase64 = 'fake base64';
76
+
77
+ // WHEN
78
+ comp.byteSize(fakeBase64);
79
+
80
+ // THEN
81
+ expect(dataUtils.byteSize).toBeCalledWith(fakeBase64);
84
82
  });
83
+ });
85
84
 
86
- describe('openFile', () => {
87
- it('Should call openFile from DataUtils', () => {
88
- const newWindow = { ...window };
89
- newWindow.document.write = jest.fn();
90
- window.open = jest.fn(() => newWindow);
91
- window.onload = jest.fn(() => newWindow);
92
- window.URL.createObjectURL = jest.fn();
93
- // GIVEN
94
- jest.spyOn(dataUtils, 'openFile');
95
- const fakeContentType = 'fake content type';
96
- const fakeBase64 = 'fake base64';
97
-
98
- // WHEN
99
- comp.openFile(fakeBase64, fakeContentType);
100
-
101
- // THEN
102
- expect(dataUtils.openFile).toBeCalledWith(fakeBase64, fakeContentType);
103
- });
85
+ describe('openFile', () => {
86
+ it('Should call openFile from DataUtils', () => {
87
+ const newWindow = { ...window };
88
+ newWindow.document.write = jest.fn();
89
+ window.open = jest.fn(() => newWindow);
90
+ window.onload = jest.fn(() => newWindow);
91
+ window.URL.createObjectURL = jest.fn();
92
+ // GIVEN
93
+ jest.spyOn(dataUtils, 'openFile');
94
+ const fakeContentType = 'fake content type';
95
+ const fakeBase64 = 'fake base64';
96
+
97
+ // WHEN
98
+ comp.openFile(fakeBase64, fakeContentType);
99
+
100
+ // THEN
101
+ expect(dataUtils.openFile).toBeCalledWith(fakeBase64, fakeContentType);
104
102
  });
105
- <%_ } _%>
106
103
  });
104
+ <%_ } _%>
107
105
  });
@@ -35,7 +35,7 @@ import { <%= entityAngularName %>RoutingModule } from './route/<%= entityFileNam
35
35
 
36
36
  <%_ if (applicationTypeMicroservice && enableTranslation) { _%>
37
37
  function translatePartialLoader(http: HttpClient, applicationConfigService: ApplicationConfigService): TranslateLoader {
38
- const prefix = applicationConfigService.getEndpointFor('i18n/', '<%= microserviceName %>');
38
+ const prefix = applicationConfigService.isMicrofrontend() ? 'i18n/' : applicationConfigService.getEndpointFor('i18n/', '<%= microserviceName %>');
39
39
  return new TranslateHttpLoader(http, prefix, `.json?_=${I18N_HASH}`);
40
40
  }
41
41
 
@@ -39,118 +39,116 @@ import { <%= entityAngularName %>Service } from '../service/<%= entityFileName %
39
39
 
40
40
  import { <%= entityAngularName %>Component } from './<%= entityFileName %>.component';
41
41
 
42
- describe('Component Tests', () => {
43
- describe('<%= entityAngularName %> Management Component', () => {
44
- let comp: <%= entityAngularName %>Component;
45
- let fixture: ComponentFixture<<%= entityAngularName %>Component>;
46
- let service: <%= entityAngularName %>Service;
47
-
48
- beforeEach(() => {
49
- TestBed.configureTestingModule({
50
- imports: [HttpClientTestingModule],
51
- declarations: [<%= entityAngularName %>Component],
42
+ describe('<%= entityAngularName %> Management Component', () => {
43
+ let comp: <%= entityAngularName %>Component;
44
+ let fixture: ComponentFixture<<%= entityAngularName %>Component>;
45
+ let service: <%= entityAngularName %>Service;
46
+
47
+ beforeEach(() => {
48
+ TestBed.configureTestingModule({
49
+ imports: [HttpClientTestingModule],
50
+ declarations: [<%= entityAngularName %>Component],
52
51
  <%_ if (paginationPagination) { _%>
53
- providers: [
54
- Router,
55
- {
56
- provide: ActivatedRoute,
57
- useValue: {
58
- data: of({
59
- defaultSort: '<%- primaryKey.name %>,asc',
60
- }),
61
- queryParamMap: of(
62
- jest.requireActual('@angular/router').convertToParamMap({
63
- page: '1',
64
- size: '1',
65
- sort: '<%- primaryKey.name %>,desc',
66
- })
67
- ),
68
- <%_ if (searchEngine) { _%>
69
- snapshot: { queryParams: {} },
70
- <%_ } _%>
71
- }
52
+ providers: [
53
+ Router,
54
+ {
55
+ provide: ActivatedRoute,
56
+ useValue: {
57
+ data: of({
58
+ defaultSort: '<%- primaryKey.name %>,asc',
59
+ }),
60
+ queryParamMap: of(
61
+ jest.requireActual('@angular/router').convertToParamMap({
62
+ page: '1',
63
+ size: '1',
64
+ sort: '<%- primaryKey.name %>,desc',
65
+ })
66
+ ),
67
+ <%_ if (searchEngine) { _%>
68
+ snapshot: { queryParams: {} },
69
+ <%_ } _%>
72
70
  }
73
- ]
71
+ }
72
+ ]
74
73
  <%_ } else if (searchEngine) { _%>
75
- providers: [
76
- {
77
- provide: ActivatedRoute,
78
- useValue: { snapshot: { queryParams: {} } }
79
- }
80
- ]
74
+ providers: [
75
+ {
76
+ provide: ActivatedRoute,
77
+ useValue: { snapshot: { queryParams: {} } }
78
+ }
79
+ ]
81
80
  <%_ } _%>
82
- })
83
- .overrideTemplate(<%= entityAngularName %>Component, '')
84
- .compileComponents();
85
-
86
- fixture = TestBed.createComponent(<%= entityAngularName %>Component);
87
- comp = fixture.componentInstance;
88
- service = TestBed.inject(<%= entityAngularName %>Service);
89
-
90
- const headers = new HttpHeaders().append('link', 'link;link');
91
- jest.spyOn(service, 'query').mockReturnValue(
92
- of(
93
- new HttpResponse({
94
- body: [<%- testEntityPrimaryKey %>],
95
- headers,
96
- })
97
- )
98
- );
99
- });
100
-
101
- it('Should call load all on init', () => {
102
- // WHEN
103
- comp.ngOnInit();
104
-
105
- // THEN
106
- expect(service.query).toHaveBeenCalled();
107
- expect(comp.<%= entityInstancePlural %><%= entityArrayOptionalChainSymbol %>[0]).toEqual(expect.objectContaining(<%- testEntityPrimaryKey %>));
108
- });
81
+ })
82
+ .overrideTemplate(<%= entityAngularName %>Component, '')
83
+ .compileComponents();
84
+
85
+ fixture = TestBed.createComponent(<%= entityAngularName %>Component);
86
+ comp = fixture.componentInstance;
87
+ service = TestBed.inject(<%= entityAngularName %>Service);
88
+
89
+ const headers = new HttpHeaders();
90
+ jest.spyOn(service, 'query').mockReturnValue(
91
+ of(
92
+ new HttpResponse({
93
+ body: [<%- testEntityPrimaryKey %>],
94
+ headers,
95
+ })
96
+ )
97
+ );
98
+ });
99
+
100
+ it('Should call load all on init', () => {
101
+ // WHEN
102
+ comp.ngOnInit();
103
+
104
+ // THEN
105
+ expect(service.query).toHaveBeenCalled();
106
+ expect(comp.<%= entityInstancePlural %><%= entityArrayOptionalChainSymbol %>[0]).toEqual(expect.objectContaining(<%- testEntityPrimaryKey %>));
107
+ });
109
108
 
110
109
  <%_ if (!paginationNo) { _%>
111
- it('should load a page', () => {
112
- // WHEN
113
- comp.loadPage(1);
114
-
115
- // THEN
116
- expect(service.query).toHaveBeenCalled();
117
- expect(comp.<%= entityInstancePlural %><%= entityArrayOptionalChainSymbol %>[0]).toEqual(expect.objectContaining(<%- testEntityPrimaryKey %>));
118
- });
119
-
120
- it('should calculate the sort attribute for an id', () => {
121
- // WHEN
122
- comp.ngOnInit();
123
-
124
- // THEN
125
- expect(service.query).toHaveBeenCalledWith(expect.objectContaining({ sort: ['<%- primaryKey.fields.map(field => field.fieldName).join(',') %>,<%= order %>'] }));
126
- });
127
-
128
- it('should calculate the sort attribute for a non-id attribute', () => {
129
- // INIT
130
- comp.ngOnInit();
131
-
132
- // GIVEN
133
- comp.predicate = 'name';
134
-
135
- // WHEN
136
- comp.loadPage(1);
137
-
138
- // THEN
139
- expect(service.query).toHaveBeenLastCalledWith(expect.objectContaining({ sort: ['name,<%= order %>', '<%- primaryKey.fields.map(field => field.fieldName).join(',') %>'] }));
140
- });
141
-
142
- <%_ if (paginationInfiniteScroll) { _%>
143
- it('should re-initialize the page', () => {
144
- // WHEN
145
- comp.loadPage(1);
146
- comp.reset();
147
-
148
- // THEN
149
- expect(comp.page).toEqual(0);
150
- expect(service.query).toHaveBeenCalledTimes(2);
151
- expect(comp.<%= entityInstancePlural %>[0]).toEqual(expect.objectContaining(<%- testEntityPrimaryKey %>));
152
- });
153
- <%_ } _%>
154
- <%_ } _%>
110
+ it('should load a page', () => {
111
+ // WHEN
112
+ comp.loadPage(1);
113
+
114
+ // THEN
115
+ expect(service.query).toHaveBeenCalled();
116
+ expect(comp.<%= entityInstancePlural %><%= entityArrayOptionalChainSymbol %>[0]).toEqual(expect.objectContaining(<%- testEntityPrimaryKey %>));
117
+ });
118
+
119
+ it('should calculate the sort attribute for an id', () => {
120
+ // WHEN
121
+ comp.ngOnInit();
122
+
123
+ // THEN
124
+ expect(service.query).toHaveBeenCalledWith(expect.objectContaining({ sort: ['<%- primaryKey.fields.map(field => field.fieldName).join(',') %>,<%= order %>'] }));
155
125
  });
126
+
127
+ it('should calculate the sort attribute for a non-id attribute', () => {
128
+ // INIT
129
+ comp.ngOnInit();
130
+
131
+ // GIVEN
132
+ comp.predicate = 'name';
133
+
134
+ // WHEN
135
+ comp.loadPage(1);
136
+
137
+ // THEN
138
+ expect(service.query).toHaveBeenLastCalledWith(expect.objectContaining({ sort: ['name,<%= order %>', '<%- primaryKey.fields.map(field => field.fieldName).join(',') %>'] }));
139
+ });
140
+
141
+ <%_ if (paginationInfiniteScroll) { _%>
142
+ it('should re-initialize the page', () => {
143
+ // WHEN
144
+ comp.loadPage(1);
145
+ comp.reset();
146
+
147
+ // THEN
148
+ expect(comp.page).toEqual(0);
149
+ expect(service.query).toHaveBeenCalledTimes(2);
150
+ expect(comp.<%= entityInstancePlural %>[0]).toEqual(expect.objectContaining(<%- testEntityPrimaryKey %>));
151
+ });
152
+ <%_ } _%>
153
+ <%_ } _%>
156
154
  });
@@ -153,7 +153,14 @@ _%>
153
153
 
154
154
  <%_ } else if (paginationInfiniteScroll) { _%>
155
155
  protected paginate<%= entityClassPlural %>(data: I<%= entityAngularName %>[] | null, headers: HttpHeaders): void {
156
- this.links = this.parseLinks.parse(headers.get('link') ?? '');
156
+ const linkHeader = headers.get('link');
157
+ if (linkHeader) {
158
+ this.links = this.parseLinks.parse(linkHeader);
159
+ } else {
160
+ this.links = {
161
+ last: 0,
162
+ };
163
+ }
157
164
  if (data) {
158
165
  for (const d of data) {
159
166
  this.<%= entityInstancePlural %>.push(d);
@@ -32,72 +32,70 @@ import { <%= entityAngularName %>Service } from '../service/<%= entityFileName %
32
32
 
33
33
  import { <%= entityAngularName %>RoutingResolveService } from './<%= entityFileName %>-routing-resolve.service';
34
34
 
35
- describe('Service Tests', () => {
36
- describe('<%= entityAngularName %> routing resolve service', () => {
37
- let mockRouter: Router;
38
- let mockActivatedRouteSnapshot: ActivatedRouteSnapshot;
39
- let routingResolveService: <%= entityAngularName %>RoutingResolveService;
40
- let service: <%= entityAngularName %>Service;
41
- let result<%= entityAngularName %>: I<%= entityAngularName %> | undefined;
42
-
43
- beforeEach(() => {
44
- TestBed.configureTestingModule({
45
- imports: [HttpClientTestingModule],
46
- providers: [Router, ActivatedRouteSnapshot],
47
- });
48
- mockRouter = TestBed.inject(Router);
49
- mockActivatedRouteSnapshot = TestBed.inject(ActivatedRouteSnapshot);
50
- routingResolveService = TestBed.inject(<%= entityAngularName %>RoutingResolveService);
51
- service = TestBed.inject(<%= entityAngularName %>Service);
52
- result<%= entityAngularName %> = undefined;
35
+ describe('<%= entityAngularName %> routing resolve service', () => {
36
+ let mockRouter: Router;
37
+ let mockActivatedRouteSnapshot: ActivatedRouteSnapshot;
38
+ let routingResolveService: <%= entityAngularName %>RoutingResolveService;
39
+ let service: <%= entityAngularName %>Service;
40
+ let result<%= entityAngularName %>: I<%= entityAngularName %> | undefined;
41
+
42
+ beforeEach(() => {
43
+ TestBed.configureTestingModule({
44
+ imports: [HttpClientTestingModule],
45
+ providers: [Router, ActivatedRouteSnapshot],
53
46
  });
47
+ mockRouter = TestBed.inject(Router);
48
+ mockActivatedRouteSnapshot = TestBed.inject(ActivatedRouteSnapshot);
49
+ routingResolveService = TestBed.inject(<%= entityAngularName %>RoutingResolveService);
50
+ service = TestBed.inject(<%= entityAngularName %>Service);
51
+ result<%= entityAngularName %> = undefined;
52
+ });
54
53
 
55
- describe('resolve', () => {
56
- it('should return I<%= entityAngularName %> returned by find', () => {
57
- // GIVEN
58
- service.find = jest.fn(<%= primaryKey.name %> => of(new HttpResponse({ body: { <%= primaryKey.name %> } })));
59
- mockActivatedRouteSnapshot.params = { <%= primaryKey.name %>: <%- tsKeyId %> };
60
-
61
- // WHEN
62
- routingResolveService.resolve(mockActivatedRouteSnapshot).subscribe(result => {
63
- result<%= entityAngularName %> = result;
64
- });
54
+ describe('resolve', () => {
55
+ it('should return I<%= entityAngularName %> returned by find', () => {
56
+ // GIVEN
57
+ service.find = jest.fn(<%= primaryKey.name %> => of(new HttpResponse({ body: { <%= primaryKey.name %> } })));
58
+ mockActivatedRouteSnapshot.params = { <%= primaryKey.name %>: <%- tsKeyId %> };
65
59
 
66
- // THEN
67
- expect(service.find).toBeCalledWith(<%- tsKeyId %>);
68
- expect(result<%= entityAngularName %>).toEqual({ <%= primaryKey.name %>: <%- tsKeyId %> });
60
+ // WHEN
61
+ routingResolveService.resolve(mockActivatedRouteSnapshot).subscribe(result => {
62
+ result<%= entityAngularName %> = result;
69
63
  });
70
64
 
71
- it('should return new I<%= entityAngularName %> if id is not provided', () => {
72
- // GIVEN
73
- service.find = jest.fn();
74
- mockActivatedRouteSnapshot.params = {};
65
+ // THEN
66
+ expect(service.find).toBeCalledWith(<%- tsKeyId %>);
67
+ expect(result<%= entityAngularName %>).toEqual({ <%= primaryKey.name %>: <%- tsKeyId %> });
68
+ });
75
69
 
76
- // WHEN
77
- routingResolveService.resolve(mockActivatedRouteSnapshot).subscribe(result => {
78
- result<%= entityAngularName %> = result;
79
- });
70
+ it('should return new I<%= entityAngularName %> if id is not provided', () => {
71
+ // GIVEN
72
+ service.find = jest.fn();
73
+ mockActivatedRouteSnapshot.params = {};
80
74
 
81
- // THEN
82
- expect(service.find).not.toBeCalled();
83
- expect(result<%= entityAngularName %>).toEqual(new <%= entityAngularName %>());
75
+ // WHEN
76
+ routingResolveService.resolve(mockActivatedRouteSnapshot).subscribe(result => {
77
+ result<%= entityAngularName %> = result;
84
78
  });
85
79
 
86
- it('should route to 404 page if data not found in server', () => {
87
- // GIVEN
88
- jest.spyOn(service, 'find').mockReturnValue(of(new HttpResponse({ body: null as unknown as <%= entityAngularName %>})));
89
- mockActivatedRouteSnapshot.params = { <%= primaryKey.name %>: <%- tsKeyId %> };
80
+ // THEN
81
+ expect(service.find).not.toBeCalled();
82
+ expect(result<%= entityAngularName %>).toEqual(new <%= entityAngularName %>());
83
+ });
90
84
 
91
- // WHEN
92
- routingResolveService.resolve(mockActivatedRouteSnapshot).subscribe(result => {
93
- result<%= entityAngularName %> = result;
94
- });
85
+ it('should route to 404 page if data not found in server', () => {
86
+ // GIVEN
87
+ jest.spyOn(service, 'find').mockReturnValue(of(new HttpResponse({ body: null as unknown as <%= entityAngularName %>})));
88
+ mockActivatedRouteSnapshot.params = { <%= primaryKey.name %>: <%- tsKeyId %> };
95
89
 
96
- // THEN
97
- expect(service.find).toBeCalledWith(<%- tsKeyId %>);
98
- expect(result<%= entityAngularName %>).toEqual(undefined);
99
- expect(mockRouter.navigate).toHaveBeenCalledWith(['404']);
90
+ // WHEN
91
+ routingResolveService.resolve(mockActivatedRouteSnapshot).subscribe(result => {
92
+ result<%= entityAngularName %> = result;
100
93
  });
94
+
95
+ // THEN
96
+ expect(service.find).toBeCalledWith(<%- tsKeyId %>);
97
+ expect(result<%= entityAngularName %>).toEqual(undefined);
98
+ expect(mockRouter.navigate).toHaveBeenCalledWith(['404']);
101
99
  });
102
100
  });
103
101
  });
@@ -33,7 +33,7 @@ const <%= entityInstance %>Route: Routes = [
33
33
  component: <%= entityAngularName %>Component,
34
34
  <%_ if (paginationPagination) { _%>
35
35
  data: {
36
- defaultSort: 'id,asc',
36
+ defaultSort: '<%- primaryKey.name %>,asc',
37
37
  },
38
38
  <%_ } _%>
39
39
  canActivate: [UserRouteAccessService]