generator-jhipster 7.3.0 → 7.5.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 (340) hide show
  1. package/cli/import-jdl.js +3 -2
  2. package/cli/jhipster-command.js +2 -2
  3. package/cli/program.js +32 -29
  4. package/generators/app/index.js +46 -27
  5. package/generators/aws/index.js +8 -8
  6. package/generators/aws/lib/eb.js +1 -1
  7. package/generators/azure-app-service/index.js +16 -9
  8. package/generators/azure-app-service/templates/github/workflows/azure-app-service.yml.ejs +2 -2
  9. package/generators/azure-spring-cloud/index.js +16 -9
  10. package/generators/azure-spring-cloud/templates/github/workflows/azure-spring-cloud.yml.ejs +2 -2
  11. package/generators/bootstrap/index.js +57 -62
  12. package/generators/ci-cd/index.js +11 -8
  13. package/generators/ci-cd/templates/github-actions.yml.ejs +1 -1
  14. package/generators/ci-cd/templates/travis.yml.ejs +9 -4
  15. package/generators/cleanup.js +27 -171
  16. package/generators/client/files-angular.js +12 -1
  17. package/generators/client/files-common.js +6 -2
  18. package/generators/client/files-react.js +13 -2
  19. package/generators/client/files-vue.js +59 -7
  20. package/generators/client/index.js +46 -32
  21. package/generators/client/needle-api/needle-client-angular.js +1 -1
  22. package/generators/client/needle-api/needle-client-vue.js +57 -7
  23. package/generators/client/templates/angular/.eslintrc.json.ejs +1 -0
  24. package/generators/client/templates/angular/angular.json.ejs +5 -0
  25. package/generators/client/templates/angular/jest.conf.js.ejs +2 -0
  26. package/generators/client/templates/angular/package.json +29 -29
  27. package/generators/client/templates/angular/package.json.ejs +3 -1
  28. package/generators/client/templates/angular/src/main/webapp/app/account/activate/activate.component.spec.ts.ejs +52 -54
  29. package/generators/client/templates/angular/src/main/webapp/app/account/activate/activate.component.ts.ejs +4 -4
  30. package/generators/client/templates/angular/src/main/webapp/app/account/activate/activate.service.spec.ts.ejs +65 -0
  31. package/generators/client/templates/angular/src/main/webapp/app/account/password/password-strength-bar/password-strength-bar.component.spec.ts.ejs +35 -37
  32. package/generators/client/templates/angular/src/main/webapp/app/account/password/password-strength-bar/password-strength-bar.component.ts.ejs +1 -1
  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.component.ts.ejs +4 -4
  35. package/generators/client/templates/angular/src/main/webapp/app/account/password/password.service.spec.ts.ejs +41 -0
  36. package/generators/client/templates/angular/src/main/webapp/app/account/password-reset/finish/password-reset-finish.component.spec.ts.ejs +73 -75
  37. package/generators/client/templates/angular/src/main/webapp/app/account/password-reset/finish/password-reset-finish.component.ts.ejs +4 -4
  38. package/generators/client/templates/angular/src/main/webapp/app/account/password-reset/finish/password-reset-finish.service.spec.ts.ejs +62 -0
  39. package/generators/client/templates/angular/src/main/webapp/app/account/password-reset/init/password-reset-init.component.spec.ts.ejs +44 -46
  40. package/generators/client/templates/angular/src/main/webapp/app/account/password-reset/init/password-reset-init.service.spec.ts.ejs +61 -0
  41. package/generators/client/templates/angular/src/main/webapp/app/account/register/register.component.spec.ts.ejs +122 -123
  42. package/generators/client/templates/angular/src/main/webapp/app/account/register/register.component.ts.ejs +1 -1
  43. package/generators/client/templates/angular/src/main/webapp/app/account/register/register.service.spec.ts.ejs +66 -0
  44. package/generators/client/templates/angular/src/main/webapp/app/account/sessions/sessions.component.spec.ts.ejs +75 -77
  45. package/generators/client/templates/angular/src/main/webapp/app/account/settings/settings.component.spec.ts.ejs +80 -80
  46. package/generators/client/templates/angular/src/main/webapp/app/admin/configuration/configuration.component.spec.ts.ejs +48 -50
  47. package/generators/client/templates/angular/src/main/webapp/app/admin/health/health.component.spec.ts.ejs +45 -47
  48. package/generators/client/templates/angular/src/main/webapp/app/admin/health/health.component.ts.ejs +4 -4
  49. package/generators/client/templates/angular/src/main/webapp/app/admin/health/health.service.spec.ts.ejs +66 -0
  50. package/generators/client/templates/angular/src/main/webapp/app/admin/health/modal/health-modal.component.spec.ts.ejs +99 -101
  51. package/generators/client/templates/angular/src/main/webapp/app/admin/logs/logs.component.spec.ts.ejs +61 -63
  52. package/generators/client/templates/angular/src/main/webapp/app/admin/metrics/blocks/jvm-memory/jvm-memory.component.html.ejs +2 -2
  53. package/generators/client/templates/angular/src/main/webapp/app/admin/metrics/metrics.component.spec.ts.ejs +28 -30
  54. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/delete/user-management-delete-dialog.component.spec.ts.ejs +35 -37
  55. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/detail/user-management-detail.component.spec.ts.ejs +40 -42
  56. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/list/user-management.component.spec.ts.ejs +89 -91
  57. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/list/user-management.component.ts.ejs +4 -4
  58. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/update/user-management-update.component.spec.ts.ejs +81 -83
  59. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/update/user-management-update.component.ts.ejs +8 -8
  60. package/generators/client/templates/angular/src/main/webapp/app/app-routing.module.ts.ejs +14 -3
  61. package/generators/client/templates/angular/src/main/webapp/app/app.module.ts.ejs +8 -29
  62. package/generators/client/templates/angular/src/main/webapp/app/config/datepicker-adapter.ts.ejs +1 -1
  63. package/generators/client/templates/angular/src/main/webapp/app/config/dayjs.ts.ejs +4 -4
  64. package/generators/client/templates/angular/src/main/webapp/app/core/auth/account.service.spec.ts.ejs +14 -9
  65. package/generators/client/templates/angular/src/main/webapp/app/core/tracker/tracker.service.ts.ejs +6 -6
  66. package/generators/client/templates/angular/src/main/webapp/app/core/util/parse-links.service.ts.ejs +1 -1
  67. package/generators/client/templates/angular/src/main/webapp/app/entities/entity-navbar-items.ts.ejs +29 -0
  68. package/generators/client/templates/angular/src/main/webapp/app/home/home.component.spec.ts.ejs +106 -98
  69. package/generators/client/templates/angular/src/main/webapp/app/layouts/main/main.component.spec.ts.ejs +166 -168
  70. package/generators/client/templates/angular/src/main/webapp/app/layouts/main/main.component.ts.ejs +1 -1
  71. package/generators/client/templates/angular/src/main/webapp/app/layouts/navbar/navbar.component.html.ejs +20 -0
  72. package/generators/client/templates/angular/src/main/webapp/app/layouts/navbar/navbar.component.spec.ts.ejs +74 -70
  73. package/generators/client/templates/angular/src/main/webapp/app/layouts/navbar/navbar.component.ts.ejs +41 -2
  74. package/generators/client/templates/angular/src/main/webapp/app/layouts/profiles/page-ribbon.component.spec.ts.ejs +27 -29
  75. package/generators/client/templates/angular/src/main/webapp/app/login/login.component.spec.ts.ejs +114 -115
  76. package/generators/client/templates/angular/src/main/webapp/app/login/login.component.ts.ejs +4 -4
  77. package/generators/client/templates/angular/src/main/webapp/app/shared/alert/alert-error.component.spec.ts.ejs +132 -134
  78. package/generators/client/templates/angular/src/main/webapp/app/shared/alert/alert.component.spec.ts.ejs +29 -31
  79. package/generators/client/templates/angular/src/main/webapp/app/shared/auth/has-any-authority.directive.spec.ts.ejs +4 -4
  80. package/generators/client/templates/angular/src/main/webapp/app/shared/date/duration.pipe.ts.ejs +1 -1
  81. package/generators/client/templates/angular/src/main/webapp/app/shared/date/format-medium-date.pipe.spec.ts.ejs +1 -1
  82. package/generators/client/templates/angular/src/main/webapp/app/shared/date/format-medium-date.pipe.ts.ejs +1 -1
  83. package/generators/client/templates/angular/src/main/webapp/app/shared/date/format-medium-datetime.pipe.spec.ts.ejs +1 -1
  84. package/generators/client/templates/angular/src/main/webapp/app/shared/date/format-medium-datetime.pipe.ts.ejs +1 -1
  85. package/generators/client/templates/angular/src/main/webapp/app/shared/language/translate.directive.ts.ejs +6 -6
  86. package/generators/client/templates/angular/src/main/webapp/app/shared/language/translation.module.ts.ejs +83 -0
  87. package/generators/client/templates/angular/src/main/webapp/declarations.d.ts.ejs +16 -2
  88. package/generators/client/templates/angular/tsconfig.json.ejs +2 -0
  89. package/generators/client/templates/angular/tsconfig.spec.json.ejs +0 -1
  90. package/generators/client/templates/angular/webpack/proxy.conf.js.ejs +0 -2
  91. package/generators/client/templates/angular/webpack/webpack.custom.js.ejs +0 -16
  92. package/generators/client/templates/angular/webpack/webpack.microfrontend.js.ejs +12 -5
  93. package/generators/client/templates/common/package.json +6 -6
  94. package/generators/client/templates/common/src/main/webapp/robots.txt.ejs +0 -1
  95. package/generators/client/templates/common/src/main/webapp/swagger-ui/index.html.ejs +86 -56
  96. package/generators/client/templates/common/webpack/webpack.microfrontend.js.jhi.ejs +56 -0
  97. package/generators/client/templates/react/.eslintrc.json.ejs +1 -0
  98. package/generators/client/templates/react/package.json +54 -53
  99. package/generators/client/templates/react/package.json.ejs +6 -1
  100. package/generators/client/templates/react/src/main/webapp/app/app.scss.ejs +0 -3
  101. package/generators/client/templates/react/src/main/webapp/app/config/axios-interceptor.spec.ts.ejs +3 -2
  102. package/generators/client/templates/react/src/main/webapp/app/modules/account/password/password.tsx.ejs +2 -2
  103. package/generators/client/templates/react/src/main/webapp/app/modules/administration/configuration/configuration.tsx.ejs +2 -2
  104. package/generators/client/templates/react/src/main/webapp/app/modules/administration/gateway/gateway.tsx.ejs +2 -2
  105. package/generators/client/templates/react/src/main/webapp/app/modules/administration/metrics/metrics.tsx.ejs +6 -6
  106. package/generators/client/templates/react/src/main/webapp/app/modules/administration/user-management/user-management.tsx.ejs +8 -8
  107. package/generators/client/templates/react/src/main/webapp/app/modules/home/home.tsx.ejs +1 -1
  108. package/generators/client/templates/react/src/main/webapp/app/shared/layout/header/header.scss.ejs +9 -0
  109. package/generators/client/templates/react/src/main/webapp/app/shared/layout/header/header.tsx.ejs +2 -2
  110. package/generators/client/templates/react/src/main/webapp/app/shared/layout/menus/account.tsx.ejs +3 -3
  111. package/generators/client/templates/react/src/main/webapp/app/shared/layout/menus/admin.tsx.ejs +7 -7
  112. package/generators/client/templates/react/src/main/webapp/app/shared/layout/menus/menu-components.tsx.ejs +1 -1
  113. package/generators/client/templates/react/src/main/webapp/app/shared/reducers/authentication.spec.ts.ejs +1 -1
  114. package/generators/client/templates/react/webpack/webpack.dev.js.ejs +17 -3
  115. package/generators/client/templates/react/webpack/webpack.prod.js.ejs +13 -1
  116. package/generators/client/templates/vue/.eslintrc.js.ejs +8 -5
  117. package/generators/client/templates/vue/package.json +40 -49
  118. package/generators/client/templates/vue/package.json.ejs +13 -17
  119. package/generators/client/templates/vue/src/main/webapp/app/account/account.service.ts.ejs +23 -12
  120. package/generators/client/templates/vue/src/main/webapp/app/account/settings/settings.vue.ejs +7 -1
  121. package/generators/client/templates/vue/src/main/webapp/app/admin/configuration/configuration.vue.ejs +1 -1
  122. package/generators/client/templates/vue/src/main/webapp/app/admin/metrics/metrics.component.ts.ejs +1 -1
  123. package/generators/client/templates/vue/src/main/webapp/app/constants.ts.ejs +16 -6
  124. package/generators/client/templates/vue/src/main/webapp/app/core/jhi-navbar/jhi-navbar.component.ts.ejs +27 -8
  125. package/generators/client/templates/vue/src/main/webapp/app/core/jhi-navbar/jhi-navbar.vue.ejs +6 -0
  126. package/generators/client/templates/vue/src/main/webapp/app/declarations.d.ts.ejs +41 -0
  127. package/generators/client/templates/vue/src/main/webapp/app/entities/entities-menu.component.ts.ejs +34 -0
  128. package/generators/client/templates/vue/src/main/webapp/app/entities/entities-menu.vue.ejs +13 -0
  129. package/generators/client/templates/vue/src/main/webapp/app/entities/entities.component.ts.ejs +20 -0
  130. package/generators/client/templates/vue/src/main/webapp/app/entities/entities.vue.ejs +5 -0
  131. package/generators/client/templates/vue/src/main/webapp/app/entities/user/{user.oauth2.service.ts.ejs → user.service.ts.ejs} +1 -1
  132. package/generators/client/templates/vue/{webpack/utils.js.ejs → src/main/webapp/app/index.ts.ejs} +1 -12
  133. package/generators/client/templates/vue/src/main/webapp/app/locale/translation.service.ts.ejs +26 -9
  134. package/generators/client/templates/vue/src/main/webapp/app/main.ts.ejs +20 -18
  135. package/generators/client/templates/vue/src/main/webapp/app/router/entities.ts.ejs +45 -3
  136. package/generators/client/templates/vue/src/main/webapp/app/router/index.ts.ejs +19 -3
  137. package/generators/client/templates/vue/src/main/webapp/app/shared/config/axios-interceptor.ts.ejs +0 -2
  138. package/generators/client/templates/vue/src/main/webapp/app/shared/data/data-utils.service.ts.ejs +3 -1
  139. package/generators/client/templates/vue/src/main/webapp/app/shims-vue.d.ts.ejs +17 -3
  140. package/generators/client/templates/vue/src/test/javascript/jest.conf.js.ejs +25 -10
  141. package/generators/client/templates/vue/src/test/javascript/spec/app/account/login-form/login-form.component.spec.ts.ejs +2 -2
  142. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/user-management/user-management-edit.component.spec.ts.ejs +6 -4
  143. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/user-management/user-management.component.spec.ts.ejs +4 -2
  144. package/generators/client/templates/vue/src/test/javascript/spec/app/core/jhi-navbar/jhi-navbar.component.spec.ts.ejs +10 -4
  145. package/generators/client/templates/vue/src/test/javascript/spec/app/entities/entities-menu.spec.ts.ejs +52 -0
  146. package/generators/client/templates/vue/src/test/javascript/spec/app/microfrontends/entities-menu.component.ts.ejs +4 -0
  147. package/generators/client/templates/vue/src/test/javascript/spec/app/microfrontends/entities-menu.vue.ejs +7 -0
  148. package/generators/client/templates/vue/src/test/javascript/spec/app/microfrontends/entities-router.ts.ejs +1 -0
  149. package/generators/client/templates/vue/src/test/javascript/spec/app/shared/config/axios-interceptor.spec.ts.ejs +0 -1
  150. package/generators/client/templates/vue/tsconfig.json.ejs +6 -10
  151. package/generators/client/templates/vue/tsconfig.spec.json.ejs +37 -0
  152. package/generators/client/templates/vue/webpack/config.js.ejs +50 -0
  153. package/generators/client/templates/vue/webpack/vue.utils.js.ejs +33 -32
  154. package/generators/client/templates/vue/webpack/webpack.common.js.ejs +150 -126
  155. package/generators/client/templates/vue/webpack/webpack.dev.js.ejs +19 -76
  156. package/generators/client/templates/vue/webpack/webpack.microfrontend.js.jhi.vue.ejs +77 -0
  157. package/generators/client/templates/vue/webpack/webpack.prod.js.ejs +5 -41
  158. package/generators/cloudfoundry/index.js +9 -9
  159. package/generators/common/index.js +12 -10
  160. package/generators/common/templates/.prettierrc.ejs +1 -1
  161. package/generators/common/templates/README.md.jhi.ejs +19 -0
  162. package/generators/common/templates/package.json +4 -4
  163. package/generators/cypress/index.js +12 -9
  164. package/generators/cypress/templates/cypress.json.ejs +16 -2
  165. package/generators/cypress/templates/src/test/javascript/cypress/integration/account/login-page.spec.ts.ejs +3 -14
  166. package/generators/cypress/templates/src/test/javascript/cypress/integration/account/password-page.spec.ts.ejs +33 -39
  167. package/generators/cypress/templates/src/test/javascript/cypress/integration/account/register-page.spec.ts.ejs +52 -62
  168. package/generators/cypress/templates/src/test/javascript/cypress/integration/account/reset-password-page.spec.ts.ejs +2 -10
  169. package/generators/cypress/templates/src/test/javascript/cypress/integration/account/settings-page.spec.ts.ejs +25 -34
  170. package/generators/cypress/templates/src/test/javascript/cypress/integration/administration/administration.spec.ts.ejs +1 -22
  171. package/generators/cypress/templates/src/test/javascript/cypress/plugins/index.ts.ejs +4 -4
  172. package/generators/cypress/templates/src/test/javascript/cypress/support/commands.ts.ejs +67 -7
  173. package/generators/cypress/templates/src/test/javascript/cypress/support/entity.ts.ejs +4 -4
  174. package/generators/cypress/templates/src/test/javascript/cypress/support/index.ts.ejs +1 -6
  175. package/generators/cypress/templates/src/test/javascript/cypress/support/management.ts.ejs +1 -1
  176. package/generators/cypress/templates/src/test/javascript/cypress/support/navbar.ts.ejs +8 -8
  177. package/generators/cypress/templates/src/test/javascript/cypress/support/oauth2.ts.ejs +0 -9
  178. package/generators/database-changelog/index.js +33 -22
  179. package/generators/database-changelog-liquibase/index.js +12 -8
  180. package/generators/database-changelog-liquibase/templates/src/main/resources/config/liquibase/changelog/updated_entity_constraints.xml.ejs +1 -1
  181. package/generators/docker-compose/index.js +11 -12
  182. package/generators/docker-compose/templates/realm-config/jhipster-realm.json.ejs +1 -1
  183. package/generators/entities/index.js +35 -26
  184. package/generators/entities-client/index.js +10 -7
  185. package/generators/entity/index.js +81 -32
  186. package/generators/entity-client/files.js +7 -16
  187. package/generators/entity-client/index.js +22 -12
  188. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/delete/entity-management-delete-dialog.component.spec.ts.ejs +42 -44
  189. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/detail/entity-management-detail.component.html.ejs +1 -1
  190. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/detail/entity-management-detail.component.spec.ts.ejs +58 -60
  191. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/entity-management.module.ts.ejs +1 -35
  192. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/entity.model.ts.ejs +1 -1
  193. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/list/entity-management.component.html.ejs +4 -4
  194. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/list/entity-management.component.spec.ts.ejs +110 -112
  195. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/list/entity-management.component.ts.ejs +9 -2
  196. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/list/infinite-scroll-template.ejs +8 -8
  197. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/list/no-pagination-template.ejs +8 -8
  198. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/list/pagination-template.ejs +8 -8
  199. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/route/entity-management-routing-resolve.service.spec.ts.ejs +15 -6
  200. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/route/entity-management-routing.module.ts.ejs +1 -1
  201. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/service/entity.service.spec.ts.ejs +1 -1
  202. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/service/entity.service.ts.ejs +1 -1
  203. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/update/entity-management-update.component.spec.ts.ejs +203 -198
  204. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/update/entity-management-update.component.ts.ejs +5 -5
  205. package/generators/entity-client/templates/angular/src/test/javascript/e2e/entities/entity.spec.ts.ejs +1 -1
  206. package/generators/entity-client/templates/common/src/test/javascript/cypress/integration/entity/entity.spec.ts.ejs +264 -127
  207. package/generators/entity-client/templates/react/src/main/webapp/app/entities/entity-update.tsx.ejs +17 -14
  208. package/generators/entity-client/templates/react/src/main/webapp/app/entities/entity.reducer.ts.ejs +5 -4
  209. package/generators/entity-client/templates/react/src/main/webapp/app/entities/entity.tsx.ejs +11 -13
  210. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity-update.component.ts.ejs +32 -25
  211. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity-update.vue.ejs +6 -9
  212. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity.component.ts.ejs +2 -1
  213. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity.model.ts.ejs +1 -1
  214. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity.service.ts.ejs +2 -6
  215. package/generators/entity-client/templates/vue/src/test/javascript/spec/app/entities/entity-update.component.spec.ts.ejs +10 -7
  216. package/generators/entity-client/templates/vue/src/test/javascript/spec/app/entities/entity.component.spec.ts.ejs +5 -1
  217. package/generators/entity-client/templates/vue/src/test/javascript/spec/app/entities/entity.service.spec.ts.ejs +1 -1
  218. package/generators/entity-i18n/index.js +7 -4
  219. package/generators/entity-server/files.js +14 -0
  220. package/generators/entity-server/index.js +12 -8
  221. package/generators/entity-server/templates/src/main/java/package/common/get_all_template.ejs +2 -2
  222. package/generators/entity-server/templates/src/main/java/package/common/search_template.ejs +1 -1
  223. package/generators/entity-server/templates/src/main/java/package/domain/Entity.java.jhi.ejs +9 -8
  224. package/generators/entity-server/templates/src/main/java/package/repository/EntityRepositoryInternalImpl_reactive.java.ejs +16 -29
  225. package/generators/entity-server/templates/src/main/java/package/repository/EntityRepository_reactive.java.ejs +3 -3
  226. package/generators/entity-server/templates/src/main/java/package/repository/EntitySqlHelper_reactive.java.ejs +46 -0
  227. package/generators/entity-server/templates/src/main/java/package/repository/rowmapper/EntityRowMapper.java.ejs +1 -1
  228. package/generators/entity-server/templates/src/main/java/package/repository/search/EntitySearchRepository.java.ejs +18 -2
  229. package/generators/entity-server/templates/src/main/java/package/repository/search/SortToFieldSortBuilderConverter.java.ejs +24 -0
  230. package/generators/entity-server/templates/src/main/java/package/service/dto/EntityDTO.java.ejs +8 -6
  231. package/generators/entity-server/templates/src/main/java/package/service/mapper/EntityMapper.java.ejs +5 -1
  232. package/generators/entity-server/templates/src/main/java/package/web/rest/EntityResource.java.ejs +41 -43
  233. package/generators/entity-server/templates/src/test/java/package/web/rest/EntityResourceIT.java.ejs +3 -3
  234. package/generators/gae/index.js +10 -10
  235. package/generators/generator-base-blueprint.js +14 -46
  236. package/generators/generator-base-private.js +44 -23
  237. package/generators/generator-base.js +58 -18
  238. package/generators/generator-constants.js +30 -23
  239. package/generators/generator-transforms.js +39 -27
  240. package/generators/heroku/index.js +14 -33
  241. package/generators/init/constants.cjs +1 -1
  242. package/generators/java/constants.cjs +1 -1
  243. package/generators/kubernetes/files.js +3 -0
  244. package/generators/kubernetes/index.js +10 -10
  245. package/generators/kubernetes/templates/db/couchbase.yml.ejs +1 -1
  246. package/generators/kubernetes/templates/deployment.yml.ejs +8 -3
  247. package/generators/kubernetes/templates/istio/destination-rule.yml.ejs +1 -1
  248. package/generators/kubernetes/templates/istio/gateway/grafana-gateway.yml.ejs +5 -2
  249. package/generators/kubernetes/templates/istio/gateway/jhipster-grafana-gateway.yml.ejs +5 -2
  250. package/generators/kubernetes/templates/istio/gateway/kiali-gateway.yml.ejs +10 -8
  251. package/generators/kubernetes/templates/istio/gateway/zipkin-gateway.yml.ejs +5 -2
  252. package/generators/kubernetes/templates/istio/gateway.yml.ejs +7 -5
  253. package/generators/kubernetes/templates/secret/couchbase-secret.yml.ejs +9 -0
  254. package/generators/kubernetes-base.js +1 -0
  255. package/generators/kubernetes-helm/files.js +3 -8
  256. package/generators/kubernetes-helm/index.js +10 -10
  257. package/generators/kubernetes-helm/templates/README-KUBERNETES-HELM.md.ejs +0 -1
  258. package/generators/kubernetes-helm/templates/app/Chart.yml.ejs +5 -0
  259. package/generators/kubernetes-helm/templates/app/helpers.tpl.ejs +0 -11
  260. package/generators/kubernetes-helm/templates/app/requirements.yml.ejs +5 -0
  261. package/generators/kubernetes-helm/templates/app/values.yml.ejs +68 -5
  262. package/generators/kubernetes-helm/templates/csvc/Chart.yml.ejs +1 -1
  263. package/generators/kubernetes-helm/templates/csvc/requirements.yml.ejs +1 -1
  264. package/generators/kubernetes-knative/index.js +10 -10
  265. package/generators/kubernetes-knative/templates/istio/gateway.yml.ejs +6 -4
  266. package/generators/kubernetes-knative/templates/service.yml.ejs +1 -1
  267. package/generators/languages/index.js +13 -13
  268. package/generators/languages/templates/src/main/webapp/i18n/vi/login.json +1 -1
  269. package/generators/openapi-client/index.js +13 -10
  270. package/generators/openshift/index.js +10 -11
  271. package/generators/openshift/templates/deployment.yml.ejs +1 -1
  272. package/generators/page/index.js +12 -10
  273. package/generators/server/__snapshots__/generator.spec.mjs.snap +28 -15
  274. package/generators/server/cleanup.js +151 -0
  275. package/generators/server/files-sql.js +52 -0
  276. package/generators/server/files.js +31 -14
  277. package/generators/server/index.js +86 -33
  278. package/generators/server/templates/build.gradle.ejs +231 -189
  279. package/generators/server/templates/gradle.properties.ejs +12 -12
  280. package/generators/server/templates/npmw +8 -6
  281. package/generators/server/templates/npmw.cmd +13 -8
  282. package/generators/server/templates/pom.xml.ejs +425 -217
  283. package/generators/server/templates/sql/reactive/src/main/java/package/repository/UserSqlHelper.java.ejs +48 -0
  284. package/generators/server/templates/src/main/docker/app.yml.ejs +1 -1
  285. package/generators/server/templates/src/main/docker/config/realm-config/jhipster-realm.json.ejs +2 -2
  286. package/generators/server/templates/src/main/java/package/config/LocaleConfiguration.java.ejs +3 -2
  287. package/generators/server/templates/src/main/java/package/config/OpenApiConfiguration.java.ejs +17 -54
  288. package/generators/server/templates/src/main/java/package/config/SecurityConfiguration.java.ejs +5 -5
  289. package/generators/server/templates/src/main/java/package/config/SecurityConfiguration_reactive.java.ejs +4 -6
  290. package/generators/server/templates/src/main/java/package/config/WebConfigurer.java.ejs +0 -3
  291. package/generators/server/templates/src/main/java/package/config/neo4j/Neo4jMigrations.java.ejs +19 -9
  292. package/generators/server/templates/src/main/java/package/management/SecurityMetersService.java.ejs +68 -0
  293. package/generators/server/templates/src/main/java/package/repository/AuthorityRepository.java.ejs +2 -2
  294. package/generators/server/templates/src/main/java/package/repository/UserRepository.java.ejs +0 -25
  295. package/generators/server/templates/src/main/java/package/security/jwt/TokenProvider.java.ejs +31 -4
  296. package/generators/server/templates/src/main/java/package/security/oauth2/CustomClaimConverter.java.ejs +23 -11
  297. package/generators/server/templates/src/main/java/package/service/UserService.java.ejs +16 -8
  298. package/generators/server/templates/src/main/java/package/service/dto/UserDTO.java.ejs +6 -6
  299. package/generators/server/templates/src/main/java/package/web/filter/ModifyServersOpenApiFilter.java.ejs +3 -2
  300. package/generators/server/templates/src/main/java/package/web/filter/SpaWebFilter.java.ejs +1 -1
  301. package/generators/server/templates/src/main/java/package/web/rest/PublicUserResource.java.ejs +2 -2
  302. package/generators/server/templates/src/main/java/package/web/rest/UserResource.java.ejs +2 -2
  303. package/generators/server/templates/src/main/resources/config/application.yml.ejs +22 -8
  304. package/generators/server/templates/src/main/resources/logback-spring.xml.ejs +1 -2
  305. package/generators/server/templates/src/main/resources/static/microservices_index.html.ejs +1 -1
  306. package/generators/server/templates/src/test/java/package/cucumber/CucumberIT.java.ejs +2 -6
  307. package/generators/server/templates/src/test/java/package/cucumber/CucumberTestContextConfiguration.java.ejs +2 -3
  308. package/generators/server/templates/src/test/java/package/cucumber/stepdefs/UserStepDefs.java.ejs +41 -6
  309. package/generators/server/templates/src/test/java/package/management/SecurityMetersServiceTests.java.ejs +113 -0
  310. package/generators/server/templates/src/test/java/package/security/jwt/JWTFilterTest.java.ejs +6 -1
  311. package/generators/server/templates/src/test/java/package/security/jwt/TokenProviderSecurityMetersTests.java.ejs +198 -0
  312. package/generators/server/templates/src/test/java/package/security/jwt/TokenProviderTest.java.ejs +13 -3
  313. package/generators/server/templates/src/test/java/package/security/oauth2/AuthorizationHeaderUtilTest.java.ejs +17 -3
  314. package/generators/server/templates/src/test/java/package/security/oauth2/CustomClaimConverterIT.java.ejs +63 -0
  315. package/generators/server/templates/src/test/java/package/service/MailServiceIT.java.ejs +1 -1
  316. package/generators/server/templates/src/test/java/package/web/rest/AccountResourceIT.java.ejs +2 -3
  317. package/generators/server/templates/src/test/java/package/web/rest/ClientForwardControllerTest.java.ejs +9 -0
  318. package/generators/server/templates/src/test/resources/junit-platform.properties.ejs +2 -0
  319. package/generators/server/templates/src/test/resources/logback.xml.ejs +1 -1
  320. package/generators/server/templates/src/test/{features → resources/package/features}/gitkeep +0 -0
  321. package/generators/server/templates/src/test/{features → resources/package/features}/user/user.feature.ejs +0 -0
  322. package/generators/spring-controller/index.js +9 -7
  323. package/generators/spring-controller/templates/src/test/java/package/web/rest/ResourceIT.java.ejs +1 -1
  324. package/generators/spring-service/index.js +10 -7
  325. package/generators/upgrade/index.js +4 -5
  326. package/generators/utils.js +2 -2
  327. package/generators/workspaces/index.js +16 -7
  328. package/jdl/jhipster/default-application-options.js +9 -7
  329. package/package.json +22 -22
  330. package/utils/entity.js +17 -4
  331. package/utils/field.js +11 -1
  332. package/utils/multi-step-transform/index.js +8 -8
  333. package/generators/client/templates/react/.npmrc.ejs +0 -1
  334. package/generators/client/templates/vue/webpack/dev.env.js.ejs +0 -17
  335. package/generators/client/templates/vue/webpack/env.js.ejs +0 -67
  336. package/generators/client/templates/vue/webpack/loader.conf.js.ejs +0 -20
  337. package/generators/client/templates/vue/webpack/prod.env.js.ejs +0 -15
  338. package/generators/server/templates/src/main/java/package/config/apidocs/GatewaySwaggerResourcesProvider.java.ejs +0 -91
  339. package/generators/server/templates/src/test/java/package/config/apidocs/GatewaySwaggerResourcesProviderTest.java.ejs +0 -79
  340. package/generators/server/templates/src/test/resources/cucumber.properties.ejs +0 -1
