Search in sources :

Example 36 with ProcessEntry

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

the class SuspendIT method test.

@Test
public void test() throws Exception {
    URI dir = SuspendIT.class.getResource("suspend").toURI();
    byte[] payload = archive(dir);
    // ---
    ProcessApi processApi = new ProcessApi(getApiClient());
    StartProcessResponse spr = start(payload);
    // ---
    ProcessEntry pir = waitForStatus(processApi, spr.getInstanceId(), ProcessEntry.StatusEnum.SUSPENDED);
    byte[] ab = getLog(pir.getLogFileName());
    assertLog(".*aaaa.*", ab);
    // ---
    String testValue = "test#" + randomString();
    Map<String, Object> args = Collections.singletonMap("testValue", testValue);
    Map<String, Object> req = Collections.singletonMap(Constants.Request.ARGUMENTS_KEY, args);
    processApi.resume(spr.getInstanceId(), "ev1", null, req);
    pir = waitForCompletion(processApi, spr.getInstanceId());
    assertEquals(ProcessEntry.StatusEnum.FINISHED, pir.getStatus());
    waitForLog(pir.getLogFileName(), ".*bbbb.*");
    waitForLog(pir.getLogFileName(), ".*" + Pattern.quote(testValue) + ".*");
}
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 37 with ProcessEntry

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

the class ThrowExceptionTaskIT method testThrowException.

