Skip to content

Commit

Permalink
Merge pull request #5589 from jay-hodgson/SWC-7194
Browse files Browse the repository at this point in the history
  • Loading branch information
jay-hodgson authored Nov 25, 2024
2 parents 3650c8c + ecac17c commit 7fc9048
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 31 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -352,10 +352,7 @@ public void onError(Throwable caught) {
headerWidget.configure();
if (caught instanceof NotFoundException) {
show404();
} else if (
caught instanceof ForbiddenException &&
authenticationController.isLoggedIn()
) {
} else if (caught instanceof ForbiddenException) {
show403();
} else {
view.clear();
Expand All @@ -364,35 +361,35 @@ public void onError(Throwable caught) {
}

public void show403() {
if (entityId != null) {
synAlert.show403(entityId, versionNumber);
}
synAlert.show403(entityId, versionNumber);
view.setLoadingVisible(false);
view.setEntityPageTopVisible(false);
// also add the open team invitations widget (accepting may gain access to this project)
openTeamInvitesWidget.configure(
new Callback() {
@Override
public void invoke() {
// when team is updated, refresh to see if we can now access
refresh();
}
},
new CallbackP<List<OpenUserInvitationBundle>>() {
@Override
public void invoke(List<OpenUserInvitationBundle> invites) {
// if there are any, then also add the title text to the panel
if (invites != null && invites.size() > 0) {
view.setAccessDependentMessageVisible(true);
if (authenticationController.isLoggedIn()) {
// also add the open team invitations widget (accepting may gain access to this project)
openTeamInvitesWidget.configure(
new Callback() {
@Override
public void invoke() {
// when team is updated, refresh to see if we can now access
refresh();
}
},
new CallbackP<List<OpenUserInvitationBundle>>() {
@Override
public void invoke(List<OpenUserInvitationBundle> invites) {
// if there are any, then also add the title text to the panel
if (invites != null && invites.size() > 0) {
view.setAccessDependentMessageVisible(true);
}
}
}
}
);
view.setOpenTeamInvitesVisible(true);
);
view.setOpenTeamInvitesVisible(true);
}
}

public void show404() {
synAlert.show404();
synAlert.show404(entityId, versionNumber);
view.setLoadingVisible(false);
view.setEntityPageTopVisible(false);
view.setOpenTeamInvitesVisible(false);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -41,10 +41,6 @@ public void clear() {
entityVersion = null;
}

public void show403() {
show403(null, null);
}

public void show403(String entityId, Long entityVersion) {
clear();
this.entityId = entityId;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -346,14 +346,25 @@ public void testClear() {
}

@Test
public void testShow403() {
public void testShow403LoggedIn() {
when(mockAuthenticationController.isLoggedIn()).thenReturn(true);
entityPresenter.setEntityId("123");
entityPresenter.show403();
verify(mockSynAlert).show403(any(), any());
verify(mockView).setEntityPageTopVisible(false);
verify(mockView).setOpenTeamInvitesVisible(true);
}

@Test
public void testShow403Anonymous() {
when(mockAuthenticationController.isLoggedIn()).thenReturn(false);
entityPresenter.setEntityId("123");
entityPresenter.show403();
verify(mockSynAlert).show403(any(), any());
verify(mockView).setEntityPageTopVisible(false);
verify(mockView, never()).setOpenTeamInvitesVisible(anyBoolean());
}

@Test
public void testEntityUpdatedHandlerWithoutId() {
QueryKey mockQueryKey = mock(QueryKey.class);
Expand Down

0 comments on commit 7fc9048

Please sign in to comment.