@@ -25,14 +25,13 @@ const allRelationshipsByEntityNeedingOptions = Object
25
25
  const testEntityPrimaryKey0 = generateTestEntityPrimaryKey(primaryKey, 0);
26
26
  const testEntityPrimaryKey1 = generateTestEntityPrimaryKey(primaryKey, 1);
27
27
  _%>
28
- jest.mock('@angular/router');
29
-
30
28
  import { ComponentFixture, TestBed } from '@angular/core/testing';
31
29
  import { HttpResponse } from '@angular/common/http';
32
30
  import { HttpClientTestingModule } from '@angular/common/http/testing';
33
31
  import { FormBuilder } from '@angular/forms';
34
32
  import { ActivatedRoute } from '@angular/router';
35
- import { of, Subject } from 'rxjs';
33
+ import { RouterTestingModule } from '@angular/router/testing';
34
+ import { of, Subject, from } from 'rxjs';
36
35
 
37
36
  import { <%= entityAngularName %>Service } from '../service/<%= entityFileName %>.service';
38
37
  import { I<%= entityAngularName %>, <%= entityAngularName %> } from '../<%= entityFileName %>.model';
@@ -50,240 +49,246 @@ import { <%= otherEntity.entityAngularName %>Service } from 'app/entities/<%= ot
50
49
 
