public void documentGetApplicationPermission()

in component-test/src/main/java/IdentityApiDocumentation.java [728:764]


  public void documentGetApplicationPermission ( ) throws InterruptedException {

    try (final AutoUserContext ignored
                 = tenantApplicationSecurityEnvironment.createAutoSeshatContext()) {

      final String appIdentifier = "testApp" + RandomStringUtils.randomNumeric(3) + "-v1";

      final RsaKeyPairFactory.KeyPairHolder keyPair = RsaKeyPairFactory.createKeyPair();

      final String appTimeStamp = keyPair.getTimestamp();

      final Signature signature = new Signature(keyPair.getPublicKeyMod(), keyPair.getPublicKeyExp());

      getTestSubject().setApplicationSignature(appIdentifier, appTimeStamp, signature);
      this.eventRecorder.wait(EventConstants.OPERATION_PUT_APPLICATION_SIGNATURE, new ApplicationSignatureEvent(appIdentifier, keyPair.getTimestamp()));

      final Permission newPermission = new Permission(PermittableGroupIds.IDENTITY_MANAGEMENT, Sets.newHashSet(AllowedOperation.CHANGE));

      createApplicationPermission(appIdentifier, newPermission);

      Gson serializer = new Gson();
      try {
        this.mockMvc.perform(get("/applications/" + appIdentifier + "/permissions/" + newPermission.getPermittableEndpointGroupIdentifier())
                .accept(MediaType.ALL_VALUE)
                .contentType(MediaType.APPLICATION_JSON_VALUE))
                .andExpect(status().isOk())
                .andDo(document("document-get-application-permission", preprocessResponse(prettyPrint()),
                        responseFields(
                                fieldWithPath("permittableEndpointGroupIdentifier").description("permittable group endpoint identifier"),
                                fieldWithPath("allowedOperations").type("Set<AllowedOperation>").description("Set of Allowed Operations")
                        )
                ));
      } catch (Exception e) {
        e.printStackTrace();
      }
    }
  }