generator-jhipster 7.2.0 → 7.3.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 (116) hide show
  1. package/cli/environment-builder.js +1 -0
  2. package/cli/import-jdl.js +2 -2
  3. package/cli/jdl.js +1 -0
  4. package/generators/bootstrap/index.js +2 -1
  5. package/generators/client/__workflow/devserver-angular.json +1 -1
  6. package/generators/client/__workflow/devserver-react.json +1 -1
  7. package/generators/client/__workflow/devserver-vue.json +1 -1
  8. package/generators/client/files-vue.js +2 -0
  9. package/generators/client/index.js +69 -0
  10. package/generators/client/templates/angular/package.json +12 -12
  11. package/generators/client/templates/angular/package.json.ejs +2 -1
  12. package/generators/client/templates/angular/src/main/webapp/app/admin/configuration/configuration.service.spec.ts.ejs +50 -52
  13. package/generators/client/templates/angular/src/main/webapp/app/admin/logs/logs.service.spec.ts.ejs +19 -21
  14. package/generators/client/templates/angular/src/main/webapp/app/admin/metrics/metrics.service.spec.ts.ejs +62 -64
  15. package/generators/client/templates/angular/src/main/webapp/app/admin/user-management/service/user-management.service.spec.ts.ejs +41 -43
  16. package/generators/client/templates/angular/src/main/webapp/app/app.module.ts.ejs +3 -0
  17. package/generators/client/templates/angular/src/main/webapp/app/core/auth/account.service.spec.ts.ejs +178 -180
  18. package/generators/client/templates/angular/src/main/webapp/app/core/config/application-config.service.ts.ejs +9 -0
  19. package/generators/client/templates/angular/src/main/webapp/app/entities/user/user.service.spec.ts.ejs +87 -89
  20. package/generators/client/templates/angular/webpack/webpack.custom.js.ejs +2 -3
  21. package/generators/client/templates/common/README.md.jhi.client.ejs +34 -0
  22. package/generators/client/templates/common/package.json +3 -3
  23. package/generators/client/templates/react/package.json +29 -29
  24. package/generators/client/templates/react/package.json.ejs +1 -1
  25. package/generators/client/templates/vue/package.json +22 -22
  26. package/generators/client/templates/vue/package.json.ejs +1 -1
  27. package/generators/client/templates/vue/src/main/webapp/app/account/account.service.ts.ejs +2 -2
  28. package/generators/client/templates/vue/src/main/webapp/app/admin/configuration/configuration.service.ts.ejs +1 -1
  29. package/generators/client/templates/vue/src/main/webapp/app/admin/tracker/tracker.service.ts.ejs +5 -4
  30. package/generators/client/templates/vue/src/main/webapp/app/admin/user-management/user-management-edit.component.ts.ejs +9 -0
  31. package/generators/client/templates/vue/src/main/webapp/app/admin/user-management/user-management-view.component.ts.ejs +5 -0
  32. package/generators/client/templates/vue/src/main/webapp/app/admin/user-management/user-management.component.ts.ejs +5 -0
  33. package/generators/client/templates/vue/src/main/webapp/app/main.ts.ejs +4 -2
  34. package/generators/client/templates/vue/src/main/webapp/app/router/admin.ts.ejs +4 -4
  35. package/generators/client/templates/vue/src/main/webapp/app/shared/alert/alert.service.ts.ejs +61 -0
  36. package/generators/client/templates/vue/src/test/javascript/spec/app/account/account.service.spec.ts.ejs +2 -2
  37. package/generators/client/templates/vue/src/test/javascript/spec/app/account/login-form/login-form.component.spec.ts.ejs +1 -1
  38. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/tracker/tracker.component.spec.ts.ejs +12 -12
  39. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/tracker/tracker.service.spec.ts.ejs +2 -1
  40. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/user-management/user-management-edit.component.spec.ts.ejs +3 -1
  41. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/user-management/user-management-view.component.spec.ts.ejs +2 -1
  42. package/generators/client/templates/vue/src/test/javascript/spec/app/admin/user-management/user-management.component.spec.ts.ejs +3 -1
  43. package/generators/client/templates/vue/src/test/javascript/spec/app/shared/alert/alert.service.spec.ts.ejs +124 -0
  44. package/generators/common/templates/.husky/pre-commit +1 -1
  45. package/generators/common/templates/package.json +3 -3
  46. package/generators/docker-compose/templates/realm-config/jhipster-realm.json.ejs +13 -12
  47. package/generators/entity/index.js +13 -0
  48. package/generators/entity-client/index.js +53 -0
  49. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/entity-management.module.ts.ejs +1 -1
  50. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/route/entity-management-routing-resolve.service.spec.ts.ejs +52 -54
  51. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/service/entity.service.spec.ts.ejs +173 -175
  52. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/update/entity-management-update.component.html.ejs +2 -4
  53. package/generators/entity-client/templates/angular/src/main/webapp/app/entities/update/entity-management-update.component.ts.ejs +7 -0
  54. package/generators/entity-client/templates/react/src/main/webapp/app/entities/entity-delete-dialog.tsx.ejs +5 -2
  55. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity-details.component.ts.ejs +5 -0
  56. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity-update.component.ts.ejs +14 -2
  57. package/generators/entity-client/templates/vue/src/main/webapp/app/entities/entity.component.ts.ejs +7 -0
  58. package/generators/entity-client/templates/vue/src/test/javascript/spec/app/entities/entity-details.component.spec.ts.ejs +2 -1
  59. package/generators/entity-client/templates/vue/src/test/javascript/spec/app/entities/entity-update.component.spec.ts.ejs +2 -0
  60. package/generators/entity-client/templates/vue/src/test/javascript/spec/app/entities/entity.component.spec.ts.ejs +3 -1
  61. package/generators/entity-server/files-couchbase.js +2 -2
  62. package/generators/entity-server/files.js +31 -30
  63. package/generators/entity-server/templates/couchbase/src/main/java/package/repository/EntityRepository.java.ejs +2 -2
  64. package/generators/entity-server/templates/couchbase/src/main/resources/config/couchmove/changelog/entity.fts.ejs +1 -1
  65. package/generators/entity-server/templates/src/main/java/package/domain/Entity.java.jhi.ejs +2 -2
  66. package/generators/entity-server/templates/src/main/java/package/domain/enumeration/Enum.java.ejs +1 -1
  67. package/generators/entity-server/templates/src/main/java/package/repository/EntityRepository.java.ejs +2 -2
  68. package/generators/entity-server/templates/src/main/java/package/repository/EntityRepositoryInternalImpl_reactive.java.ejs +7 -7
  69. package/generators/entity-server/templates/src/main/java/package/repository/EntityRepository_reactive.java.ejs +2 -2
  70. package/generators/entity-server/templates/src/main/java/package/repository/rowmapper/EntityRowMapper.java.ejs +4 -4
  71. package/generators/entity-server/templates/src/main/java/package/repository/search/EntitySearchRepository.java.ejs +2 -2
  72. package/generators/entity-server/templates/src/main/java/package/service/EntityQueryService.java.ejs +8 -8
  73. package/generators/entity-server/templates/src/main/java/package/service/EntityService.java.ejs +4 -4
  74. package/generators/entity-server/templates/src/main/java/package/service/criteria/EntityCriteria.java.ejs +4 -4
  75. package/generators/entity-server/templates/src/main/java/package/service/dto/EntityDTO.java.ejs +3 -3
  76. package/generators/entity-server/templates/src/main/java/package/service/impl/EntityServiceImpl.java.ejs +8 -8
  77. package/generators/entity-server/templates/src/main/java/package/service/mapper/BaseEntityMapper.java.ejs +1 -1
  78. package/generators/entity-server/templates/src/main/java/package/service/mapper/EntityMapper.java.ejs +3 -3
  79. package/generators/entity-server/templates/src/main/java/package/web/rest/EntityResource.java.ejs +12 -12
  80. package/generators/entity-server/templates/src/test/java/package/domain/EntityTest.java.ejs +1 -1
  81. package/generators/entity-server/templates/src/test/java/package/repository/search/EntitySearchRepositoryMockConfiguration.java.ejs +1 -1
  82. package/generators/entity-server/templates/src/test/java/package/service/dto/EntityDTOTest.java.ejs +1 -1
  83. package/generators/entity-server/templates/src/test/java/package/service/mapper/EntityMapperTest.java.ejs +1 -1
  84. package/generators/entity-server/templates/src/test/java/package/web/rest/EntityResourceIT.java.ejs +18 -15
  85. package/generators/generator-base.js +10 -3
  86. package/generators/generator-constants.js +6 -5
  87. package/generators/heroku/index.js +13 -15
  88. package/generators/init/templates/.husky/pre-commit +1 -1
  89. package/generators/kubernetes-helm/templates/app/Chart.yml.ejs +22 -0
  90. package/generators/kubernetes-helm/templates/app/requirements.yml.ejs +2 -2
  91. package/generators/kubernetes-helm/templates/csvc/Chart.yml.ejs +17 -0
  92. package/generators/kubernetes-helm/templates/csvc/requirements.yml.ejs +3 -3
  93. package/generators/languages/templates/src/main/webapp/i18n/hr/reset.json.ejs +1 -2
  94. package/generators/maven/templates/.mvn/wrapper/maven-wrapper.properties +1 -1
  95. package/generators/server/index.js +38 -13
  96. package/generators/server/needle-api/needle-server-cache.js +4 -6
  97. package/generators/server/templates/.mvn/wrapper/maven-wrapper.properties +1 -1
  98. package/generators/server/templates/build.gradle.ejs +1 -1
  99. package/generators/server/templates/gradle.properties.ejs +1 -1
  100. package/generators/server/templates/pom.xml.ejs +4 -3
  101. package/generators/server/templates/settings.gradle.ejs +9 -0
  102. package/generators/server/templates/src/main/docker/app.yml.ejs +1 -0
  103. package/generators/server/templates/src/main/docker/config/realm-config/jhipster-realm.json.ejs +13 -12
  104. package/generators/server/templates/src/main/java/package/aop/logging/LoggingAspect.java.ejs +1 -1
  105. package/generators/server/templates/src/main/java/package/config/DatabaseConfiguration_cassandra.java.ejs +0 -6
  106. package/generators/server/templates/src/main/java/package/config/DatabaseConfiguration_sql.java.ejs +2 -2
  107. package/generators/server/templates/src/main/java/package/config/JacksonConfiguration.java.ejs +1 -1
  108. package/generators/server/templates/src/main/java/package/config/LocaleConfiguration.java.ejs +0 -2
  109. package/generators/server/templates/src/main/java/package/config/SecurityConfiguration.java.ejs +2 -5
  110. package/generators/server/templates/src/main/java/package/config/SecurityConfiguration_reactive.java.ejs +9 -1
  111. package/generators/server/templates/src/main/java/package/security/PersistentTokenRememberMeServices.java.ejs +0 -2
  112. package/generators/server/templates/src/main/resources/config/application-dev.yml.ejs +1 -1
  113. package/generators/server/templates/src/main/resources/config/application-prod.yml.ejs +1 -1
  114. package/generators/server/templates/src/main/resources/config/application.yml.ejs +2 -2
  115. package/package.json +12 -12
  116. package/utils/field.js +1 -1
