public ListEnvironmentsResponse listEnvironments(@NonNull final ListEnvironmentsRequest request) throws InternalServiceException { final Cluster cluster = apiModelMapper.toModelCluster(request.getCluster()); try { final List<Environment> environments = environmentRepository.listEnvironments(cluster, request.getEnvironmentNamePrefix()); return ListEnvironmentsResponse.builder() .environmentIds( environments .stream() .map(e -> apiModelMapper.toWrapperEnvironmentId(e.getEnvironmentId())) .collect(Collectors.toList())) .build(); } catch (final InternalServiceException e) { log.error(e.getMessage(), e); throw e; } catch (final Exception e) { log.error(e.getMessage(), e); throw new InternalServiceException(e.getMessage(), e); } } }
@Test @SuppressWarnings("unchecked") public void invokesSchedulerForAllEnvironments() throws Exception { when(dataService.listEnvironments(ListEnvironmentsRequest.builder().cluster(CLUSTER).build())) .thenReturn( ListEnvironmentsResponse.builder() .environmentIds(Arrays.asList(FIRST_ENVIRONMENT_ID, SECOND_ENVIRONMENT_ID)) .build()); when(scheduler.callAsync(schedulerArgument.capture())) .thenReturn( CompletableFuture.completedFuture( new SchedulerOutput(CLUSTER_NAME, FIRST_ENVIRONMENT_ID, 1, 1))); ManagerHandler handler = new ManagerHandler(dataService, ecs, scheduler); handler.handleRequest(new ManagerInput(CLUSTER), null); assertThat( schedulerArgument.getAllValues(), contains( hasProperty("environmentId", is(FIRST_ENVIRONMENT_ID)), hasProperty("environmentId", is(SECOND_ENVIRONMENT_ID)))); } }
@Test public void testFromDataServiceResponse() { final ListEnvironmentsResponse dsResponse = ListEnvironmentsResponse.builder() .environmentIds( Collections.singletonList( EnvironmentId.builder() .accountId(ACCOUNT_ID) .cluster(CLUSTER) .environmentName(ENVIRONMENT_NAME) .build())) .build(); final ListEnvironments.ListEnvironmentsResponse response = mapper.fromDataServiceResponse(dsResponse); assertThat(response.getEnvironmentNames().size()).isEqualTo(1); assertThat(response.getEnvironmentNames().get(0)).isEqualTo(ENVIRONMENT_NAME); assertThat(response.getNextToken()).isNull(); } }
@Bean public DataService dataService() throws Exception { return when(mock(DataService.class) .listEnvironments( ListEnvironmentsRequest.builder() .cluster( Cluster.builder().accountId(ACCOUNT_ID).clusterName(CLUSTER_NAME).build()) .build())) .thenReturn( ListEnvironmentsResponse.builder() .environmentIds( Collections.singletonList( EnvironmentId.builder() .accountId(ACCOUNT_ID) .cluster(CLUSTER_NAME) .environmentName(ENVIRONMENT_NAME) .build())) .build()) .getMock(); }
@Override public ListEnvironmentsResponse listEnvironments(ListEnvironmentsRequest request) { return ListEnvironmentsResponse.builder() .environmentIds( Collections.singletonList( EnvironmentId.builder() .accountId(accountId) .cluster(clusterName) .environmentName(environmentName) .build())) .build(); }