From a4867882847f8df7d29bd469d4e601d86510036e Mon Sep 17 00:00:00 2001 From: Damien Vitrac Date: Tue, 10 Dec 2024 14:24:36 +0100 Subject: [PATCH 1/2] feat: Update SCDF-UI to use the latest APIs Resolves #2021 --- ui/src/app/app.module.ts | 3 +- .../apps/add/register/register.component.html | 26 ---------- .../add/register/register.component.spec.ts | 16 +++---- .../apps/add/register/register.component.ts | 5 +- ui/src/app/apps/apps.component.html | 14 ------ ui/src/app/apps/apps.component.spec.ts | 6 +-- ui/src/app/shared/api/app.service.spec.ts | 2 - ui/src/app/shared/api/app.service.ts | 5 +- ui/src/app/shared/api/job.service.ts | 35 ++++---------- ui/src/app/shared/api/task.service.spec.ts | 21 ++++---- ui/src/app/shared/api/task.service.ts | 48 +++++-------------- ui/src/app/shared/model/job.model.ts | 3 -- .../app/shared/model/task-execution.model.ts | 5 -- .../execution/execution.component.html | 8 +--- .../execution/execution.component.ts | 1 - .../executions/executions.component.html | 13 +---- .../executions/executions.component.ts | 4 +- .../jobs/execution/execution.component.html | 39 ++++----------- .../jobs/execution/execution.component.ts | 9 ++-- .../app/tasks-jobs/jobs/jobs.component.html | 18 +------ ui/src/app/tasks-jobs/jobs/jobs.component.ts | 4 +- .../tasks-jobs/jobs/step/step.component.html | 8 +--- .../tasks-jobs/jobs/step/step.component.ts | 12 ++--- .../tasks-jobs/tasks-jobs-routing.module.ts | 6 +-- .../tasks/launch/launch.component.spec.ts | 2 +- .../tasks/launch/launch.component.ts | 6 +-- .../tasks-jobs/tasks/task/task.component.html | 19 ++------ .../tasks-jobs/tasks/task/task.component.ts | 4 +- ui/src/app/tests/api/task.service.mock.ts | 2 +- 29 files changed, 78 insertions(+), 266 deletions(-) diff --git a/ui/src/app/app.module.ts b/ui/src/app/app.module.ts index 01eb8a8f1..5a7ffbcf0 100644 --- a/ui/src/app/app.module.ts +++ b/ui/src/app/app.module.ts @@ -30,6 +30,7 @@ import {AppsModule} from './apps/apps.module'; import {UrlUtilities} from './url-utilities.service'; import {TaskService} from './shared/api/task.service'; import {JobService} from './shared/api/job.service'; +import {DevModule} from './dev/dev.module'; @NgModule({ declarations: [AppComponent], @@ -44,7 +45,7 @@ import {JobService} from './shared/api/job.service'; FormsModule, LayoutModule, // DashboardModule, - // DevModule, + DevModule, StreamsModule, TasksJobsModule, ManageModule, diff --git a/ui/src/app/apps/add/register/register.component.html b/ui/src/app/apps/add/register/register.component.html index b39667ceb..9dc886265 100644 --- a/ui/src/app/apps/add/register/register.component.html +++ b/ui/src/app/apps/add/register/register.component.html @@ -48,32 +48,6 @@ -
- -
-
- -
-
- {{ 'applications.add.register.invalidType' | translate }} -
-
-
{ const navigate = spyOn((component).router, 'navigateByUrl'); fixture.detectChanges(); const tests = [ - {name: 'foobar1', type: 'source', uri: 'https://foo.bar', metaDataUri: '', bootVersion: '3', force: false}, - {name: '', type: '', uri: '', metaDataUri: '', bootVersion: '2', force: false}, - {name: '', type: '', uri: '', metaDataUri: '', bootVersion: '2', force: false} + {name: 'foobar1', type: 'source', uri: 'https://foo.bar', metaDataUri: '', force: false}, + {name: '', type: '', uri: '', metaDataUri: '', force: false}, + {name: '', type: '', uri: '', metaDataUri: '', force: false} ]; component.newForm(); component.newForm(); @@ -80,7 +80,6 @@ describe('apps/register/register.component.ts', () => { component.forms[index].get('name').setValue(test.name); component.forms[index].get('type').setValue(test.type); component.forms[index].get('uri').setValue(test.uri); - component.forms[index].get('bootVersion').setValue(test.bootVersion); component.forms[index].get('metaDataUri').setValue(test.metaDataUri); component.forms[index].get('force').setValue(test.force); }); @@ -108,9 +107,9 @@ describe('apps/register/register.component.ts', () => { it('should display errors form', () => { fixture.detectChanges(); const tests = [ - {name: 'foobar1', type: 'source', uri: 'https://foo.bar', metaDataUri: '', bootVersion: '3', force: false}, - {name: 'foobar2', type: 'sink', uri: 'https://foo.bar', metaDataUri: '', bootVersion: '2', force: false}, - {name: 'foobar3', type: 'processor', uri: '', metaDataUri: '', bootVersion: '3', force: false} + {name: 'foobar1', type: 'source', uri: 'https://foo.bar', metaDataUri: '', force: false}, + {name: 'foobar2', type: 'sink', uri: 'https://foo.bar', metaDataUri: '', force: false}, + {name: 'foobar3', type: 'processor', uri: '', metaDataUri: '', force: false} ]; component.newForm(); component.newForm(); @@ -118,7 +117,6 @@ describe('apps/register/register.component.ts', () => { component.forms[index].get('name').setValue(test.name); component.forms[index].get('type').setValue(test.type); component.forms[index].get('uri').setValue(test.uri); - component.forms[index].get('bootVersion').setValue(test.bootVersion); component.forms[index].get('metaDataUri').setValue(test.metaDataUri); component.forms[index].get('force').setValue(test.force); }); @@ -137,13 +135,11 @@ describe('apps/register/register.component.ts', () => { type: 'source', uri: 'https://foo.bar', metaDataUri: '', - bootVersion: '3', force: false }; component.forms[0].get('name').setValue(test.name); component.forms[0].get('type').setValue(test.type); component.forms[0].get('uri').setValue(test.uri); - component.forms[0].get('bootVersion').setValue(test.bootVersion); component.forms[0].get('metaDataUri').setValue(test.metaDataUri); component.forms[0].get('force').setValue(test.force); fixture.detectChanges(); diff --git a/ui/src/app/apps/add/register/register.component.ts b/ui/src/app/apps/add/register/register.component.ts index cfeffaec8..9a4ba4f59 100644 --- a/ui/src/app/apps/add/register/register.component.ts +++ b/ui/src/app/apps/add/register/register.component.ts @@ -59,7 +59,6 @@ export class RegisterComponent implements OnInit { type: form.get('type').value as ApplicationType, uri: form.get('uri').value, metaDataUri: form.get('metaDataUri').value, - bootVersion: form.get('bootVersion').value, force: form.get('force').value }; } @@ -109,8 +108,7 @@ export class RegisterComponent implements OnInit { form.get('uri').hasError('required') && form.get('name').hasError('required') && form.get('metaDataUri').value === '' && - form.get('type').hasError('required') && - form.get('bootVersion').value === this.defaultBoot + form.get('type').hasError('required') ); } @@ -121,7 +119,6 @@ export class RegisterComponent implements OnInit { type: new UntypedFormControl('', Validators.required), uri: new UntypedFormControl('', [AppsAddValidator.appUri, Validators.required]), metaDataUri: new UntypedFormControl('', AppsAddValidator.appUri), - bootVersion: new UntypedFormControl(this.defaultBoot, Validators.required), force: new UntypedFormControl(false) }); diff --git a/ui/src/app/apps/apps.component.html b/ui/src/app/apps/apps.component.html index 859b23249..bac8a2110 100644 --- a/ui/src/app/apps/apps.component.html +++ b/ui/src/app/apps/apps.component.html @@ -83,17 +83,6 @@

- - - {{ 'applications.main.bootVersion' | translate }} - - - {{ app.versions?.length }} - - {{ 'applications.main.bootVersions.' + app.bootVersion | translate }} - {{ app.uri }} diff --git a/ui/src/app/apps/apps.component.spec.ts b/ui/src/app/apps/apps.component.spec.ts index e593b2e61..3cd820b1b 100644 --- a/ui/src/app/apps/apps.component.spec.ts +++ b/ui/src/app/apps/apps.component.spec.ts @@ -80,7 +80,7 @@ describe('apps/apps.component.ts', () => { expect(actionBar).toBeTruthy(); expect(title.textContent).toContain('Applications'); expect(rows.length === 20).toBeTruthy(); - expect(cols.length === 6).toBeTruthy(); + expect(cols.length === 5).toBeTruthy(); done(); }); @@ -230,13 +230,13 @@ describe('apps/apps.component.ts', () => { sort: {by: 'version', reverse: true} }); // URI - cols[4].query(By.css('button')).nativeElement.click(); + cols[3].query(By.css('button')).nativeElement.click(); fixture.detectChanges(); expect(refresh).toHaveBeenCalledWith({ page: {from: 0, to: 19, size: 20, current: 1}, sort: {by: 'uri', reverse: false} }); - cols[4].query(By.css('button')).nativeElement.click(); + cols[3].query(By.css('button')).nativeElement.click(); fixture.detectChanges(); expect(refresh).toHaveBeenCalledWith({ page: {from: 0, to: 19, size: 20, current: 1}, diff --git a/ui/src/app/shared/api/app.service.spec.ts b/ui/src/app/shared/api/app.service.spec.ts index 8ae69e1d2..4c0b0c47d 100644 --- a/ui/src/app/shared/api/app.service.spec.ts +++ b/ui/src/app/shared/api/app.service.spec.ts @@ -110,7 +110,6 @@ describe('shared/api/app.service.ts', () => { uri: 'https://uri.foo.bar', metaDataUri: 'https://metaDataUri.foo.bar', type: ApplicationType.processor, - bootVersion: '3', force: true }); const httpUri = mockHttp.post.calls.mostRecent().args[0]; @@ -121,7 +120,6 @@ describe('shared/api/app.service.ts', () => { expect(headerArgs.get('Accept')).toEqual('application/json'); expect(httpParams.get('uri')).toEqual('https://uri.foo.bar'); expect(httpParams.get('metadata-uri')).toEqual('https://metaDataUri.foo.bar'); - expect(httpParams.get('bootVersion')).toEqual('3'); expect(httpParams.get('force')).toEqual('true'); }); diff --git a/ui/src/app/shared/api/app.service.ts b/ui/src/app/shared/api/app.service.ts index 6ee214801..114849898 100644 --- a/ui/src/app/shared/api/app.service.ts +++ b/ui/src/app/shared/api/app.service.ts @@ -108,10 +108,7 @@ export class AppService { } registerProp(prop: any): Observable { - let params = new HttpParams() - .append('uri', prop.uri) - .append('force', prop.force.toString()) - .append('bootVersion', prop.bootVersion); + let params = new HttpParams().append('uri', prop.uri).append('force', prop.force.toString()); if (prop.metaDataUri) { params = params.append('metadata-uri', prop.metaDataUri); } diff --git a/ui/src/app/shared/api/job.service.ts b/ui/src/app/shared/api/job.service.ts index 28482f35a..059428ed8 100644 --- a/ui/src/app/shared/api/job.service.ts +++ b/ui/src/app/shared/api/job.service.ts @@ -33,23 +33,21 @@ export class JobService { .pipe(map(JobExecutionPage.parse), catchError(ErrorUtils.catchError)); } - getExecution(executionId: string, schemaTarget: string): Observable { + getExecution(executionId: string): Observable { const headers = HttpUtils.getDefaultHttpHeaders(); - const params = new HttpParams({encoder: new DataflowEncoder()}).set('schemaTarget', schemaTarget); return this.httpClient - .get(UrlUtilities.calculateBaseApiUrl() + `jobs/executions/${executionId}`, {headers, params}) + .get(UrlUtilities.calculateBaseApiUrl() + `jobs/executions/${executionId}`, {headers}) .pipe(map(JobExecution.parse), catchError(ErrorUtils.catchError)); } restart(execution: JobExecution): Observable { const headers = HttpUtils.getDefaultHttpHeaders(); const initHttpParams = new HttpParams({encoder: new DataflowEncoder()}); - const params = initHttpParams.append('schemaTarget', execution.schemaTarget); return this.httpClient .put( UrlUtilities.calculateBaseApiUrl() + `jobs/executions/${execution.jobExecutionId}?restart=true`, {}, - {headers, params} + {headers} ) .pipe(catchError(ErrorUtils.catchError)); } @@ -57,42 +55,25 @@ export class JobService { stop(item: JobExecution): Observable { const headers = HttpUtils.getDefaultHttpHeaders(); const initHttpParams = new HttpParams({encoder: new DataflowEncoder()}); - const params = initHttpParams.append('schemaTarget', item.schemaTarget); return this.httpClient - .put( - UrlUtilities.calculateBaseApiUrl() + `jobs/executions/${item.jobExecutionId}?stop=true`, - {}, - {headers, params} - ) + .put(UrlUtilities.calculateBaseApiUrl() + `jobs/executions/${item.jobExecutionId}?stop=true`, {}, {headers}) .pipe(catchError(ErrorUtils.catchError)); } - getExecutionStep( - jobExecutionId: string, - stepId: string, - schemaTarget: string - ): Observable { + getExecutionStep(jobExecutionId: string, stepId: string): Observable { const headers = HttpUtils.getDefaultHttpHeaders(); - const params = new HttpParams({encoder: new DataflowEncoder()}).append('schemaTarget', schemaTarget); return this.httpClient .get(UrlUtilities.calculateBaseApiUrl() + `jobs/executions/${jobExecutionId}/steps/${stepId}`, { - headers, - params + headers }) .pipe(map(ExecutionStepResource.parse), catchError(ErrorUtils.catchError)); } - getExecutionStepProgress( - jobExecutionId: string, - stepId: string, - schemaTarget: string - ): Observable { + getExecutionStepProgress(jobExecutionId: string, stepId: string): Observable { const headers = HttpUtils.getDefaultHttpHeaders(); - const params = new HttpParams({encoder: new DataflowEncoder()}).append('schemaTarget', schemaTarget); return this.httpClient .get(UrlUtilities.calculateBaseApiUrl() + `jobs/executions/${jobExecutionId}/steps/${stepId}/progress`, { - headers, - params + headers }) .pipe(map(ExecutionStepProgress.parse), catchError(ErrorUtils.catchError)); } diff --git a/ui/src/app/shared/api/task.service.spec.ts b/ui/src/app/shared/api/task.service.spec.ts index b6f0960ca..8c2a7e04d 100644 --- a/ui/src/app/shared/api/task.service.spec.ts +++ b/ui/src/app/shared/api/task.service.spec.ts @@ -104,12 +104,12 @@ describe('shared/api/task.service.ts', () => { it('executionsClean', async () => { mockHttp.delete.and.returnValue(of(jsonData)); const taskExecutions = [ - TaskExecution.parse({executionId: 'foo1', schemaTarget: 'boot2'}), - TaskExecution.parse({executionId: 'foo2', parentExecutionId: 'foo1', schemaTarget: 'boot2'}), - TaskExecution.parse({executionId: 'foo3', parentExecutionId: 'foo1', schemaTarget: 'boot3'}), - TaskExecution.parse({executionId: 'bar1', schemaTarget: 'boot3'}), - TaskExecution.parse({executionId: 'bar2', parentExecutionId: 'bar1', schemaTarget: 'boot2'}), - TaskExecution.parse({executionId: 'bar3', parentExecutionId: 'bar1', schemaTarget: 'boot3'}) + TaskExecution.parse({executionId: 'foo1'}), + TaskExecution.parse({executionId: 'foo2', parentExecutionId: 'foo1'}), + TaskExecution.parse({executionId: 'foo3', parentExecutionId: 'foo1'}), + TaskExecution.parse({executionId: 'bar1'}), + TaskExecution.parse({executionId: 'bar2', parentExecutionId: 'bar1'}), + TaskExecution.parse({executionId: 'bar3', parentExecutionId: 'bar1'}) ]; await taskService.executionsClean(taskExecutions).toPromise(); const httpUri = mockHttp.delete.calls.all(); @@ -117,10 +117,8 @@ describe('shared/api/task.service.ts', () => { expect(httpUri).not.toEqual(null); expect(httpUri.length).not.toEqual(0); expect(httpUri.map(url => url.args[0])).toEqual([ - '/tasks/executions/foo2,bar2?action=CLEANUP,REMOVE_DATA&schemaTarget=boot2', - '/tasks/executions/foo3,bar3?action=CLEANUP,REMOVE_DATA&schemaTarget=boot3', - '/tasks/executions/foo1?action=CLEANUP,REMOVE_DATA&schemaTarget=boot2', - '/tasks/executions/bar1?action=CLEANUP,REMOVE_DATA&schemaTarget=boot3' + '/tasks/executions/foo2,foo3,bar2,bar3?action=CLEANUP,REMOVE_DATA', + '/tasks/executions/foo1,bar1?action=CLEANUP,REMOVE_DATA' ]); }); @@ -152,13 +150,12 @@ describe('shared/api/task.service.ts', () => { taskService.getExecutionLogs( TaskExecution.parse({ externalExecutionId: 'foo', - schemaTarget: 'boot3', arguments: ['--spring.cloud.data.flow.platformname=bar'] }) ); const httpUri = mockHttp.get.calls.mostRecent().args[0]; const headerArgs = mockHttp.get.calls.mostRecent().args[1].headers; - expect(httpUri).toEqual('/tasks/logs/foo?platformName=bar&schemaTarget=boot3'); + expect(httpUri).toEqual('/tasks/logs/foo?platformName=bar'); expect(headerArgs.get('Content-Type')).toEqual('application/json'); expect(headerArgs.get('Accept')).toEqual('application/json'); }); diff --git a/ui/src/app/shared/api/task.service.ts b/ui/src/app/shared/api/task.service.ts index 6239522e4..bc906e441 100644 --- a/ui/src/app/shared/api/task.service.ts +++ b/ui/src/app/shared/api/task.service.ts @@ -94,24 +94,17 @@ export class TaskService { executionStop(taskExecution: TaskExecution): Observable { const headers = HttpUtils.getDefaultHttpHeaders(); - const params = new HttpParams({encoder: new DataflowEncoder()}).append('schemaTarget', taskExecution?.schemaTarget); return this.httpClient - .post( - UrlUtilities.calculateBaseApiUrl() + `tasks/executions/${taskExecution.executionId}`, - {}, - {headers, params} - ) + .post(UrlUtilities.calculateBaseApiUrl() + `tasks/executions/${taskExecution.executionId}`, {}, {headers}) .pipe(catchError(ErrorUtils.catchError)); } executionClean(taskExecution: TaskExecution): Observable { const headers = HttpUtils.getDefaultHttpHeaders(); - const params = new HttpParams({encoder: new DataflowEncoder()}).append('schemaTarget', taskExecution.schemaTarget); const url = UrlUtilities.calculateBaseApiUrl() + `tasks/executions/${taskExecution.executionId}?action=REMOVE_DATA`; return this.httpClient .delete(url, { headers, - params, observe: 'response' }) .pipe(catchError(ErrorUtils.catchError)); @@ -134,39 +127,24 @@ export class TaskService { const taskExecutionsChildren = taskExecutions.filter(taskExecution => taskExecution.parentExecutionId); const taskExecutionsParents = taskExecutions.filter(taskExecution => !taskExecution.parentExecutionId); if (taskExecutionsChildren.length > 0) { - await this.executionsCleanBySchema(taskExecutionsChildren); + await this.executionsCleanGrouped(taskExecutionsChildren); } if (taskExecutionsParents.length > 0) { - await this.executionsCleanBySchema(taskExecutionsParents); + await this.executionsCleanGrouped(taskExecutionsParents); } return Promise.resolve(); } - private async executionsCleanBySchema(taskExecutions: TaskExecution[]): Promise { - const groupBySchemaTarget = taskExecutions.reduce((group, task) => { - const schemaTarget = task.schemaTarget; - group[schemaTarget] = group[schemaTarget] ?? []; - group[schemaTarget].push(task); - return group; - }, {}); - for (const schemaTarget in groupBySchemaTarget) { - if (schemaTarget) { - const group: TaskExecution[] = groupBySchemaTarget[schemaTarget]; - const ids = group.map(task => task.executionId); - if (ids.length > 0) { - await this.taskExecutionsCleanByIds(ids, schemaTarget).toPromise(); - } - } - } + private async executionsCleanGrouped(taskExecutions: TaskExecution[]): Promise { + const ids = taskExecutions.map(task => task.executionId); + await this.taskExecutionsCleanByIds(ids); return Promise.resolve(); } - taskExecutionsCleanByIds(ids: number[], schemaTarget: string): Observable { + taskExecutionsCleanByIds(ids: number[]): Observable { const headers = HttpUtils.getDefaultHttpHeaders(); const idStr = ids.join(','); - const url = - UrlUtilities.calculateBaseApiUrl() + - `tasks/executions/${idStr}?action=CLEANUP,REMOVE_DATA&schemaTarget=${schemaTarget}`; + const url = UrlUtilities.calculateBaseApiUrl() + `tasks/executions/${idStr}?action=CLEANUP,REMOVE_DATA`; return this.httpClient.delete(url, {headers, observe: 'response'}).pipe(catchError(ErrorUtils.catchError)); } @@ -232,19 +210,17 @@ export class TaskService { .pipe(map(TaskExecution.parse), catchError(ErrorUtils.catchError)); } - getExecutionById(executionId: number, schemaTarget: string): Observable { + getExecutionById(executionId: number): Observable { const headers = HttpUtils.getDefaultHttpHeaders(); - const params = new HttpParams({encoder: new DataflowEncoder()}).set('schemaTarget', schemaTarget); return this.httpClient .get(UrlUtilities.calculateBaseApiUrl() + `tasks/executions/${executionId ?? 0}`, { - headers: headers, - params: params + headers: headers }) .pipe(map(TaskExecution.parse), catchError(ErrorUtils.catchError)); } getExecution(taskExecution: TaskExecution): Observable { - return this.getExecutionById(taskExecution.executionId, taskExecution.schemaTarget); + return this.getExecutionById(taskExecution.executionId); } getExecutionLogs(taskExecution: TaskExecution): Observable { @@ -262,7 +238,7 @@ export class TaskService { taskExecution?._links && taskExecution?._links['tasks/logs'] !== undefined ? taskExecution?._links['tasks/logs'].href : UrlUtilities.calculateBaseApiUrl() + - `tasks/logs/${taskExecution.externalExecutionId}?platformName=${platformName}&schemaTarget=${taskExecution.schemaTarget}`; + `tasks/logs/${taskExecution.externalExecutionId}?platformName=${platformName}`; const params = new HttpParams({encoder: new DataflowEncoder()}); return this.httpClient .get( diff --git a/ui/src/app/shared/model/job.model.ts b/ui/src/app/shared/model/job.model.ts index 19b8c496d..d969bb0b3 100644 --- a/ui/src/app/shared/model/job.model.ts +++ b/ui/src/app/shared/model/job.model.ts @@ -185,7 +185,6 @@ export class JobExecution { public jobParametersString: string; public exitCode: string; public exitMessage: string; - public schemaTarget: string; public stepExecutions: ExecutionStep[]; public restartable: boolean; public abandonable: boolean; @@ -212,7 +211,6 @@ export class JobExecution { jobExecution.abandonable = input.abandonable; jobExecution.stoppable = input.stoppable; jobExecution.defined = input.defined; - jobExecution.schemaTarget = input.schemaTarget; jobExecution.jobParametersString = input.jobParametersString; if (get(input, 'jobExecution.stepExecutions')) { jobExecution.stepExecutions = input.jobExecution.stepExecutions.map(ExecutionStep.parse); @@ -243,7 +241,6 @@ export class JobExecution { jobExecution.abandonable = input.abandonable; jobExecution.stoppable = input.stoppable; jobExecution.defined = input.defined; - jobExecution.schemaTarget = input.schemaTarget; jobExecution.jobParametersString = input.jobParametersString; return jobExecution; } diff --git a/ui/src/app/shared/model/task-execution.model.ts b/ui/src/app/shared/model/task-execution.model.ts index d30232773..912bc0242 100644 --- a/ui/src/app/shared/model/task-execution.model.ts +++ b/ui/src/app/shared/model/task-execution.model.ts @@ -11,11 +11,9 @@ interface TaskExecutionLinks { export class LaunchResponse { executionId: number; - schemaTarget: string; static parse(input: any): LaunchResponse { const response = new LaunchResponse(); response.executionId = input?.executionId; - response.schemaTarget = input?.schemaTarget; return response; } } @@ -31,7 +29,6 @@ export class TaskExecution { arguments: string[]; jobExecutionIds: number[]; errorMessage: string; - schemaTarget: string; externalExecutionId: string; taskExecutionStatus: string; parentExecutionId: number; @@ -50,7 +47,6 @@ export class TaskExecution { execution.endTime = input?.endTime ? DateTime.fromISO(input.endTime) : null; execution.exitMessage = input?.exitMessage; execution.arguments = input?.arguments || []; - execution.schemaTarget = input?.schemaTarget || 'boot2'; execution.jobExecutionIds = input?.jobExecutionIds || []; execution.errorMessage = input?.errorMessage; execution.taskExecutionStatus = input?.taskExecutionStatus; @@ -60,7 +56,6 @@ export class TaskExecution { execution.appProperties = input?.appProperties; execution.deploymentProperties = input?.deploymentProperties; execution._links = input?._links; - execution.schemaTarget = input?.schemaTarget; return execution; } diff --git a/ui/src/app/tasks-jobs/executions/execution/execution.component.html b/ui/src/app/tasks-jobs/executions/execution/execution.component.html index cafc65538..c8d60ac75 100644 --- a/ui/src/app/tasks-jobs/executions/execution/execution.component.html +++ b/ui/src/app/tasks-jobs/executions/execution/execution.component.html @@ -54,10 +54,6 @@

{{ 'executions.main.executionId' | translate }}
{{ execution.executionId }}

-
-
{{ 'executions.main.schemaTarget' | translate }}
-
{{ execution.schemaTarget }}
-
{{ 'executions.main.arguments' | translate }}
@@ -87,9 +83,7 @@

{{ 'executions.main.jobExecutionIds' | translate }}

- {{ execution.executionId }} + {{ execution.executionId }} {{ execution.taskName }} - {{ execution.schemaTarget }} {{ execution.startTime | duration: execution.endTime }} {{ execution.startTime | datetime }} {{ execution.endTime | datetime }} diff --git a/ui/src/app/tasks-jobs/executions/executions.component.ts b/ui/src/app/tasks-jobs/executions/executions.component.ts index 709654596..d87e3ad3e 100644 --- a/ui/src/app/tasks-jobs/executions/executions.component.ts +++ b/ui/src/app/tasks-jobs/executions/executions.component.ts @@ -61,9 +61,7 @@ export class ExecutionsComponent extends DatagridComponent { } details(execution: TaskExecution): void { - this.router.navigateByUrl( - `tasks-jobs/task-executions/${execution.executionId}/schemaTarget/${execution.schemaTarget}` - ); + this.router.navigateByUrl(`tasks-jobs/task-executions/${execution.executionId}`); } taskDetails(execution: TaskExecution): void { diff --git a/ui/src/app/tasks-jobs/jobs/execution/execution.component.html b/ui/src/app/tasks-jobs/jobs/execution/execution.component.html index 67bf277ba..cf1204a29 100644 --- a/ui/src/app/tasks-jobs/jobs/execution/execution.component.html +++ b/ui/src/app/tasks-jobs/jobs/execution/execution.component.html @@ -50,18 +50,11 @@

{{ 'jobs.main.taskExecutionId' | translate }}
-
-
{{ 'jobs.main.schemaTarget' | translate }}
-
{{ execution.schemaTarget }}
-
{{ 'jobs.main.jobParameters' | translate }}
{{ execution.jobParametersString }}
@@ -182,10 +175,6 @@

{{ 'executions.main.executionId' | translate }}
{{ taskExecution.executionId }}

-
-
{{ 'executions.main.schemaTarget' | translate }}
-
{{ taskExecution.schemaTarget }}
-
{{ 'executions.main.arguments' | translate }}
@@ -208,9 +197,7 @@

{{ 'executions.main.jobExecutionIds' | translate }}
{{ jobExecutionId }} @@ -329,20 +316,14 @@

- {{ step.id }} + {{ + step.id + }} - {{ step.name }} + {{ + step.name + }} {{ step.readCount }} {{ step.writeCount }} diff --git a/ui/src/app/tasks-jobs/jobs/execution/execution.component.ts b/ui/src/app/tasks-jobs/jobs/execution/execution.component.ts index 77ce5098c..224111151 100644 --- a/ui/src/app/tasks-jobs/jobs/execution/execution.component.ts +++ b/ui/src/app/tasks-jobs/jobs/execution/execution.component.ts @@ -49,8 +49,7 @@ export class ExecutionComponent implements OnInit { mergeMap(val => { this.execution = new JobExecution(); this.execution.jobExecutionId = val.executionId; - this.execution.schemaTarget = val.schemaTarget; - return this.jobService.getExecution(val.executionId, val.schemaTarget); + return this.jobService.getExecution(val.executionId); }) ) .subscribe( @@ -70,7 +69,7 @@ export class ExecutionComponent implements OnInit { getTaskExecution(): void { this.loadingExecution = true; - this.taskService.getExecutionById(this.execution.taskExecutionId, this.execution.schemaTarget).subscribe( + this.taskService.getExecutionById(this.execution.taskExecutionId).subscribe( (taskExecution: TaskExecution) => { this.taskExecution = taskExecution; this.getTask(); @@ -161,9 +160,7 @@ export class ExecutionComponent implements OnInit { } navigateTaskExecution(): void { - this.router.navigateByUrl( - `/tasks-jobs/task-executions/${this.taskExecution.executionId}/schemaTarget/${this.taskExecution.schemaTarget}` - ); + this.router.navigateByUrl(`/tasks-jobs/task-executions/${this.taskExecution.executionId}`); } relaunch(): void { diff --git a/ui/src/app/tasks-jobs/jobs/jobs.component.html b/ui/src/app/tasks-jobs/jobs/jobs.component.html index d8e8874f7..39c346fb7 100644 --- a/ui/src/app/tasks-jobs/jobs/jobs.component.html +++ b/ui/src/app/tasks-jobs/jobs/jobs.component.html @@ -32,13 +32,6 @@

{{ 'jobs.main.title' | translate }}

{{ 'jobs.main.instanceId' | translate }} - - {{ 'jobs.main.schemaTarget' | translate }} - - {{ 'jobs.main.title' | translate }}

- {{ execution.jobExecutionId }} + {{ execution.jobExecutionId }} - {{ execution.name }} + {{ execution.name }} {{ execution.taskExecutionId }} {{ execution.jobInstanceId }} - {{ execution.schemaTarget }} {{ execution.startTime | datetime }} {{ execution.stepExecutionCount }}
{{ 'executions.main.executionId' | translate }}
{{ taskExecution.executionId }}
-
-
{{ 'jobs.main.schemaTarget' | translate }}
-
{{ taskExecution?.schemaTarget }}
-
{{ 'executions.main.arguments' | translate }}
@@ -313,9 +309,7 @@

{{ 'executions.main.jobExecutionIds' | translate }}
{{ jobExecutionId }} diff --git a/ui/src/app/tasks-jobs/jobs/step/step.component.ts b/ui/src/app/tasks-jobs/jobs/step/step.component.ts index 8518af1b0..8400ff94d 100644 --- a/ui/src/app/tasks-jobs/jobs/step/step.component.ts +++ b/ui/src/app/tasks-jobs/jobs/step/step.component.ts @@ -52,9 +52,9 @@ export class StepComponent implements OnInit { .pipe( mergeMap(params => forkJoin([ - this.jobService.getExecution(params.executionId, params.schemaTarget), - this.jobService.getExecutionStep(params.executionId, params.stepId, params.schemaTarget), - this.jobService.getExecutionStepProgress(params.executionId, params.stepId, params.schemaTarget) + this.jobService.getExecution(params.executionId), + this.jobService.getExecutionStep(params.executionId, params.stepId), + this.jobService.getExecutionStepProgress(params.executionId, params.stepId) ]).pipe( map(results => ({ execution: results[0], @@ -83,7 +83,7 @@ export class StepComponent implements OnInit { getTaskExecution(): void { this.loadingExecution = true; - this.taskService.getExecutionById(this.execution.taskExecutionId, this.execution.schemaTarget).subscribe( + this.taskService.getExecutionById(this.execution.taskExecutionId).subscribe( (taskExecution: TaskExecution) => { this.taskExecution = taskExecution; this.getTask(); @@ -151,9 +151,7 @@ export class StepComponent implements OnInit { } navigateTaskExecution(): void { - this.router.navigateByUrl( - `/tasks-jobs/task-executions/${this.taskExecution.executionId}/schemaTarget/${this.taskExecution.schemaTarget}` - ); + this.router.navigateByUrl(`/tasks-jobs/task-executions/${this.taskExecution.executionId}`); } relaunch(): void { diff --git a/ui/src/app/tasks-jobs/tasks-jobs-routing.module.ts b/ui/src/app/tasks-jobs/tasks-jobs-routing.module.ts index 697868741..ccbd7dde9 100644 --- a/ui/src/app/tasks-jobs/tasks-jobs-routing.module.ts +++ b/ui/src/app/tasks-jobs/tasks-jobs-routing.module.ts @@ -45,7 +45,7 @@ const routes: Routes = [ component: ExecutionsComponent }, { - path: 'task-executions/:executionId/schemaTarget/:schemaTarget', + path: 'task-executions/:executionId', component: ExecutionComponent }, { @@ -53,11 +53,11 @@ const routes: Routes = [ component: JobsComponent }, { - path: 'job-executions/:executionId/schemaTarget/:schemaTarget', + path: 'job-executions/:executionId', component: JobExecutionComponent }, { - path: 'job-executions/:executionId/:stepId/schemaTarget/:schemaTarget', + path: 'job-executions/:executionId/:stepId', component: StepComponent }, { diff --git a/ui/src/app/tasks-jobs/tasks/launch/launch.component.spec.ts b/ui/src/app/tasks-jobs/tasks/launch/launch.component.spec.ts index 6a3c481e8..1ad747c03 100644 --- a/ui/src/app/tasks-jobs/tasks/launch/launch.component.spec.ts +++ b/ui/src/app/tasks-jobs/tasks/launch/launch.component.spec.ts @@ -123,7 +123,7 @@ describe('streams/streams/deploy/deploy.component.ts', () => { fixture.detectChanges(); await fixture.whenStable(); expect(spy).toHaveBeenCalled(); - expect(navigate).toHaveBeenCalledWith(['tasks-jobs/task-executions/0/schemaTarget/boot2']); + expect(navigate).toHaveBeenCalledWith(['tasks-jobs/task-executions/0']); done(); }); }); diff --git a/ui/src/app/tasks-jobs/tasks/launch/launch.component.ts b/ui/src/app/tasks-jobs/tasks/launch/launch.component.ts index 32ca517c8..60c4ce171 100644 --- a/ui/src/app/tasks-jobs/tasks/launch/launch.component.ts +++ b/ui/src/app/tasks-jobs/tasks/launch/launch.component.ts @@ -202,11 +202,7 @@ export class LaunchComponent implements OnInit, OnDestroy { this.translate.instant('tasks.launch.main.message.successTitle'), this.translate.instant('tasks.launch.main.message.successContent', {name: this.task.name}) ); - this.router.navigate([ - `tasks-jobs/task-executions/${launchResponse.executionId ?? 0}/schemaTarget/${ - launchResponse.schemaTarget ?? 'boot2' - }` - ]); + this.router.navigate([`tasks-jobs/task-executions/${launchResponse.executionId ?? 0}`]); }, error => { this.isLaunching = false; diff --git a/ui/src/app/tasks-jobs/tasks/task/task.component.html b/ui/src/app/tasks-jobs/tasks/task/task.component.html index 4e6915800..895857328 100644 --- a/ui/src/app/tasks-jobs/tasks/task/task.component.html +++ b/ui/src/app/tasks-jobs/tasks/task/task.component.html @@ -101,12 +101,6 @@

{{ 'executions.main.executionId' | translate }}
{{ task.lastTaskExecution?.executionId }}

-
-
{{ 'executions.main.schemaTarget' | translate }}
-
- {{ task.lastTaskExecution.schemaTarget }} -
-
{{ 'executions.main.arguments' | translate }}
@@ -136,9 +130,7 @@

{{ 'executions.main.jobExecutionIds' | translate }}
{{ jobExecutionId }} @@ -247,12 +239,9 @@

- {{ execution.executionId }} + {{ + execution.executionId + }} {{ execution.startTime | datetime }} {{ execution.endTime | datetime }} diff --git a/ui/src/app/tasks-jobs/tasks/task/task.component.ts b/ui/src/app/tasks-jobs/tasks/task/task.component.ts index e06ffcbe6..b555961dc 100644 --- a/ui/src/app/tasks-jobs/tasks/task/task.component.ts +++ b/ui/src/app/tasks-jobs/tasks/task/task.component.ts @@ -179,9 +179,7 @@ export class TaskComponent implements OnInit { } navigateExecution(execution: TaskExecution): void { - this.router.navigateByUrl( - `tasks-jobs/task-executions/${execution.executionId}/schemaTarget/${execution.schemaTarget}` - ); + this.router.navigateByUrl(`tasks-jobs/task-executions/${execution.executionId}`); } destroy(): void { diff --git a/ui/src/app/tests/api/task.service.mock.ts b/ui/src/app/tests/api/task.service.mock.ts index b7ffd22c2..415e7fa11 100644 --- a/ui/src/app/tests/api/task.service.mock.ts +++ b/ui/src/app/tests/api/task.service.mock.ts @@ -78,7 +78,7 @@ export class TaskServiceMock { return of(GET_EXECUTION).pipe(delay(1), map(TaskExecution.parse)); } - getExecutionById(executionId: number, schemaTarget: string): Observable { + getExecutionById(executionId: number): Observable { return of(GET_EXECUTION).pipe(delay(1), map(TaskExecution.parse)); } From d2514c4314531f3f688b5482408aa5f9ced3f85f Mon Sep 17 00:00:00 2001 From: Damien Vitrac Date: Wed, 11 Dec 2024 08:44:19 +0100 Subject: [PATCH 2/2] Clean --- ui/src/app/about/info/info.component.html | 7 ------- .../apps/add/register/register.component.ts | 7 +------ ui/src/app/apps/app/app.component.html | 8 -------- ui/src/app/apps/app/app.component.ts | 2 +- ui/src/app/shared/api/app.service.spec.ts | 4 ++-- ui/src/app/shared/api/app.service.ts | 18 +++--------------- ui/src/app/shared/model/app.model.ts | 2 -- ui/src/app/shared/model/detailed-app.model.ts | 1 - ui/src/app/shared/store/about.reducer.ts | 1 - ui/src/app/shared/store/about.support.ts | 1 - ui/src/app/tests/api/app.service.mock.ts | 7 ------- ui/src/app/tests/data/about.ts | 2 -- 12 files changed, 7 insertions(+), 53 deletions(-) diff --git a/ui/src/app/about/info/info.component.html b/ui/src/app/about/info/info.component.html index 31b5ac72a..db6870ba6 100644 --- a/ui/src/app/about/info/info.component.html +++ b/ui/src/app/about/info/info.component.html @@ -136,10 +136,6 @@

{{ 'about.info.runtimeSkipperDeployer' | translate }}

{{ 'about.info.platformType' | translate }}: {{ about.runtimeEnvironment.appDeployer.platformType || 'N/A' }} -
  • - {{ 'about.info.springBootVersion' | translate }}: - {{ about.runtimeEnvironment.appDeployer.springBootVersion || 'N/A' }} -
  • {{ 'about.info.springVersion' | translate }}: {{ about.runtimeEnvironment.appDeployer.springVersion || 'N/A' }} @@ -203,9 +199,6 @@

    {{ 'about.info.runtimeTaskLauncher' | translate }}

  • {{ 'about.info.platformType' | translate }}: {{ item.platformType }}
  • -
  • - {{ 'about.info.springBootVersion' | translate }}: {{ item.springBootVersion }} -
  • {{ 'about.info.springVersion' | translate }}: {{ item.springVersion }}
  • diff --git a/ui/src/app/apps/add/register/register.component.ts b/ui/src/app/apps/add/register/register.component.ts index 9a4ba4f59..042b486b2 100644 --- a/ui/src/app/apps/add/register/register.component.ts +++ b/ui/src/app/apps/add/register/register.component.ts @@ -14,7 +14,6 @@ import {TranslateService} from '@ngx-translate/core'; export class RegisterComponent implements OnInit { forms: UntypedFormGroup[] = []; applicationTypes = ApplicationType; - bootVersions: Array; defaultBoot: string; submitted = false; isImporting = false; @@ -28,11 +27,7 @@ export class RegisterComponent implements OnInit { ) {} ngOnInit(): void { - this.appService.getBootVersions().subscribe((data: any) => { - this.bootVersions = data.versions; - this.defaultBoot = data.defaultSchemaVersion; - this.newForm(); - }); + this.newForm(); } register(): void { diff --git a/ui/src/app/apps/app/app.component.html b/ui/src/app/apps/app/app.component.html index 7a2f9c533..f7c223d18 100644 --- a/ui/src/app/apps/app/app.component.html +++ b/ui/src/app/apps/app/app.component.html @@ -68,14 +68,6 @@

    {{ detailedApp.version }}

    -
    -
    {{ 'applications.main.bootVersion' | translate }}
    -
    - {{ - 'applications.main.bootVersions.' + detailedApp.bootVersion | translate - }} -
    -
    {{ 'applications.main.uri' | translate }}
    {{ detailedApp.uri }}
    diff --git a/ui/src/app/apps/app/app.component.ts b/ui/src/app/apps/app/app.component.ts index b61b39310..d0ca60073 100644 --- a/ui/src/app/apps/app/app.component.ts +++ b/ui/src/app/apps/app/app.component.ts @@ -75,7 +75,7 @@ export class AppComponent implements OnInit { this.detailedApp.version = app.version; this.detailedApp.defaultVersion = app.defaultVersion; } - this.appsService.getApp(app.name, app.type, app.version, app.version).subscribe( + this.appsService.getApp(app.name, app.type, app.version).subscribe( (detailedApp: DetailedApp) => { this.tooManyProperties = detailedApp.options.length > 50; this.showAllProperties = !this.tooManyProperties; diff --git a/ui/src/app/shared/api/app.service.spec.ts b/ui/src/app/shared/api/app.service.spec.ts index 4c0b0c47d..acbedc9cd 100644 --- a/ui/src/app/shared/api/app.service.spec.ts +++ b/ui/src/app/shared/api/app.service.spec.ts @@ -39,10 +39,10 @@ describe('shared/api/app.service.ts', () => { it('getApp with spring boot version in parameter', () => { mockHttp.get.and.returnValue(of(jsonData)); - appService.getApp('foo', 'processor' as any as ApplicationType, '', '3'); + appService.getApp('foo', 'processor' as any as ApplicationType, ''); const httpUri = mockHttp.get.calls.mostRecent().args[0]; const headerArgs = mockHttp.get.calls.mostRecent().args[1].headers; - expect(httpUri).toEqual('/apps/processor/foo?bootVersion=3'); + expect(httpUri).toEqual('/apps/processor/foo'); expect(headerArgs.get('Content-Type')).toEqual('application/json'); expect(headerArgs.get('Accept')).toEqual('application/json'); }); diff --git a/ui/src/app/shared/api/app.service.ts b/ui/src/app/shared/api/app.service.ts index 114849898..79ba345a4 100644 --- a/ui/src/app/shared/api/app.service.ts +++ b/ui/src/app/shared/api/app.service.ts @@ -42,17 +42,11 @@ export class AppService { .pipe(map(AppPage.parse), catchError(ErrorUtils.catchError)); } - getApp( - name: string, - type: ApplicationType, - appVersion?: string, - bootVersion?: string - ): Observable { + getApp(name: string, type: ApplicationType, appVersion?: string): Observable { const headers = HttpUtils.getDefaultHttpHeaders(); - const bootVersionConfig = bootVersion ? `?bootVersion=${bootVersion}` : ``; - let url = UrlUtilities.calculateBaseApiUrl() + `apps/${type}/${name}${bootVersionConfig}`; + let url = UrlUtilities.calculateBaseApiUrl() + `apps/${type}/${name}`; if (appVersion) { - url = UrlUtilities.calculateBaseApiUrl() + `apps/${type}/${name}/${appVersion}${bootVersionConfig}`; + url = UrlUtilities.calculateBaseApiUrl() + `apps/${type}/${name}/${appVersion}`; } return this.httpClient.get(url, {headers}).pipe(map(DetailedApp.parse), catchError(ErrorUtils.catchError)); } @@ -65,12 +59,6 @@ export class AppService { ); } - getBootVersions(): Observable { - const headers = HttpUtils.getDefaultHttpHeaders(); - const url = UrlUtilities.calculateBaseApiUrl() + `schema/versions`; - return this.httpClient.get(url, {headers}).pipe(catchError(ErrorUtils.catchError)); - } - unregisterApp(app: App): Observable { const headers = HttpUtils.getDefaultHttpHeaders(); let url = UrlUtilities.calculateBaseApiUrl() + `apps/${app.type}/${app.name}`; diff --git a/ui/src/app/shared/model/app.model.ts b/ui/src/app/shared/model/app.model.ts index 8f2a110f3..7acc1834d 100644 --- a/ui/src/app/shared/model/app.model.ts +++ b/ui/src/app/shared/model/app.model.ts @@ -30,7 +30,6 @@ export class App { version: string; defaultVersion: boolean; versions: Array; - bootVersion?: string; public static parse(input: any): App { const app = new App(); @@ -40,7 +39,6 @@ export class App { app.version = input.version; app.defaultVersion = input.defaultVersion; app.versions = input.versions; - app.bootVersion = input.bootVersion; return app; } diff --git a/ui/src/app/shared/model/detailed-app.model.ts b/ui/src/app/shared/model/detailed-app.model.ts index 78f291658..29e67d29b 100644 --- a/ui/src/app/shared/model/detailed-app.model.ts +++ b/ui/src/app/shared/model/detailed-app.model.ts @@ -81,7 +81,6 @@ export class DetailedApp extends App { app.name = input.name; app.type = input.type as ApplicationType; app.uri = input.uri; - app.bootVersion = input.bootVersion; app.version = input.version; app.versions = input.versions; app.defaultVersion = input.defaultVersion; diff --git a/ui/src/app/shared/store/about.reducer.ts b/ui/src/app/shared/store/about.reducer.ts index 8fda14228..595245aa1 100644 --- a/ui/src/app/shared/store/about.reducer.ts +++ b/ui/src/app/shared/store/about.reducer.ts @@ -22,7 +22,6 @@ export interface RuntimeEnvironmentState { platformHostVersion: string; platformSpecificInfo: any; platformType: string; - springBootVersion: string; springVersion: string; } diff --git a/ui/src/app/shared/store/about.support.ts b/ui/src/app/shared/store/about.support.ts index 756c48e0d..69a6e6924 100644 --- a/ui/src/app/shared/store/about.support.ts +++ b/ui/src/app/shared/store/about.support.ts @@ -31,7 +31,6 @@ const parseRuntimeEnvironment = (input: any): RuntimeEnvironmentState => ({ platformHostVersion: input.platformHostVersion, platformSpecificInfo: parsePlatformSpecificInfo(input.platformSpecificInfo), platformType: input.platformType, - springBootVersion: input.springBootVersion, springVersion: input.springVersion }); diff --git a/ui/src/app/tests/api/app.service.mock.ts b/ui/src/app/tests/api/app.service.mock.ts index c1f64f9fd..464262243 100644 --- a/ui/src/app/tests/api/app.service.mock.ts +++ b/ui/src/app/tests/api/app.service.mock.ts @@ -26,13 +26,6 @@ export class AppServiceMock { return of(GET_APP).pipe(delay(1), map(DetailedApp.parse), catchError(ErrorUtils.catchError)); } - getBootVersions(): Observable { - return of({ - defaultSchemaVersion: '2', - versions: ['2', '3'] - }); - } - getAppVersions(name: string, type: ApplicationType): Observable { return of(GET_APP_VERSIONS).pipe( map(AppPage.parse), diff --git a/ui/src/app/tests/data/about.ts b/ui/src/app/tests/data/about.ts index b48ae0e62..49dab1d0e 100644 --- a/ui/src/app/tests/data/about.ts +++ b/ui/src/app/tests/data/about.ts @@ -28,7 +28,6 @@ export const LOAD = { platformHostVersion: '', platformSpecificInfo: {default: 'local'}, platformType: 'Skipper Managed', - springBootVersion: '2.3.2.RELEASE', springVersion: '5.2.8.RELEASE' }, taskLaunchers: [ @@ -42,7 +41,6 @@ export const LOAD = { platformHostVersion: '4.19.76-linuxkit', platformSpecificInfo: {}, platformType: 'Local', - springBootVersion: '2.3.2.RELEASE', springVersion: '5.2.8.RELEASE' } ]