@@ -43,6 +43,7 @@ module.exports = class EnvironmentBuilder {
43
43
  jhipsterSharedData: new SharedData(),
44
44
  };
45
45
  const env = Environment.createEnv(args, { newErrorHandler: true, ...options, sharedOptions }, adapter);
46
+ env.setMaxListeners(0);
46
47
  return new EnvironmentBuilder(env);
47
48
  }
48
49
 
package/cli/import-jdl.js CHANGED
@@ -432,8 +432,8 @@ class JDLProcessor {
432
432
  applicationWithEntities.config.applications = Object.fromEntries(
433
433
  relatedApplications.map(([baseName, config]) => {
434
434
  config.gatewayServerPort = gatewayServerPort;
435
- const { serverPort, applicationIndex } = config;
436
- return [baseName, { serverPort, applicationIndex }];
435
+ const { serverPort, applicationIndex, devServerPort } = config;
436
+ return [baseName, { serverPort, applicationIndex, devServerPort }];
437
437
  })
438
438
  );
439
439
  }
package/cli/jdl.js CHANGED
@@ -54,6 +54,7 @@ module.exports = ([jdlFiles = []], options = {}, env, forkProcess) => {
54
54
  }
55
55
  const promises = jdlFiles.map(toJdlFile).map(filename => {
56
56
  if (!fs.existsSync(filename)) {
57
+ logger.info(`File not found: ${filename}. Attempting download from jdl-samples repository`);
57
58
  return download([[filename]], options);
58
59
  }
59
60
  return Promise.resolve(filename);
@@ -160,10 +160,11 @@ module.exports = class extends BaseGenerator {
160
160
  }
161
161
  }
162
162
  });
