@Override @SneakyThrows // TODO add checked exception handling public ManagerOutput handleRequest(ManagerInput input, Context context) { log.debug("Manager request: {}", input); ListEnvironmentsResponse r = data.listEnvironments( ListEnvironmentsRequest.builder().cluster(input.getCluster()).build()); List<EnvironmentId> environments = r.getEnvironmentIds(); ClusterSnapshot state = ecs.snapshotState(input.getCluster().getClusterName()); Stream<CompletableFuture<SchedulerOutput>> pendingRequests = environments .stream() .map(environmentId -> scheduler.callAsync(new SchedulerInput(state, environmentId))); List<SchedulerOutput> outputs = pendingRequests.collect(CompletableFutures.joinList()).join(); return new ManagerOutput(input.getCluster(), outputs); } }
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); } } }
@Before public void setup() { request = ListEnvironmentsRequest.builder().cluster(clusterWrapper).build(); when(apiModelMapper.toModelCluster(clusterWrapper)).thenReturn(cluster); when(environment.getEnvironmentId()).thenReturn(environmentId); when(apiModelMapper.toWrapperEnvironmentId(environmentId)).thenReturn(environmentIdWrapper); }
@Test public void testToListEnvironmentsRequest() { final ApiGatewayRequestContext context = new ApiGatewayRequestContext(); context.setAccountId(ACCOUNT_ID); final ListEnvironmentsRequest request = mapper.toListEnvironmentsRequest(context, CLUSTER, ENVIRONMENT_NAME_PREFIX); assertThat(request.getCluster().getAccountId()).isEqualTo(ACCOUNT_ID); assertThat(request.getCluster().getClusterName()).isEqualTo(CLUSTER); assertThat(request.getEnvironmentNamePrefix()).isEqualTo(ENVIRONMENT_NAME_PREFIX); }
public ListEnvironmentsRequestBuilder listEnvironmentsRequest() { return ListEnvironmentsRequest.builder() .cluster(cluster().build()) .environmentNamePrefix(environmentName); }
@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)))); } }
@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(); }