51
50
  import { <%= entityAngularName %>UpdateComponent } from './<%= entityFileName %>-update.component';
52
51
 
53
- describe('Component Tests', () => {
54
- describe('<%= entityAngularName %> Management Update Component', () => {
55
- let comp: <%= entityAngularName %>UpdateComponent;
56
- let fixture: ComponentFixture<<%= entityAngularName %>UpdateComponent>;
57
- let activatedRoute: ActivatedRoute;
58
- let <%= entityInstance %>Service: <%= entityAngularName %>Service;
52
+ describe('<%= entityAngularName %> Management Update Component', () => {
53
+ let comp: <%= entityAngularName %>UpdateComponent;
54
+ let fixture: ComponentFixture<<%= entityAngularName %>UpdateComponent>;
55
+ let activatedRoute: ActivatedRoute;
56
+ let <%= entityInstance %>Service: <%= entityAngularName %>Service;
59
57
  <%_ for (const relationshipsByEntityNeedingOptions of allRelationshipsByEntityNeedingOptions.filter(relationships => relationships[0].otherEntity.entityAngularName !== entityAngularName)) { _%>
60
- <%_ const otherEntity = relationshipsByEntityNeedingOptions[0].otherEntity; _%>
61
- let <%= otherEntity.entityInstance %>Service: <%= otherEntity.entityAngularName %>Service;
58
+ <%_ const otherEntity = relationshipsByEntityNeedingOptions[0].otherEntity; _%>
59
+ let <%= otherEntity.entityInstance %>Service: <%= otherEntity.entityAngularName %>Service;
62
60
  <%_ } _%>
63
61
 
64
- beforeEach(() => {
65
- TestBed.configureTestingModule({
66
- imports: [HttpClientTestingModule],
67
- declarations: [<%= entityAngularName %>UpdateComponent],
68
- providers: [FormBuilder, ActivatedRoute],
69
- })
70
- .overrideTemplate(<%= entityAngularName %>UpdateComponent, '')
71
- .compileComponents();
72
-
73
- fixture = TestBed.createComponent(<%= entityAngularName %>UpdateComponent);
74
- activatedRoute = TestBed.inject(ActivatedRoute);
75
- <%= entityInstance %>Service = TestBed.inject(<%= entityAngularName %>Service);
62
+ beforeEach(() => {
63
+ TestBed.configureTestingModule({
64
+ imports: [HttpClientTestingModule, RouterTestingModule.withRoutes([])],
65
+ declarations: [<%= entityAngularName %>UpdateComponent],
66
+ providers: [
67
+ FormBuilder,
68
+ {
69
+ provide: ActivatedRoute,
70
+ useValue: {
71
+ params: from([{}]),
72
+ },
73
+ },
74
+ ]
75
+ })
76
+ .overrideTemplate(<%= entityAngularName %>UpdateComponent, '')
77
+ .compileComponents();
78
+
79
+ fixture = TestBed.createComponent(<%= entityAngularName %>UpdateComponent);
80
+ activatedRoute = TestBed.inject(ActivatedRoute);
81
+ <%= entityInstance %>Service = TestBed.inject(<%= entityAngularName %>Service);
76
82
  <%_ for (const relationshipsByEntityNeedingOptions of allRelationshipsByEntityNeedingOptions.filter(relationships => relationships[0].otherEntity.entityAngularName !== entityAngularName)) { _%>
77
- <%_ const otherEntity = relationshipsByEntityNeedingOptions[0].otherEntity; _%>
78
- <%= otherEntity.entityInstance %>Service = TestBed.inject(<%= otherEntity.entityAngularName %>Service);
83
+ <%_ const otherEntity = relationshipsByEntityNeedingOptions[0].otherEntity; _%>
84
+ <%= otherEntity.entityInstance %>Service = TestBed.inject(<%= otherEntity.entityAngularName %>Service);
79
85
  <%_ } _%>
80
86
 
81
- comp = fixture.componentInstance;
82
- });
87
+ comp = fixture.componentInstance;
88
+ });
83
89
 
84
- describe('ngOnInit', () => {
90
+ describe('ngOnInit', () => {
85
91
  <%_ for (const relationshipsByEntityNeedingOptions of allRelationshipsByEntityNeedingOptions) { _%>
86
- <%_ const relationshipsWithCustomUniqueOptions = relationshipsByEntityNeedingOptions.filter(rel => rel.relationshipOneToOne && !rel.otherEntityUser); _%>
87
- <%_ const relationshipsWithCustomSharedOptions = relationshipsByEntityNeedingOptions.filter(rel => !relationshipsWithCustomUniqueOptions.includes(rel)); _%>
88
- <%_ if (relationshipsWithCustomSharedOptions.length > 0) { _%>
89
- <%_ const otherEntity = relationshipsByEntityNeedingOptions[0].otherEntity; _%>
90
- it('Should call <%= otherEntity.entityAngularName %> query and add missing value', () => {
91
- const <%= entityInstance %> : I<%= entityAngularName %> = <%- testEntityPrimaryKey1 %>;
92
- <%_ for (const relationship of relationshipsWithCustomSharedOptions) { _%>
93
- <%_ const reference = relationship.reference _%>
94
- <%_ if (relationship.collection) { _%>
95
- const <%= reference.name %> : I<%= otherEntity.entityAngularName %>[] = [<%- generateTestEntityPrimaryKey(otherEntity.primaryKey) %>];
96
- <%_ } else { _%>
97
- const <%= reference.name %> : I<%= otherEntity.entityAngularName %> = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey) %>;
98
- <%_ } _%>
99
- <%= entityInstance %>.<%= reference.name %> = <%= reference.name %>;
100
- <%_ } _%>
101
-
102
- const <%= otherEntity.entityInstance %>Collection: I<%= otherEntity.entityAngularName %>[] = [<%- generateTestEntityPrimaryKey(otherEntity.primaryKey) %>];
103
- jest.spyOn(<%= otherEntity.entityInstance %>Service, 'query').mockReturnValue(of(new HttpResponse({ body: <%= otherEntity.entityInstance %>Collection })));
104
- const additional<%= otherEntity.entityAngularNamePlural %> = [
105
- <%_ for (const relationship of relationshipsWithCustomSharedOptions) { _%>
106
- <%_ const reference = relationship.reference _%>
107
- <% if (relationship.collection) { %>...<% } %><%= reference.name %>,
108
- <%_ } _%>
109
- ];
110
- const expectedCollection: I<%= otherEntity.entityAngularName %>[] = [...additional<%= otherEntity.entityAngularNamePlural %>, ...<%= otherEntity.entityInstance %>Collection];
111
- jest.spyOn(<%= otherEntity.entityInstance %>Service, 'add<%= otherEntity.entityAngularName %>ToCollectionIfMissing').mockReturnValue(expectedCollection);
112
-
113
- activatedRoute.data = of({ <%= entityInstance %> });
114
- comp.ngOnInit();
115
-
116
- expect(<%= otherEntity.entityInstance %>Service.query).toHaveBeenCalled();
117
- expect(<%= otherEntity.entityInstance %>Service.add<%= otherEntity.entityAngularName %>ToCollectionIfMissing).toHaveBeenCalledWith(<%= otherEntity.entityInstance %>Collection, ...additional<%= otherEntity.entityAngularNamePlural %>);
118
- expect(comp.<%= otherEntity.entityInstancePlural %>SharedCollection).toEqual(expectedCollection);
119
- });
120
-
92
+ <%_ const relationshipsWithCustomUniqueOptions = relationshipsByEntityNeedingOptions.filter(rel => rel.relationshipOneToOne && !rel.otherEntityUser); _%>
93
+ <%_ const relationshipsWithCustomSharedOptions = relationshipsByEntityNeedingOptions.filter(rel => !relationshipsWithCustomUniqueOptions.includes(rel)); _%>
94
+ <%_ if (relationshipsWithCustomSharedOptions.length > 0) { _%>
95
+ <%_ const otherEntity = relationshipsByEntityNeedingOptions[0].otherEntity; _%>
96
+ it('Should call <%= otherEntity.entityAngularName %> query and add missing value', () => {
97
+ const <%= entityInstance %> : I<%= entityAngularName %> = <%- testEntityPrimaryKey1 %>;
98
+ <%_ for (const relationship of relationshipsWithCustomSharedOptions) { _%>
99
+ <%_ const reference = relationship.reference _%>
100
+ <%_ if (relationship.collection) { _%>
101
+ const <%= reference.name %> : I<%= otherEntity.entityAngularName %>[] = [<%- generateTestEntityPrimaryKey(otherEntity.primaryKey) %>];
102
+ <%_ } else { _%>
103
+ const <%= reference.name %> : I<%= otherEntity.entityAngularName %> = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey) %>;
104
+ <%_ } _%>
105
+ <%= entityInstance %>.<%= reference.name %> = <%= reference.name %>;
121
106
  <%_ } _%>
122
- <%_ for (const relationship of relationshipsWithCustomUniqueOptions) { %>
123
- <%_ const otherEntity = relationship.otherEntity _%>
124
- <%_ const reference = relationship.reference _%>
125
- it('Should call <%= reference.name %> query and add missing value', () => {
126
- const <%= entityInstance %> : I<%= entityAngularName %> = <%- testEntityPrimaryKey1 %>;
127
- const <%= reference.name %> : I<%= otherEntity.entityAngularName %> = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey) %>;
128
- <%= entityInstance %>.<%= reference.name %> = <%= reference.name %>;
129
-
130
- const <%= reference.name %>Collection: I<%= otherEntity.entityAngularName %>[] = [<%- generateTestEntityPrimaryKey(otherEntity.primaryKey) %>];
131
- jest.spyOn(<%= otherEntity.entityInstance %>Service, 'query').mockReturnValue(of(new HttpResponse({ body: <%= reference.name %>Collection })));
132
- const expectedCollection: I<%= otherEntity.entityAngularName %>[] = [<%= reference.name %>, ...<%= reference.name %>Collection];
133
- jest.spyOn(<%= otherEntity.entityInstance %>Service, 'add<%= otherEntity.entityAngularName %>ToCollectionIfMissing').mockReturnValue(expectedCollection);
134
-
135
- activatedRoute.data = of({ <%= entityInstance %> });
136
- comp.ngOnInit();
137
-
138
- expect(<%= otherEntity.entityInstance %>Service.query).toHaveBeenCalled();
139
- expect(<%= otherEntity.entityInstance %>Service.add<%= otherEntity.entityAngularName %>ToCollectionIfMissing).toHaveBeenCalledWith(<%= reference.name %>Collection, <%= reference.name %>);
140
- expect(comp.<%= relationship.relationshipFieldNamePlural %>Collection).toEqual(expectedCollection);
141
- });
142
107
 
108
+ const <%= otherEntity.entityInstance %>Collection: I<%= otherEntity.entityAngularName %>[] = [<%- generateTestEntityPrimaryKey(otherEntity.primaryKey) %>];
109
+ jest.spyOn(<%= otherEntity.entityInstance %>Service, 'query').mockReturnValue(of(new HttpResponse({ body: <%= otherEntity.entityInstance %>Collection })));
110
+ const additional<%= otherEntity.entityAngularNamePlural %> = [
111
+ <%_ for (const relationship of relationshipsWithCustomSharedOptions) { _%>
112
+ <%_ const reference = relationship.reference _%>
113
+ <% if (relationship.collection) { %>...<% } %><%= reference.name %>,
143
114
  <%_ } _%>
144
- <%_ } _%>
145
- it('Should update editForm', () => {
146
- const <%= entityInstance %>: I<%= entityAngularName %> = <%- testEntityPrimaryKey1 %>;
147
- <%_ for (const relationshipsByEntityNeedingOptions of allRelationshipsByEntityNeedingOptions) { _%>
148
- <%_ for (const relationship of relationshipsByEntityNeedingOptions) { _%>
149
- <%_ const otherEntity = relationship.otherEntity _%>
150
- const <%= relationship.reference.name %>: I<%= otherEntity.entityAngularName %> = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey) %>;
151
- <%= entityInstance %>.<%= relationship.reference.name %> = <%= relationship.collection ? `[${relationship.reference.name}]` : relationship.reference.name %>;
152
- <%_ } _%>
153
- <%_ } _%>
115
+ ];
116
+ const expectedCollection: I<%= otherEntity.entityAngularName %>[] = [...additional<%= otherEntity.entityAngularNamePlural %>, ...<%= otherEntity.entityInstance %>Collection];
117
+ jest.spyOn(<%= otherEntity.entityInstance %>Service, 'add<%= otherEntity.entityAngularName %>ToCollectionIfMissing').mockReturnValue(expectedCollection);
154
118
 
155
119
  activatedRoute.data = of({ <%= entityInstance %> });
156
120
  comp.ngOnInit();
157
121
 
158
- expect(comp.editForm.value).toEqual(expect.objectContaining(<%= entityInstance %>));
159
- <%_ for (const relationshipsByEntityNeedingOptions of allRelationshipsByEntityNeedingOptions) { _%>
160
- <%_ const relationshipsWithCustomUniqueOptions = relationshipsByEntityNeedingOptions.filter(rel => rel.relationshipOneToOne && !rel.otherEntityUser); _%>
161
- <%_ for (const relationship of relationshipsByEntityNeedingOptions) { _%>
162
- <%_ const otherEntity = relationship.otherEntity _%>
163
- expect(comp.<% if (!relationshipsWithCustomUniqueOptions.includes(relationship)) { %><%= otherEntity.entityInstancePlural %>Shared<% } else { %><%= relationship.relationshipFieldNamePlural %><% } %>Collection).toContain(<%= relationship.reference.name %>);
164
- <%_ } _%>
165
- <%_ } _%>
166
- });
122
+ expect(<%= otherEntity.entityInstance %>Service.query).toHaveBeenCalled();
123
+ expect(<%= otherEntity.entityInstance %>Service.add<%= otherEntity.entityAngularName %>ToCollectionIfMissing).toHaveBeenCalledWith(<%= otherEntity.entityInstance %>Collection, ...additional<%= otherEntity.entityAngularNamePlural %>);
124
+ expect(comp.<%= otherEntity.entityInstancePlural %>SharedCollection).toEqual(expectedCollection);
167
125
  });
168
126
 
169
- describe('save', () => {
170
- it('Should call update service on save for existing entity', () => {
171
- // GIVEN
172
- const saveSubject = new Subject<HttpResponse<<%= entityAngularName %>>>();
173
- const <%= entityInstance %> = <%- testEntityPrimaryKey0 %>;
174
- jest.spyOn(<%= entityInstance %>Service, 'update').mockReturnValue(saveSubject);
175
- jest.spyOn(comp, 'previousState');
176
- activatedRoute.data = of({ <%= entityInstance %> });
177
- comp.ngOnInit();
178
-
179
- // WHEN
180
- comp.save();
181
- expect(comp.isSaving).toEqual(true);
182
- saveSubject.next(new HttpResponse({ body: <%= entityInstance %> }));
183
- saveSubject.complete();
127
+ <%_ } _%>
128
+ <%_ for (const relationship of relationshipsWithCustomUniqueOptions) { %>
129
+ <%_ const otherEntity = relationship.otherEntity _%>
130
+ <%_ const reference = relationship.reference _%>
131
+ it('Should call <%= reference.name %> query and add missing value', () => {
132
+ const <%= entityInstance %> : I<%= entityAngularName %> = <%- testEntityPrimaryKey1 %>;
133
+ const <%= reference.name %> : I<%= otherEntity.entityAngularName %> = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey) %>;
134
+ <%= entityInstance %>.<%= reference.name %> = <%= reference.name %>;
184
135
 
185
- // THEN
186
- expect(comp.previousState).toHaveBeenCalled();
187
- expect(<%= entityInstance %>Service.update).toHaveBeenCalledWith(<%= entityInstance %>);
188
- expect(comp.isSaving).toEqual(false);
189
- });
136
+ const <%= reference.name %>Collection: I<%= otherEntity.entityAngularName %>[] = [<%- generateTestEntityPrimaryKey(otherEntity.primaryKey) %>];
137
+ jest.spyOn(<%= otherEntity.entityInstance %>Service, 'query').mockReturnValue(of(new HttpResponse({ body: <%= reference.name %>Collection })));
138
+ const expectedCollection: I<%= otherEntity.entityAngularName %>[] = [<%= reference.name %>, ...<%= reference.name %>Collection];
139
+ jest.spyOn(<%= otherEntity.entityInstance %>Service, 'add<%= otherEntity.entityAngularName %>ToCollectionIfMissing').mockReturnValue(expectedCollection);
190
140
 
191
- it('Should call create service on save for new entity', () => {
192
- // GIVEN
193
- const saveSubject = new Subject<HttpResponse<<%= entityAngularName %>>>();
194
- const <%= entityInstance %> = new <%= entityAngularName %>();
195
- jest.spyOn(<%= entityInstance %>Service, 'create').mockReturnValue(saveSubject);
196
- jest.spyOn(comp, 'previousState');
197
141
  activatedRoute.data = of({ <%= entityInstance %> });
198
142
  comp.ngOnInit();
199
143
 
200
- // WHEN
201
- comp.save();
202
- expect(comp.isSaving).toEqual(true);
203
- saveSubject.next(new HttpResponse({ body: <%= entityInstance %> }));
204
- saveSubject.complete();
144
+ expect(<%= otherEntity.entityInstance %>Service.query).toHaveBeenCalled();
145
+ expect(<%= otherEntity.entityInstance %>Service.add<%= otherEntity.entityAngularName %>ToCollectionIfMissing).toHaveBeenCalledWith(<%= reference.name %>Collection, <%= reference.name %>);
146
+ expect(comp.<%= relationship.relationshipFieldNamePlural %>Collection).toEqual(expectedCollection);
147
+ });
205
148
 
206
- // THEN
207
- expect(<%= entityInstance %>Service.create).toHaveBeenCalledWith(<%= entityInstance %>);
208
- expect(comp.isSaving).toEqual(false);
209
- expect(comp.previousState).toHaveBeenCalled();
210
- });
149
+ <%_ } _%>
150
+ <%_ } _%>
151
+ it('Should update editForm', () => {
152
+ const <%= entityInstance %>: I<%= entityAngularName %> = <%- testEntityPrimaryKey1 %>;
153
+ <%_ for (const relationshipsByEntityNeedingOptions of allRelationshipsByEntityNeedingOptions) { _%>
154
+ <%_ for (const relationship of relationshipsByEntityNeedingOptions) { _%>
155
+ <%_ const otherEntity = relationship.otherEntity _%>
156
+ const <%= relationship.reference.name %>: I<%= otherEntity.entityAngularName %> = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey) %>;
157
+ <%= entityInstance %>.<%= relationship.reference.name %> = <%= relationship.collection ? `[${relationship.reference.name}]` : relationship.reference.name %>;
158
+ <%_ } _%>
159
+ <%_ } _%>
211
160
 
212
- it('Should set isSaving to false on error', () => {
213
- // GIVEN
214
- const saveSubject = new Subject<HttpResponse<<%= entityAngularName %>>>();
215
- const <%= entityInstance %> = <%- testEntityPrimaryKey0 %>;
216
- jest.spyOn(<%= entityInstance %>Service, 'update').mockReturnValue(saveSubject);
217
- jest.spyOn(comp, 'previousState');
218
- activatedRoute.data = of({ <%= entityInstance %> });
219
- comp.ngOnInit();
161
+ activatedRoute.data = of({ <%= entityInstance %> });
162
+ comp.ngOnInit();
220
163
 
221
- // WHEN
222
- comp.save();
223
- expect(comp.isSaving).toEqual(true);
224
- saveSubject.error('This is an error!');
164
+ expect(comp.editForm.value).toEqual(expect.objectContaining(<%= entityInstance %>));
165
+ <%_ for (const relationshipsByEntityNeedingOptions of allRelationshipsByEntityNeedingOptions) { _%>
166
+ <%_ const relationshipsWithCustomUniqueOptions = relationshipsByEntityNeedingOptions.filter(rel => rel.relationshipOneToOne && !rel.otherEntityUser); _%>
167
+ <%_ for (const relationship of relationshipsByEntityNeedingOptions) { _%>
168
+ <%_ const otherEntity = relationship.otherEntity _%>
169
+ expect(comp.<% if (!relationshipsWithCustomUniqueOptions.includes(relationship)) { %><%= otherEntity.entityInstancePlural %>Shared<% } else { %><%= relationship.relationshipFieldNamePlural %><% } %>Collection).toContain(<%= relationship.reference.name %>);
170
+ <%_ } _%>
171
+ <%_ } _%>
172
+ });
173
+ });
225
174
 
226
- // THEN
227
- expect(<%= entityInstance %>Service.update).toHaveBeenCalledWith(<%= entityInstance %>);
228
- expect(comp.isSaving).toEqual(false);
229
- expect(comp.previousState).not.toHaveBeenCalled();
230
- });
175
+ describe('save', () => {
176
+ it('Should call update service on save for existing entity', () => {
177
+ // GIVEN
178
+ const saveSubject = new Subject<HttpResponse<<%= entityAngularName %>>>();
179
+ const <%= entityInstance %> = <%- testEntityPrimaryKey0 %>;
180
+ jest.spyOn(<%= entityInstance %>Service, 'update').mockReturnValue(saveSubject);
181
+ jest.spyOn(comp, 'previousState');
182
+ activatedRoute.data = of({ <%= entityInstance %> });
183
+ comp.ngOnInit();
184
+
185
+ // WHEN
186
+ comp.save();
187
+ expect(comp.isSaving).toEqual(true);
188
+ saveSubject.next(new HttpResponse({ body: <%= entityInstance %> }));
189
+ saveSubject.complete();
190
+
191
+ // THEN
192
+ expect(comp.previousState).toHaveBeenCalled();
193
+ expect(<%= entityInstance %>Service.update).toHaveBeenCalledWith(<%= entityInstance %>);
194
+ expect(comp.isSaving).toEqual(false);
195
+ });
196
+
197
+ it('Should call create service on save for new entity', () => {
198
+ // GIVEN
199
+ const saveSubject = new Subject<HttpResponse<<%= entityAngularName %>>>();
200
+ const <%= entityInstance %> = new <%= entityAngularName %>();
201
+ jest.spyOn(<%= entityInstance %>Service, 'create').mockReturnValue(saveSubject);
202
+ jest.spyOn(comp, 'previousState');
203
+ activatedRoute.data = of({ <%= entityInstance %> });
204
+ comp.ngOnInit();
205
+
206
+ // WHEN
207
+ comp.save();
208
+ expect(comp.isSaving).toEqual(true);
209
+ saveSubject.next(new HttpResponse({ body: <%= entityInstance %> }));
210
+ saveSubject.complete();
211
+
212
+ // THEN
213
+ expect(<%= entityInstance %>Service.create).toHaveBeenCalledWith(<%= entityInstance %>);
214
+ expect(comp.isSaving).toEqual(false);
215
+ expect(comp.previousState).toHaveBeenCalled();
216
+ });
217
+
218
+ it('Should set isSaving to false on error', () => {
219
+ // GIVEN
220
+ const saveSubject = new Subject<HttpResponse<<%= entityAngularName %>>>();
221
+ const <%= entityInstance %> = <%- testEntityPrimaryKey0 %>;
222
+ jest.spyOn(<%= entityInstance %>Service, 'update').mockReturnValue(saveSubject);
223
+ jest.spyOn(comp, 'previousState');
224
+ activatedRoute.data = of({ <%= entityInstance %> });
225
+ comp.ngOnInit();
226
+
227
+ // WHEN
228
+ comp.save();
229
+ expect(comp.isSaving).toEqual(true);
230
+ saveSubject.error('This is an error!');
231
+
232
+ // THEN
233
+ expect(<%= entityInstance %>Service.update).toHaveBeenCalledWith(<%= entityInstance %>);
234
+ expect(comp.isSaving).toEqual(false);
235
+ expect(comp.previousState).not.toHaveBeenCalled();
231
236
  });
237
+ });
232
238
  <%_ const trackedEntities = Object.values(differentRelationships).filter(arr => arr.some(rel => rel.reference.owned && rel.otherEntity.primaryKey)).map(arr => arr[0].reference);
233
239
  if (trackedEntities.length > 0) {
234
240
  _%>
235
241
 
236
- describe('Tracking relationships identifiers', () => {
237
- <%_ for (reference of trackedEntities) {
238
- const otherEntity = reference.relationship.otherEntity;
239
- _%>
240
- describe('track<%= otherEntity.entityAngularName %>By<%= otherEntity.primaryKey.nameCapitalized %>', () => {
241
- it('Should return tracked <%= otherEntity.entityAngularName %> primary key', () => {
242
- const entity = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey, 0) %>;
243
- const trackResult = comp.track<%= otherEntity.entityAngularName %>By<%= otherEntity.primaryKey.nameCapitalized %>(0, entity);
244
- expect(trackResult).toEqual(entity.<%= otherEntity.primaryKey.name %>);
245
- });
242
+ describe('Tracking relationships identifiers', () => {
243
+ <%_ for (reference of trackedEntities) {
244
+ const otherEntity = reference.relationship.otherEntity;
245
+ _%>
246
+ describe('track<%= otherEntity.entityAngularName %>By<%= otherEntity.primaryKey.nameCapitalized %>', () => {
247
+ it('Should return tracked <%= otherEntity.entityAngularName %> primary key', () => {
248
+ const entity = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey, 0) %>;
249
+ const trackResult = comp.track<%= otherEntity.entityAngularName %>By<%= otherEntity.primaryKey.nameCapitalized %>(0, entity);
250
+ expect(trackResult).toEqual(entity.<%= otherEntity.primaryKey.name %>);
246
251
  });
247
-
248
- <%_ } _%>
249
252
  });
253
+
254
+ <%_ } _%>
255
+ });
250
256
  <%_ } _%>
251
257
  <%_ const selectableEntities = Object.values(differentRelationships).filter(arr => arr.some(rel => rel.relationshipManyToMany && rel.reference.owned && rel.otherEntity.primaryKey)).map(arr => arr[0].reference);
252
- if (selectableEntities.length > 0) {
258
+ if (selectableEntities.length > 0) {
253
259
  _%>
254
260
 
255
- describe('Getting selected relationships', () => {
256
- <%_ for (reference of selectableEntities) {
257
- const otherEntity = reference.relationship.otherEntity;
258
- _%>
259
- describe('getSelected<%= otherEntity.entityAngularName %>', () => {
260
- it('Should return option if no <%= otherEntity.entityAngularName %> is selected', () => {
261
- const option = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey, 0) %>;
262
- const result = comp.getSelected<%= otherEntity.entityAngularName %>(option);
263
- expect(result === option).toEqual(true);
264
- });
265
-
266
- it('Should return selected <%= otherEntity.entityAngularName %> for according option', () => {
267
- const option = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey, 0) %>;
268
- const selected = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey, 0) %>;
269
- const selected2 = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey, 1) %>;
270
- const result = comp.getSelected<%= otherEntity.entityAngularName %>(option, [selected2, selected]);
271
- expect(result === selected).toEqual(true);
272
- expect(result === selected2).toEqual(false);
273
- expect(result === option).toEqual(false);
274
- });
275
-
276
- it('Should return option if this <%= otherEntity.entityAngularName %> is not selected', () => {
277
- const option = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey, 0) %>;
278
- const selected = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey, 1) %>;
279
- const result = comp.getSelected<%= otherEntity.entityAngularName %>(option, [selected]);
280
- expect(result === option).toEqual(true);
281
- expect(result === selected).toEqual(false);
282
- });
261
+ describe('Getting selected relationships', () => {
262
+ <%_ for (reference of selectableEntities) {
263
+ const otherEntity = reference.relationship.otherEntity;
264
+ _%>
265
+ describe('getSelected<%= otherEntity.entityAngularName %>', () => {
266
+ it('Should return option if no <%= otherEntity.entityAngularName %> is selected', () => {
267
+ const option = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey, 0) %>;
268
+ const result = comp.getSelected<%= otherEntity.entityAngularName %>(option);
269
+ expect(result === option).toEqual(true);
283
270
  });
284
271
 
285
- <%_ } _%>
272
+ it('Should return selected <%= otherEntity.entityAngularName %> for according option', () => {
273
+ const option = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey, 0) %>;
274
+ const selected = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey, 0) %>;
275
+ const selected2 = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey, 1) %>;
276
+ const result = comp.getSelected<%= otherEntity.entityAngularName %>(option, [selected2, selected]);
277
+ expect(result === selected).toEqual(true);
278
+ expect(result === selected2).toEqual(false);
279
+ expect(result === option).toEqual(false);
280
+ });
281
+
282
+ it('Should return option if this <%= otherEntity.entityAngularName %> is not selected', () => {
283
+ const option = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey, 0) %>;
284
+ const selected = <%- generateTestEntityPrimaryKey(otherEntity.primaryKey, 1) %>;
285
+ const result = comp.getSelected<%= otherEntity.entityAngularName %>(option, [selected]);
286
+ expect(result === option).toEqual(true);
287
+ expect(result === selected).toEqual(false);
288
+ });
286
289
  });
287
- <%_ } _%>
290
+
291
+ <%_ } _%>
288
292
  });
293
+ <%_ } _%>
289
294
  });
