Search in sources :

Example 51 with ProcessApi

use of com.walmartlabs.concord.client.ProcessApi in project concord by walmartlabs.

the class SuspendIT method testSuspendForCompletion.

@Test
public void testSuspendForCompletion() throws Exception {
    // ---
    byte[] payload = archive(SuspendIT.class.getResource("suspendForCompletion").toURI());
    ProcessApi processApi = new ProcessApi(getApiClient());
    StartProcessResponse parentSpr = start(payload);
    // ---
    ProcessEntry p = waitForStatus(processApi, parentSpr.getInstanceId(), ProcessEntry.StatusEnum.SUSPENDED);
    List<UUID> childrenIds = p.getChildrenIds();
    assertEquals(2, childrenIds.size());
    for (UUID childId : childrenIds) {
        waitForCompletion(processApi, childId);
    }
    ProcessEntry pir = waitForCompletion(processApi, parentSpr.getInstanceId());
    byte[] ab = getLog(pir.getLogFileName());
    assertLog(".*process is resumed.*", ab);
}
Also used : ProcessApi(com.walmartlabs.concord.client.ProcessApi) ProcessEntry(com.walmartlabs.concord.client.ProcessEntry) UUID(java.util.UUID) StartProcessResponse(com.walmartlabs.concord.client.StartProcessResponse) Test(org.junit.jupiter.api.Test)

Example 52 with ProcessApi

use of com.walmartlabs.concord.client.ProcessApi in project concord by walmartlabs.

the class SuspendIT method testSuspendForForkedProcess.

@Test
public void testSuspendForForkedProcess() throws Exception {
    // ---
    byte[] payload = archive(SuspendIT.class.getResource("suspendForForkedProcesses").toURI());
    ProcessApi processApi = new ProcessApi(getApiClient());
    StartProcessResponse parentSpr = start(payload);
    // ---
    ProcessEntry p = waitForStatus(processApi, parentSpr.getInstanceId(), ProcessEntry.StatusEnum.SUSPENDED);
    List<UUID> childrenIds = p.getChildrenIds();
    assertEquals(3, childrenIds.size());
    for (UUID childId : childrenIds) {
        waitForCompletion(processApi, childId);
    }
    ProcessEntry pir = waitForCompletion(processApi, parentSpr.getInstanceId());
    byte[] ab = getLog(pir.getLogFileName());
    assertLog(".*task completed.*", ab);
}
Also used : ProcessApi(com.walmartlabs.concord.client.ProcessApi) ProcessEntry(com.walmartlabs.concord.client.ProcessEntry) UUID(java.util.UUID) StartProcessResponse(com.walmartlabs.concord.client.StartProcessResponse) Test(org.junit.jupiter.api.Test)

Example 53 with ProcessApi

use of com.walmartlabs.concord.client.ProcessApi in project concord by walmartlabs.

the class TaskRetryIT method testAnsibleRetryWithExpression.

@Test
public void testAnsibleRetryWithExpression() throws Exception {
    URI uri = ProcessIT.class.getResource("taskRetryWithExpression").toURI();
    byte[] payload = archive(uri, ITConstants.DEPENDENCIES_DIR);
    // start the process
    ProcessApi processApi = new ProcessApi(getApiClient());
    Map<String, Object> input = new HashMap<>();
    input.put("archive", payload);
    input.put("arguments.retryCount", "1");
    input.put("arguments.retryDelay", "2");
    StartProcessResponse spr = start(input);
    // wait for completion
    ProcessEntry pir = waitForCompletion(processApi, spr.getInstanceId());
    assertEquals(ProcessEntry.StatusEnum.FINISHED, pir.getStatus());
    // check logs
    byte[] ab = getLog(pir.getLogFileName());
    assertLog(".*msg\": \"Hi retry!\".*", ab);
}
Also used : ProcessApi(com.walmartlabs.concord.client.ProcessApi) HashMap(java.util.HashMap) ProcessEntry(com.walmartlabs.concord.client.ProcessEntry) URI(java.net.URI) StartProcessResponse(com.walmartlabs.concord.client.StartProcessResponse) Test(org.junit.jupiter.api.Test)

