From 107e96e91a80ccbe96b971b358cb6ad524ef8fcb Mon Sep 17 00:00:00 2001 From: Alex Nikonov Date: Thu, 22 Aug 2024 15:55:35 +0200 Subject: [PATCH] =?UTF-8?q?fix:=20show=20revision=20in=20the=20exception?= =?UTF-8?q?=20message=20if=20it=20was=20provided=20as=20a=20p=E2=80=A6=20(?= =?UTF-8?q?#128)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * fix: show revision in the exception message if it was provided as a parameter for getting an entity * fix: by reverting changes done to maven-build.yml for triggering --------- Co-authored-by: Adam Ruberti --- .github/workflows/maven-build.yml | 4 +--- .../generic/service/PolarionService.java | 12 ++++++---- .../generic/service/PolarionServiceTest.java | 24 +++++++++++++++---- 3 files changed, 29 insertions(+), 11 deletions(-) diff --git a/.github/workflows/maven-build.yml b/.github/workflows/maven-build.yml index aea7e63..a905e98 100644 --- a/.github/workflows/maven-build.yml +++ b/.github/workflows/maven-build.yml @@ -2,9 +2,7 @@ name: maven-build on: push: - branches: [main] - pull_request: - types: [opened, synchronize, reopened] + branches: ['**/**'] jobs: build: runs-on: ubuntu-latest diff --git a/app/src/main/java/ch/sbb/polarion/extension/generic/service/PolarionService.java b/app/src/main/java/ch/sbb/polarion/extension/generic/service/PolarionService.java index 75d58a5..30e9091 100644 --- a/app/src/main/java/ch/sbb/polarion/extension/generic/service/PolarionService.java +++ b/app/src/main/java/ch/sbb/polarion/extension/generic/service/PolarionService.java @@ -99,7 +99,7 @@ public IProject getProject(@NotNull String projectId, @Nullable String revision) //Note: it seems that there is no way to get project for already deleted project (unlike workitems/modules & collections) //so method below will throw exception in this case - return getResolvableObjectOrThrow(projectService.getProject(projectId), revision, String.format("Project '%s' not found", projectId)); + return getResolvableObjectOrThrow(projectService.getProject(projectId), revision, String.format("Project '%s'%s not found", projectId, getRevisionMessagePart(revision))); } @NotNull @@ -120,7 +120,7 @@ public IWorkItem getWorkItem(@NotNull String projectId, @NotNull String workItem throw new IllegalArgumentException("Parameter 'workItemId' should be provided"); } - return getResolvableObjectOrThrow(trackerProject.getWorkItem(workItemId), revision, String.format("WorkItem '%s' not found in project '%s'", workItemId, projectId)); + return getResolvableObjectOrThrow(trackerProject.getWorkItem(workItemId), revision, String.format("WorkItem '%s'%s not found in project '%s'", workItemId, getRevisionMessagePart(revision), projectId)); } @NotNull @@ -139,7 +139,7 @@ public IModule getModule(@NotNull String projectId, @NotNull String spaceId, @No } ILocation location = Location.getLocation(spaceId + "/" + documentName); - return getResolvableObjectOrThrow(getModule(project, location), revision, String.format("Document '%s' not found in space '%s' of project '%s'", documentName, spaceId, projectId)); + return getResolvableObjectOrThrow(getModule(project, location), revision, String.format("Document '%s'%s not found in space '%s' of project '%s'", documentName, getRevisionMessagePart(revision), spaceId, projectId)); } @NotNull @@ -166,7 +166,7 @@ public IBaselineCollection getCollection(@NotNull String projectId, @NotNull Str .getOldApi() ) ); - return getResolvableObjectOrThrow(collection, revision, String.format("Collection with id '%s' not found in project '%s'", collectionId, projectId)); + return getResolvableObjectOrThrow(collection, revision, String.format("Collection with id '%s'%s not found in project '%s'", collectionId, getRevisionMessagePart(revision), projectId)); } public T getResolvableObjectOrThrow(@NotNull IPObject object, @Nullable String revision, @NotNull String notFoundMessage) { @@ -293,4 +293,8 @@ public IRepositoryConnection getConnection(@NotNull ILocation location) { public IRepositoryReadOnlyConnection getReadOnlyConnection(@NotNull ILocation location) { return repositoryService.getReadOnlyConnection(location); } + + private String getRevisionMessagePart(String revision) { + return StringUtils.isEmpty(revision) ? "" : " (rev. %s)".formatted(revision); + } } \ No newline at end of file diff --git a/app/src/test/java/ch/sbb/polarion/extension/generic/service/PolarionServiceTest.java b/app/src/test/java/ch/sbb/polarion/extension/generic/service/PolarionServiceTest.java index 85b73b2..8832d06 100644 --- a/app/src/test/java/ch/sbb/polarion/extension/generic/service/PolarionServiceTest.java +++ b/app/src/test/java/ch/sbb/polarion/extension/generic/service/PolarionServiceTest.java @@ -87,7 +87,11 @@ void init() { void testGetNotExistentProject() { mockProject(Boolean.FALSE); - assertThrows(ObjectNotFoundException.class, () -> polarionService.getProject(PROJECT_ID, null)); + ObjectNotFoundException exception = assertThrows(ObjectNotFoundException.class, () -> polarionService.getProject(PROJECT_ID, null)); + assertEquals("Project 'project_id' not found", exception.getMessage()); + + exception = assertThrows(ObjectNotFoundException.class, () -> polarionService.getProject(PROJECT_ID, "123")); + assertEquals("Project 'project_id' (rev. 123) not found", exception.getMessage()); } @Test @@ -95,7 +99,11 @@ void testGetNotExistentWorkItem() { IProject project = mockProject(Boolean.TRUE); mockWorkItem(project, Boolean.FALSE); - assertThrows(ObjectNotFoundException.class, () -> polarionService.getWorkItem(PROJECT_ID, WI_ID)); + ObjectNotFoundException exception = assertThrows(ObjectNotFoundException.class, () -> polarionService.getWorkItem(PROJECT_ID, WI_ID)); + assertEquals("WorkItem 'wi_id' not found in project 'project_id'", exception.getMessage()); + + exception = assertThrows(ObjectNotFoundException.class, () -> polarionService.getWorkItem(PROJECT_ID, WI_ID, "123")); + assertEquals("WorkItem 'wi_id' (rev. 123) not found in project 'project_id'", exception.getMessage()); } @Test @@ -103,7 +111,11 @@ void testGetNotExistentModule() { IProject project = mockProject(Boolean.TRUE); mockModule(project, Boolean.FALSE); - assertThrows(ObjectNotFoundException.class, () -> polarionService.getModule(PROJECT_ID, SPACE_ID, DOCUMENT_NAME)); + ObjectNotFoundException exception = assertThrows(ObjectNotFoundException.class, () -> polarionService.getModule(PROJECT_ID, SPACE_ID, DOCUMENT_NAME)); + assertEquals("Document 'document_name' not found in space 'space_id' of project 'project_id'", exception.getMessage()); + + exception = assertThrows(ObjectNotFoundException.class, () -> polarionService.getModule(PROJECT_ID, SPACE_ID, DOCUMENT_NAME, "123")); + assertEquals("Document 'document_name' (rev. 123) not found in space 'space_id' of project 'project_id'", exception.getMessage()); } @Test @@ -113,7 +125,11 @@ void testGetNotExistentCollection() { IBaselineCollection collection = mockCollection(Boolean.FALSE); transactionalExecutorMockedStatic.when(() -> TransactionalExecutor.executeSafelyInReadOnlyTransaction(any())).thenReturn(collection); - assertThrows(ObjectNotFoundException.class, () -> polarionService.getCollection(PROJECT_ID, COLLECTION_ID)); + ObjectNotFoundException exception = assertThrows(ObjectNotFoundException.class, () -> polarionService.getCollection(PROJECT_ID, COLLECTION_ID)); + assertEquals("Collection with id '1' not found in project 'project_id'", exception.getMessage()); + + exception = assertThrows(ObjectNotFoundException.class, () -> polarionService.getCollection(PROJECT_ID, COLLECTION_ID, "123")); + assertEquals("Collection with id '1' (rev. 123) not found in project 'project_id'", exception.getMessage()); } }