163
+ const yoResolveTranform = this.options.skipYoResolve ? [] : [createYoResolveTransform(this.env.conflicter)];
163
164
  const transformStreams = [
164
165
  // multi-step changes the file path, should be executed earlier in the pipeline
165
166
  new MultiStepTransform(),
166
- createYoResolveTransform(this.env.conflicter),
167
+ ...yoResolveTranform,
167
168
  createYoRcTransform(),
168
169
  createEachFileTransform(file => {
169
170
  if (path.extname(file.path) === '.json' && path.basename(path.dirname(file.path)) === '.jhipster') {
@@ -3,7 +3,7 @@
3
3
  {
4
4
  "app-sample": "ngx-default",
5
5
  "cache": "angular",
6
- "entity": "sqlfull",
6
+ "entity": "sqllight",
7
7
  "environment": "prod",
8
8
  "war": 0,
9
9
  "e2e": 1,
@@ -3,7 +3,7 @@
3
3
  {
4
4
  "app-sample": "react-default",
5
5
  "cache": "react",
6
- "entity": "sqlfull",
6
+ "entity": "sqllight",
7
7
  "environment": "prod",
8
8
  "war": 0,
9
9
  "e2e": 1,
@@ -3,7 +3,7 @@
3
3
  {
4
4
  "app-sample": "vue-default",
5
5
  "cache": "vue",
6
- "entity": "sqlfull",
6
+ "entity": "sqllight",
7
7
  "environment": "prod",
8
8
  "war": 0,
9
9
  "e2e": 1,
@@ -68,6 +68,7 @@ const vueFiles = {
68
68
  'shims-vue.d.ts',
69
69
  'constants.ts',
70
70
  'main.ts',
71
+ 'shared/alert/alert.service.ts',
71
72
  'shared/config/axios-interceptor.ts',
72
73
  'shared/config/config.ts',
73
74
  'shared/config/config-bootstrap-vue.ts',
@@ -231,6 +232,7 @@ const vueFiles = {
231
232
  'spec/app/core/error/error.component.spec.ts',
232
233
  'spec/app/core/jhi-navbar/jhi-navbar.component.spec.ts',
233
234
  'spec/app/core/ribbon/ribbon.component.spec.ts',
235
+ 'spec/app/shared/alert/alert.service.spec.ts',
234
236
  'spec/app/shared/config/axios-interceptor.spec.ts',
235
237
  'spec/app/shared/data/data-utils.service.spec.ts',
236
238
  ],
@@ -25,6 +25,8 @@ const writeAngularFiles = require('./files-angular').writeFiles;
25
25
  const writeReactFiles = require('./files-react').writeFiles;
26
26
  const { writeFiles: writeVueFiles, customizeFiles: customizeVueFiles } = require('./files-vue');
27
27
  const writeCommonFiles = require('./files-common').writeFiles;
28
+ const { clientI18nFiles } = require('../languages/files');
29
+
28
30
  const packagejs = require('../../package.json');
29
31
  const constants = require('../generator-constants');
30
32
  const statistics = require('../statistics');
@@ -264,6 +266,19 @@ module.exports = class JHipsterClientGenerator extends BaseBlueprintGenerator {
264
266
  this.skipUserManagement = true;
265
267
  }
266
268
  },
269
+
270
+ async loadNativeLanguage() {
271
+ if (!this.jhipsterConfig.baseName) return;
272
+ const context = {};
273
+ this.loadAppConfig(undefined, context);
274
+ this.loadDerivedAppConfig(context);
275
+ this.loadClientConfig(undefined, context);
276
+ this.loadDerivedClientConfig(context);
277
+ this.loadServerConfig(undefined, context);
278
+ this.loadPlatformConfig(undefined, context);
279
+ this.loadTranslationConfig(undefined, context);
280
+ await this._loadClientTranslations(context);
281
+ },
267
282
  };
268
283
  }
269
284
 
@@ -399,4 +414,58 @@ module.exports = class JHipsterClientGenerator extends BaseBlueprintGenerator {
399
414
  if (useBlueprints) return;
400
415
  return this._end();
401
416
  }
417
+
418
+ /**
419
+ * @experimental
420
+ * Load client native translation.
421
+ */
422
+ async _loadClientTranslations(configContext = this) {
423
+ configContext.clientTranslations = this.configOptions.clientTranslations;
424
+ if (configContext.clientTranslations) {
425
+ this.clientTranslations = configContext.clientTranslations;
426
+ return;
427
+ }
428
+ const { nativeLanguage } = configContext;
429
+ this.clientTranslations = configContext.clientTranslations = this.configOptions.clientTranslations = {};
430
+ const rootTemplatesPath = this.fetchFromInstalledJHipster('languages/templates/');
431
+
432
+ // Prepare and load en translation
433
+ const translationFiles = await this.writeFiles({
434
+ sections: clientI18nFiles,
435
+ rootTemplatesPath,
436
+ context: {
437
+ ...configContext,
438
+ lang: 'en',
439
+ clientSrcDir: '__tmp__',
440
+ },
441
+ });
442
+
443
+ // Prepare and load native translation
444
+ configContext.lang = configContext.nativeLanguage;
445
+ if (nativeLanguage && nativeLanguage !== 'en') {
446
+ translationFiles.push(
447
+ ...(await this.writeFiles({
448
+ sections: clientI18nFiles,
449
+ rootTemplatesPath,
450
+ context: {
451
+ ...configContext,
452
+ lang: configContext.nativeLanguage,
453
+ clientSrcDir: '__tmp__',
454
+ },
455
+ }))
456
+ );
457
+ }
458
+ for (const translationFile of translationFiles) {
459
+ _.merge(this.clientTranslations, this.readDestinationJSON(translationFile));
460
+ delete this.env.sharedFs.get(translationFile).state;
461
+ }
462
+ }
463
+
464
+ /**
465
+ * @experimental
466
+ * Get translation value for a key.
467
+ */
468
+ _getClientTranslation(translationKey) {
469
+ return _.get(this.clientTranslations, translationKey, `Translation missing for ${translationKey}`);
470
+ }
402
471
  };
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "dependencies": {
3
- "@angular/common": "12.2.5",
3
+ "@angular/common": "12.2.9",
4
4
  "bootstrap": "4.6.0",
5
5
  "@fortawesome/angular-fontawesome": "0.9.0",
6
6
  "@fortawesome/fontawesome-svg-core": "1.2.36",
@@ -12,18 +12,18 @@
12
12
  "ngx-infinite-scroll": "10.0.1",
13
13
  "ngx-webstorage": "8.0.0",
14
14
  "rxjs": "6.6.7",
15
- "swagger-ui-dist": "3.52.2",
15
+ "swagger-ui-dist": "3.52.3",
16
16
  "tslib": "2.3.1",
17
17
  "zone.js": "0.11.4"
18
18
  },
19
19
  "devDependencies": {
20
- "@angular/cli": "12.2.5",
21
- "@angular-builders/custom-webpack": "12.1.2",
20
+ "@angular/cli": "12.2.9",
21
+ "@angular-builders/custom-webpack": "12.1.3",
22
22
  "@angular-builders/jest": "12.1.2",
23
- "@angular-eslint/eslint-plugin": "12.4.1",
24
- "@types/node": "16.9.1",
25
- "@types/jest": "27.0.1",
26
- "@typescript-eslint/eslint-plugin": "4.31.1",
23
+ "@angular-eslint/eslint-plugin": "12.5.0",
24
+ "@types/node": "16.10.3",
25
+ "@types/jest": "27.0.2",
26
+ "@typescript-eslint/eslint-plugin": "4.33.0",
27
27
  "browser-sync": "2.27.5",
28
28
  "browser-sync-webpack-plugin": "2.3.0",
29
29
  "copy-webpack-plugin": "9.0.1",
@@ -31,10 +31,10 @@
31
31
  "eslint-config-prettier": "8.3.0",
32
32
  "eslint-webpack-plugin": "3.0.1",
33
33
  "folder-hash": "4.0.1",
34
- "jest": "27.2.0",
35
- "jest-preset-angular": "9.0.7",
34
+ "jest": "27.2.4",
35
+ "jest-preset-angular": "10.0.1",
36
36
  "jest-date-mock": "1.0.8",
37
- "jest-junit": "12.2.0",
37
+ "jest-junit": "13.0.0",
38
38
  "jest-sonar-reporter": "2.0.0",
39
39
  "merge-jsons-webpack-plugin": "1.0.21",
40
40
  "rimraf": "3.0.2",
@@ -43,6 +43,6 @@
43
43
  "webpack": "5.50.0",
44
44
  "webpack-bundle-analyzer": "4.4.2",
45
45
  "webpack-merge": "5.8.0",
46
- "webpack-notifier": "1.13.0"
46
+ "webpack-notifier": "1.14.0"
47
47
  }
48
48
  }
@@ -20,7 +20,7 @@
20
20
  {
21
21
  "name": "<%= dasherizedBaseName %>",
22
22
  "version": "0.0.1-SNAPSHOT",
23
- "description": "Description for <%= baseName %>",
23
+ "description": "<%= projectDescription %>",
24
24
  "private": true,
25
25
  "license": "UNLICENSED",
26
26
  "cacheDirectories": [
@@ -175,6 +175,7 @@
175
175
  "test": "ng test --coverage --log-heap-usage -w=2",
176
176
  "test:watch": "<%= clientPackageManager %> run test -- --watch",
177
177
  "watch": "concurrently npm:start<% if(!skipServer) { %> npm:backend:start<% } %>",
178
+ "build-watch": "concurrently 'npm run webapp:build:dev -- --watch'<% if(!skipServer) { %> npm:backend:start<% } %>",
178
179
  "webapp:build": "<%= clientPackageManager %> run clean-www && <%= clientPackageManager %> run webapp:build:dev",
179
180
  "webapp:build:dev": "ng build --configuration development",
180
181
  "webapp:build:prod": "ng build --configuration production",
@@ -22,70 +22,68 @@ import { HttpClientTestingModule, HttpTestingController } from '@angular/common/
22
22
  import { ConfigurationService } from './configuration.service';
23
23
  import { Bean, ConfigProps, Env, PropertySource } from './configuration.model';
24
24
 
25
- describe('Service Tests', () => {
26
- describe('Logs Service', () => {
27
- let service: ConfigurationService;
28
- let httpMock: HttpTestingController;
29
- let expectedResult: Bean[] | PropertySource[] | null;
25
+ describe('Logs Service', () => {
26
+ let service: ConfigurationService;
27
+ let httpMock: HttpTestingController;
28
+ let expectedResult: Bean[] | PropertySource[] | null;
30
29
 
31
- beforeEach(() => {
32
- TestBed.configureTestingModule({
33
- imports: [HttpClientTestingModule],
34
- });
35
-
36
- expectedResult = null;
37
- service = TestBed.inject(ConfigurationService);
38
- httpMock = TestBed.inject(HttpTestingController);
30
+ beforeEach(() => {
31
+ TestBed.configureTestingModule({
32
+ imports: [HttpClientTestingModule],
39
33
  });
40
34
 
41
- afterEach(() => {
42
- httpMock.verify();
43
- });
35
+ expectedResult = null;
36
+ service = TestBed.inject(ConfigurationService);
37
+ httpMock = TestBed.inject(HttpTestingController);
38
+ });
44
39
 
45
- describe('Service methods', () => {
46
- it('should get the config', () => {
47
- const bean: Bean = {
48
- prefix: 'jhipster',
49
- properties: {
50
- clientApp: {
51
- name: 'jhipsterApp',
52
- },
40
+ afterEach(() => {
41
+ httpMock.verify();
42
+ });
43
+
44
+ describe('Service methods', () => {
45
+ it('should get the config', () => {
46
+ const bean: Bean = {
47
+ prefix: 'jhipster',
48
+ properties: {
49
+ clientApp: {
50
+ name: 'jhipsterApp',
53
51
  },
54
- };
55
- const configProps: ConfigProps = {
56
- contexts: {
57
- jhipster: {
58
- beans: {
59
- 'tech.jhipster.config.JHipsterProperties': bean,
60
- },
52
+ },
53
+ };
54
+ const configProps: ConfigProps = {
55
+ contexts: {
56
+ jhipster: {
57
+ beans: {
58
+ 'tech.jhipster.config.JHipsterProperties': bean,
61
59
  },
62
60
  },
63
- };
64
- service.getBeans().subscribe(received => (expectedResult = received));
61
+ },
62
+ };
63
+ service.getBeans().subscribe(received => (expectedResult = received));
65
64
 
66
- const req = httpMock.expectOne({ method: 'GET' });
67
- req.flush(configProps);
68
- expect(expectedResult).toEqual([bean]);
69
- });
65
+ const req = httpMock.expectOne({ method: 'GET' });
66
+ req.flush(configProps);
67
+ expect(expectedResult).toEqual([bean]);
68
+ });
70
69
 
71
- it('should get the env', () => {
72
- const propertySources: PropertySource[] = [
73
- {
74
- name: 'server.ports',
75
- properties: {
76
- 'local.server.port': {
77
- value: '8080',
78
- },
70
+ it('should get the env', () => {
71
+ const propertySources: PropertySource[] = [
72
+ {
73
+ name: 'server.ports',
74
+ properties: {
75
+ 'local.server.port': {
76
+ value: '8080',
79
77
  },
80
78
  },
81
- ];
82
- const env: Env = { propertySources };
83
- service.getPropertySources().subscribe(received => (expectedResult = received));
79
+ },
80
+ ];
81
+ const env: Env = { propertySources };
82
+ service.getPropertySources().subscribe(received => (expectedResult = received));
84
83
 
85
- const req = httpMock.expectOne({ method: 'GET' });
86
- req.flush(env);
87
- expect(expectedResult).toEqual(propertySources);
88
- });
84
+ const req = httpMock.expectOne({ method: 'GET' });
85
+ req.flush(env);
86
+ expect(expectedResult).toEqual(propertySources);
89
87
  });
90
88
  });
91
89
  });
@@ -21,31 +21,29 @@ import { HttpClientTestingModule, HttpTestingController } from '@angular/common/
21
21
 
22
22
  import { LogsService } from './logs.service';
23
23
 
24
- describe('Service Tests', () => {
25
- describe('Logs Service', () => {
26
- let service: LogsService;
27
- let httpMock: HttpTestingController;
28
-
29
- beforeEach(() => {
30
- TestBed.configureTestingModule({
31
- imports: [HttpClientTestingModule],
32
- });
33
-
34
- service = TestBed.inject(LogsService);
35
- httpMock = TestBed.inject(HttpTestingController);
36
- });
24
+ describe('Logs Service', () => {
25
+ let service: LogsService;
26
+ let httpMock: HttpTestingController;
37
27
 
38
- afterEach(() => {
39
- httpMock.verify();
28
+ beforeEach(() => {
29
+ TestBed.configureTestingModule({
30
+ imports: [HttpClientTestingModule],
40
31
  });
41
32
 
42
- describe('Service methods', () => {
43
- it('should change log level', () => {
44
- service.changeLevel('main', 'ERROR').subscribe();
33
+ service = TestBed.inject(LogsService);
34
+ httpMock = TestBed.inject(HttpTestingController);
35
+ });
36
+
37
+ afterEach(() => {
38
+ httpMock.verify();
39
+ });
40
+
41
+ describe('Service methods', () => {
42
+ it('should change log level', () => {
43
+ service.changeLevel('main', 'ERROR').subscribe();
45
44
 
46
- const req = httpMock.expectOne({ method: 'POST' });
47
- expect(req.request.body).toEqual({ configuredLevel: 'ERROR' });
48
- });
45
+ const req = httpMock.expectOne({ method: 'POST' });
46
+ expect(req.request.body).toEqual({ configuredLevel: 'ERROR' });
49
47
  });
50
48
  });
51
49
  });
@@ -22,80 +22,78 @@ import { HttpClientTestingModule, HttpTestingController } from '@angular/common/
22
22
  import { MetricsService } from './metrics.service';
23
23
  import { ThreadDump, ThreadState } from './metrics.model';
24
24
 
25
- describe('Service Tests', () => {
26
- describe('Logs Service', () => {
27
- let service: MetricsService;
28
- let httpMock: HttpTestingController;
25
+ describe('Logs Service', () => {
26
+ let service: MetricsService;
27
+ let httpMock: HttpTestingController;
29
28
 
30
- beforeEach(() => {
31
- TestBed.configureTestingModule({
32
- imports: [HttpClientTestingModule],
33
- });
34
- service = TestBed.inject(MetricsService);
35
- httpMock = TestBed.inject(HttpTestingController);
36
- });
37
-
38
- afterEach(() => {
39
- httpMock.verify();
29
+ beforeEach(() => {
30
+ TestBed.configureTestingModule({
31
+ imports: [HttpClientTestingModule],
40
32
  });
33
+ service = TestBed.inject(MetricsService);
34
+ httpMock = TestBed.inject(HttpTestingController);
35
+ });
41
36
 
42
- describe('Service methods', () => {
43
- it('should return Metrics', () => {
44
- let expectedResult;
45
- const metrics = {
46
- jvm: {},
47
- 'http.server.requests': {},
48
- cache: {},
49
- services: {},
50
- databases: {},
51
- garbageCollector: {},
52
- processMetrics: {},
53
- };
37
+ afterEach(() => {
38
+ httpMock.verify();
39
+ });
54
40
 
55
- service.getMetrics().subscribe(received => {
56
- expectedResult = received;
57
- });
41
+ describe('Service methods', () => {
42
+ it('should return Metrics', () => {
43
+ let expectedResult;
44
+ const metrics = {
45
+ jvm: {},
46
+ 'http.server.requests': {},
47
+ cache: {},
48
+ services: {},
49
+ databases: {},
50
+ garbageCollector: {},
51
+ processMetrics: {},
52
+ };
58
53
 
59
- const req = httpMock.expectOne({ method: 'GET' });
60
- req.flush(metrics);
61
- expect(expectedResult).toEqual(metrics);
54
+ service.getMetrics().subscribe(received => {
55
+ expectedResult = received;
62
56
  });
63
57
 
64
- it('should return Thread Dump', () => {
65
- let expectedResult: ThreadDump | null = null;
66
- const dump: ThreadDump = {
67
- threads: [
68
- {
69
- threadName: 'Reference Handler',
70
- threadId: 2,
71
- blockedTime: -1,
72
- blockedCount: 7,
73
- waitedTime: -1,
74
- waitedCount: 0,
75
- lockName: null,
76
- lockOwnerId: -1,
77
- lockOwnerName: null,
78
- daemon: true,
79
- inNative: false,
80
- suspended: false,
81
- threadState: ThreadState.Runnable,
82
- priority: 10,
83
- stackTrace: [],
84
- lockedMonitors: [],
85
- lockedSynchronizers: [],
86
- lockInfo: null,
87
- },
88
- ],
89
- };
58
+ const req = httpMock.expectOne({ method: 'GET' });
59
+ req.flush(metrics);
60
+ expect(expectedResult).toEqual(metrics);
61
+ });
90
62
 
91
- service.threadDump().subscribe(received => {
92
- expectedResult = received;
93
- });
63
+ it('should return Thread Dump', () => {
64
+ let expectedResult: ThreadDump | null = null;
65
+ const dump: ThreadDump = {
66
+ threads: [
67
+ {
68
+ threadName: 'Reference Handler',
69
+ threadId: 2,
70
+ blockedTime: -1,
71
+ blockedCount: 7,
72
+ waitedTime: -1,
73
+ waitedCount: 0,
74
+ lockName: null,
75
+ lockOwnerId: -1,
76
+ lockOwnerName: null,
77
+ daemon: true,
78
+ inNative: false,
79
+ suspended: false,
80
+ threadState: ThreadState.Runnable,
81
+ priority: 10,
82
+ stackTrace: [],
83
+ lockedMonitors: [],
84
+ lockedSynchronizers: [],
85
+ lockInfo: null,
86
+ },
87
+ ],
88
+ };
94
89
 
95
- const req = httpMock.expectOne({ method: 'GET' });
96
- req.flush(dump);
97
- expect(expectedResult).toEqual(dump);
90
+ service.threadDump().subscribe(received => {
91
+ expectedResult = received;
98
92
  });
93
+
94
+ const req = httpMock.expectOne({ method: 'GET' });
95
+ req.flush(dump);
96
+ expect(expectedResult).toEqual(dump);
99
97
  });
100
98
  });
101
99
  });