/* * Copyright 2013-2017 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.cloudfoundry.client.v2; import org.cloudfoundry.AbstractIntegrationTest; import org.cloudfoundry.client.CloudFoundryClient; import org.cloudfoundry.client.v2.jobs.GetJobRequest; import org.cloudfoundry.client.v2.organizations.CreateOrganizationRequest; import org.cloudfoundry.client.v2.organizations.DeleteOrganizationRequest; import org.cloudfoundry.util.DelayUtils; import org.cloudfoundry.util.ResourceUtils; import org.junit.Test; import org.springframework.beans.factory.annotation.Autowired; import reactor.core.publisher.Mono; import reactor.test.StepVerifier; import java.time.Duration; import java.util.concurrent.TimeoutException; import static org.cloudfoundry.util.tuple.TupleUtils.predicate; public final class JobsTest extends AbstractIntegrationTest { @Autowired private CloudFoundryClient cloudFoundryClient; @Test public void getJob() throws TimeoutException, InterruptedException { String organizationName = this.nameFactory.getOrganizationName(); this.cloudFoundryClient.organizations() .create(CreateOrganizationRequest.builder() .name(organizationName) .build()) .map(ResourceUtils::getId) .then(organizationId -> this.cloudFoundryClient.organizations() .delete(DeleteOrganizationRequest.builder() .organizationId(organizationId) .async(true) .build()) .map(ResourceUtils::getId)) .then(jobId -> this.cloudFoundryClient.jobs() .get(GetJobRequest.builder() .jobId(jobId) .build()) .map(ResourceUtils::getId) .and(Mono.just(jobId))) .filter(predicate((getId, deleteId) -> !"0".equals(getId))) .repeatWhenEmpty(5, DelayUtils.instant()) .as(StepVerifier::create) .consumeNextWith(tupleEquality()) .expectComplete() .verify(Duration.ofMinutes(5)); } }