Example 54 with ProcessApi

use of com.walmartlabs.concord.client.ProcessApi in project concord by walmartlabs.

the class TaskRetryIT method testAnsibleRetry.

@Test
public void testAnsibleRetry() throws Exception {
    URI uri = ProcessIT.class.getResource("taskRetry").toURI();
    byte[] payload = archive(uri, ITConstants.DEPENDENCIES_DIR);
    // start the process
    ProcessApi processApi = new ProcessApi(getApiClient());
    StartProcessResponse spr = start(payload);
    // wait for completion
    ProcessEntry pir = waitForCompletion(processApi, spr.getInstanceId());
    assertEquals(ProcessEntry.StatusEnum.FINISHED, pir.getStatus());
    // check logs
    byte[] ab = getLog(pir.getLogFileName());
    assertLog(".*msg\": \"Hi retry!\".*", ab);
}
Also used : ProcessApi(com.walmartlabs.concord.client.ProcessApi) ProcessEntry(com.walmartlabs.concord.client.ProcessEntry) URI(java.net.URI) StartProcessResponse(com.walmartlabs.concord.client.StartProcessResponse) Test(org.junit.jupiter.api.Test)

Example 55 with ProcessApi

use of com.walmartlabs.concord.client.ProcessApi in project concord by walmartlabs.

the class ThrowExceptionTaskIT method testThrowExceptionMessage.

@Test
public void testThrowExceptionMessage() throws Exception {
    URI uri = ThrowExceptionTaskIT.class.getResource("throwExceptionMessage").toURI();
    byte[] payload = archive(uri);
    // start the process
    ProcessApi processApi = new ProcessApi(getApiClient());
    StartProcessResponse spr = start(payload);
    // wait for completion
    ProcessEntry pir = waitForCompletion(processApi, spr.getInstanceId());
    assertEquals(ProcessEntry.StatusEnum.FAILED, pir.getStatus());
    // check logs
    byte[] ab = getLog(pir.getLogFileName());
    assertLog(".*Kaboom!! Error occurred.*", 2, ab);
}
Also used : ProcessApi(com.walmartlabs.concord.client.ProcessApi) ProcessEntry(com.walmartlabs.concord.client.ProcessEntry) URI(java.net.URI) StartProcessResponse(com.walmartlabs.concord.client.StartProcessResponse) Test(org.junit.jupiter.api.Test)

Aggregations

ProcessApi (com.walmartlabs.concord.client.ProcessApi)58 ProcessEntry (com.walmartlabs.concord.client.ProcessEntry)55 StartProcessResponse (com.walmartlabs.concord.client.StartProcessResponse)54 Test (org.junit.jupiter.api.Test)54 HashMap (java.util.HashMap)34 URI (java.net.URI)23 File (java.io.File)4 Path (java.nio.file.Path)4 ByteArrayOutputStream (java.io.ByteArrayOutputStream)2 UUID (java.util.UUID)2 ZipArchiveOutputStream (org.apache.commons.compress.archivers.zip.ZipArchiveOutputStream)2 ConcordProcess (ca.ibodrov.concord.testcontainers.ConcordProcess)1 Payload (ca.ibodrov.concord.testcontainers.Payload)1 ObjectMapper (com.fasterxml.jackson.databind.ObjectMapper)1 ApiClient (com.walmartlabs.concord.ApiClient)1 ApiException (com.walmartlabs.concord.ApiException)1 FormListEntry (com.walmartlabs.concord.client.FormListEntry)1 FormSubmitResponse (com.walmartlabs.concord.client.FormSubmitResponse)1 ITUtils.randomString (com.walmartlabs.concord.it.common.ITUtils.randomString)1 PosixFilePermission (java.nio.file.attribute.PosixFilePermission)1