@Test
public void testThrowException() throws Exception {
    URI uri = ThrowExceptionTaskIT.class.getResource("throwExceptionTask").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(".*Catch that!.*", 3, 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 38 with ProcessEntry

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

the class ProcessContainerIT method test.

@Test
public void test() throws Exception {
    Path src = Paths.get(DockerIT.class.getResource("processContainer").toURI());
    Path dst = IOUtils.createTempDir("test");
    IOUtils.copy(src, dst);
    Path concordYml = dst.resolve("concord.yml");
    String s = new String(Files.readAllBytes(concordYml));
    s = s.replaceAll("%%image%%", ITConstants.DOCKER_ANSIBLE_IMAGE);
    Files.write(concordYml, s.getBytes());
    // ---
    byte[] payload = archive(dst.toUri());
    StartProcessResponse spr = start(payload);
    // --
    ProcessApi processApi = new ProcessApi(getApiClient());
    ProcessEntry pir = waitForCompletion(processApi, spr.getInstanceId());
    assertNotNull(pir.getLogFileName());
    assertEquals(ProcessEntry.StatusEnum.FINISHED, pir.getStatus());
    byte[] ab = getLog(pir.getLogFileName());
    assertLog(".*Hello from Docker!.*", ab);
}
Also used : Path(java.nio.file.Path) ProcessApi(com.walmartlabs.concord.client.ProcessApi) ProcessEntry(com.walmartlabs.concord.client.ProcessEntry) StartProcessResponse(com.walmartlabs.concord.client.StartProcessResponse) Test(org.junit.jupiter.api.Test)

Example 39 with ProcessEntry

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

the class FilePermissionsIT method test.

@Test
public void test() throws Exception {
    Path src = Paths.get(FilePermissionsIT.class.getResource("filePerm").toURI());
    Path tmpDir = createTempDir();
    IOUtils.copy(src, tmpDir);
    Path testFile = tmpDir.resolve("test.sh");
    Set<PosixFilePermission> permissions = new HashSet<>(Files.getPosixFilePermissions(testFile));
    permissions.add(PosixFilePermission.OWNER_EXECUTE);
    Files.setPosixFilePermissions(testFile, permissions);
    ByteArrayOutputStream payload = new ByteArrayOutputStream();
    try (ZipArchiveOutputStream zip = new ZipArchiveOutputStream(payload)) {
        IOUtils.zip(zip, tmpDir);
    }
    // ---
    ProcessApi processApi = new ProcessApi(getApiClient());
    StartProcessResponse spr = start(payload.toByteArray());
    assertNotNull(spr.getInstanceId());
    ProcessEntry pir = waitForCompletion(processApi, spr.getInstanceId());
    byte[] ab = getLog(pir.getLogFileName());
    assertLog(".*Hello!.*", ab);
}
Also used : Path(java.nio.file.Path) ProcessApi(com.walmartlabs.concord.client.ProcessApi) ZipArchiveOutputStream(org.apache.commons.compress.archivers.zip.ZipArchiveOutputStream) ProcessEntry(com.walmartlabs.concord.client.ProcessEntry) ByteArrayOutputStream(java.io.ByteArrayOutputStream) PosixFilePermission(java.nio.file.attribute.PosixFilePermission) StartProcessResponse(com.walmartlabs.concord.client.StartProcessResponse) HashSet(java.util.HashSet) Test(org.junit.jupiter.api.Test)

Example 40 with ProcessEntry

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

the class ForceSuspendIT method testTask.

@Test
public void testTask() throws Exception {
    String eventName = "ev_" + randomString();
    byte[] payload = archive(ForceSuspendIT.class.getResource("suspendTask").toURI());
    Map<String, Object> input = new HashMap<>();
    input.put("archive", payload);
    input.put("arguments.eventName", eventName);
    Map<String, Object> cfg = new HashMap<>();
    cfg.put("dependencies", new String[] { "mvn://com.walmartlabs.concord.it.tasks:suspend-test:" + ITConstants.PROJECT_VERSION });
    input.put("request", cfg);
    StartProcessResponse spr = start(input);
    ProcessApi processApi = new ProcessApi(getApiClient());
    ProcessEntry pir = waitForStatus(processApi, spr.getInstanceId(), ProcessEntry.StatusEnum.SUSPENDED);
    byte[] ab = getLog(pir.getLogFileName());
    assertLog(".*Requesting suspend.*", ab);
    assertLog(".*Whoa!.*", 0, ab);
    // ---
    processApi.resume(pir.getInstanceId(), eventName, null, null);
    pir = waitForCompletion(processApi, spr.getInstanceId());
    ab = getLog(pir.getLogFileName());
    assertLog(".*Whoa!.*", ab);
}
Also used : ProcessApi(com.walmartlabs.concord.client.ProcessApi) HashMap(java.util.HashMap) ProcessEntry(com.walmartlabs.concord.client.ProcessEntry) StartProcessResponse(com.walmartlabs.concord.client.StartProcessResponse) Test(org.junit.jupiter.api.Test)

Aggregations

ProcessEntry (com.walmartlabs.concord.client.ProcessEntry)70 Test (org.junit.jupiter.api.Test)68 ProcessApi (com.walmartlabs.concord.client.ProcessApi)55 StartProcessResponse (com.walmartlabs.concord.client.StartProcessResponse)54 HashMap (java.util.HashMap)35 URI (java.net.URI)23 ConcordProcess (ca.ibodrov.concord.testcontainers.ConcordProcess)15 Payload (ca.ibodrov.concord.testcontainers.Payload)15 Path (java.nio.file.Path)4 ITUtils.randomString (com.walmartlabs.concord.it.common.ITUtils.randomString)3 Utils.resourceToString (com.walmartlabs.concord.it.runtime.v2.Utils.resourceToString)3 File (java.io.File)3 FormListEntry (com.walmartlabs.concord.client.FormListEntry)2 ByteArrayOutputStream (java.io.ByteArrayOutputStream)2 UUID (java.util.UUID)2 ZipArchiveOutputStream (org.apache.commons.compress.archivers.zip.ZipArchiveOutputStream)2 ApiClient (com.walmartlabs.concord.ApiClient)1 FormSubmitResponse (com.walmartlabs.concord.client.FormSubmitResponse)1 HostEntry (com.walmartlabs.concord.client.HostEntry)1 NodeRosterHostsApi (com.walmartlabs.concord.client.NodeRosterHostsApi)1