@@ -43,7 +43,7 @@ import { Observable } from 'rxjs';
43
43
  import { finalize<% if (relationships.some(rel => rel.ownerSide === true)) { %>, map<% } %> } from 'rxjs/operators';
44
44
 
45
45
  <%_ if (fieldsContainInstant || fieldsContainZonedDateTime) { _%>
46
- import * as dayjs from 'dayjs';
46
+ import dayjs from 'dayjs/esm';
47
47
  import { DATE_TIME_FORMAT } from 'app/config/input.constants';
48
48
  <%_ } _%>
49
49
 
@@ -239,10 +239,10 @@ _%>
239
239
  <%_ } _%>
240
240
 
241
241
  protected subscribeToSaveResponse(result: Observable<HttpResponse<I<%= entityAngularName %>>>): void {
242
- result.pipe(finalize(() => this.onSaveFinalize())).subscribe(
243
- () => this.onSaveSuccess(),
244
- () => this.onSaveError()
245
- );
242
+ result.pipe(finalize(() => this.onSaveFinalize())).subscribe({
243
+ next: () => this.onSaveSuccess(),
244
+ error: () => this.onSaveError()
245
+ });
246
246
  }
247
247
 
248
248
  protected onSaveSuccess(): void {
@@ -42,7 +42,7 @@ import {
42
42
  <%_ } _%>
43
43
  } from './<%= entityFileName %>.page-object';
44
44
  <%_ if (fieldsContainBlobOrImage) { _%>
45
- import * as path from 'path';
45
+ import path from 'path';
46
46
  <%_ } _%>
47
47
 
48
48
  const expect = chai.expect;