Search in sources :

Example 1 with Input

use of com.netflix.conductor.contribs.http.HttpTask.Input in project conductor by Netflix.

the class TestHttpTask method testJsonGET.

@Test
public void testJsonGET() throws JsonProcessingException {
    Task task = new Task();
    Input input = new Input();
    input.setUri("http://localhost:7009/json");
    input.setMethod("GET");
    task.getInputData().put(HttpTask.REQUEST_PARAMETER_NAME, input);
    httpTask.start(workflow, task, workflowExecutor);
    Map<String, Object> hr = (Map<String, Object>) task.getOutputData().get("response");
    Object response = hr.get("body");
    assertEquals(Task.Status.COMPLETED, task.getStatus());
    assertTrue(response instanceof Map);
    Map<String, Object> map = (Map<String, Object>) response;
    assertEquals(JSON_RESPONSE, objectMapper.writeValueAsString(map));
}
Also used : Task(com.netflix.conductor.common.metadata.tasks.Task) WorkflowTask(com.netflix.conductor.common.metadata.workflow.WorkflowTask) Input(com.netflix.conductor.contribs.http.HttpTask.Input) HashMap(java.util.HashMap) Map(java.util.Map) Test(org.junit.Test)

Example 2 with Input

use of com.netflix.conductor.contribs.http.HttpTask.Input in project conductor by Netflix.

the class TestHttpTask method testPost.

@Test
public void testPost() {
    Task task = new Task();
    Input input = new Input();
    input.setUri("http://localhost:7009/post");
    Map<String, Object> body = new HashMap<>();
    body.put("input_key1", "value1");
    body.put("input_key2", 45.3d);
    body.put("someKey", null);
    input.setBody(body);
    input.setMethod("POST");
    task.getInputData().put(HttpTask.REQUEST_PARAMETER_NAME, input);
    httpTask.start(workflow, task, workflowExecutor);
    assertEquals(task.getReasonForIncompletion(), Task.Status.COMPLETED, task.getStatus());
    Map<String, Object> hr = (Map<String, Object>) task.getOutputData().get("response");
    Object response = hr.get("body");
    assertEquals(Task.Status.COMPLETED, task.getStatus());
    assertTrue("response is: " + response, response instanceof Map);
    Map<String, Object> map = (Map<String, Object>) response;
    Set<String> inputKeys = body.keySet();
    Set<String> responseKeys = map.keySet();
    inputKeys.containsAll(responseKeys);
    responseKeys.containsAll(inputKeys);
}
Also used : Task(com.netflix.conductor.common.metadata.tasks.Task) WorkflowTask(com.netflix.conductor.common.metadata.workflow.WorkflowTask) Input(com.netflix.conductor.contribs.http.HttpTask.Input) HashMap(java.util.HashMap) HashMap(java.util.HashMap) Map(java.util.Map) Test(org.junit.Test)

Example 3 with Input

use of com.netflix.conductor.contribs.http.HttpTask.Input in project conductor by Netflix.

the class TestHttpTask method testNumberGET.

@Test
public void testNumberGET() {
    Task task = new Task();
    Input input = new Input();
    input.setUri("http://localhost:7009/numeric");
    input.setMethod("GET");
    task.getInputData().put(HttpTask.REQUEST_PARAMETER_NAME, input);
    httpTask.start(workflow, task, workflowExecutor);
    Map<String, Object> hr = (Map<String, Object>) task.getOutputData().get("response");
    Object response = hr.get("body");
    assertEquals(Task.Status.COMPLETED, task.getStatus());
    assertEquals(NUM_RESPONSE, response);
    assertTrue(response instanceof Number);
}
Also used : Task(com.netflix.conductor.common.metadata.tasks.Task) WorkflowTask(com.netflix.conductor.common.metadata.workflow.WorkflowTask) Input(com.netflix.conductor.contribs.http.HttpTask.Input) HashMap(java.util.HashMap) Map(java.util.Map) Test(org.junit.Test)

Example 4 with Input

use of com.netflix.conductor.contribs.http.HttpTask.Input in project conductor by Netflix.

the class TestHttpTask method testOptional.

@Test
public void testOptional() {
    Task task = new Task();
    Input input = new Input();
    input.setUri("http://localhost:7009/failure");
    input.setMethod("GET");
    task.getInputData().put(HttpTask.REQUEST_PARAMETER_NAME, input);
    httpTask.start(workflow, task, workflowExecutor);
    assertEquals("Task output: " + task.getOutputData(), Task.Status.FAILED, task.getStatus());
    assertEquals(ERROR_RESPONSE, task.getReasonForIncompletion());
    assertTrue(!task.getStatus().isSuccessful());
    task.setStatus(Status.SCHEDULED);
    task.getInputData().remove(HttpTask.REQUEST_PARAMETER_NAME);
    task.setReferenceTaskName("t1");
    httpTask.start(workflow, task, workflowExecutor);
    assertEquals(Task.Status.FAILED, task.getStatus());
    assertEquals(HttpTask.MISSING_REQUEST, task.getReasonForIncompletion());
    assertTrue(!task.getStatus().isSuccessful());
    WorkflowTask workflowTask = new WorkflowTask();
    workflowTask.setOptional(true);
    workflowTask.setName("HTTP");
    workflowTask.setWorkflowTaskType(TaskType.USER_DEFINED);
    workflowTask.setTaskReferenceName("t1");
    WorkflowDef def = new WorkflowDef();
    def.getTasks().add(workflowTask);
    Workflow workflow = new Workflow();
    workflow.setWorkflowDefinition(def);
    workflow.getTasks().add(task);
    MetadataDAO metadataDAO = mock(MetadataDAO.class);
    ExternalPayloadStorageUtils externalPayloadStorageUtils = mock(ExternalPayloadStorageUtils.class);
    ParametersUtils parametersUtils = mock(ParametersUtils.class);
    Configuration configuration = mock(Configuration.class);
    Map<String, TaskMapper> taskMappers = new HashMap<>();
    new DeciderService(parametersUtils, metadataDAO, externalPayloadStorageUtils, taskMappers, configuration).decide(workflow);
    System.out.println(workflow.getTasks());
    System.out.println(workflow.getStatus());
}
Also used : Task(com.netflix.conductor.common.metadata.tasks.Task) WorkflowTask(com.netflix.conductor.common.metadata.workflow.WorkflowTask) WorkflowDef(com.netflix.conductor.common.metadata.workflow.WorkflowDef) Configuration(com.netflix.conductor.core.config.Configuration) HashMap(java.util.HashMap) DeciderService(com.netflix.conductor.core.execution.DeciderService) Workflow(com.netflix.conductor.common.run.Workflow) ExternalPayloadStorageUtils(com.netflix.conductor.core.utils.ExternalPayloadStorageUtils) WorkflowTask(com.netflix.conductor.common.metadata.workflow.WorkflowTask) Input(com.netflix.conductor.contribs.http.HttpTask.Input) ParametersUtils(com.netflix.conductor.core.execution.ParametersUtils) MetadataDAO(com.netflix.conductor.dao.MetadataDAO) TaskMapper(com.netflix.conductor.core.execution.mapper.TaskMapper) Test(org.junit.Test)

Example 5 with Input

use of com.netflix.conductor.contribs.http.HttpTask.Input in project conductor by Netflix.

the class TestHttpTask method testPostAsyncComplete.

@Test
public void testPostAsyncComplete() {
    Task task = new Task();
    Input input = new Input();
    input.setUri("http://localhost:7009/post");
    Map<String, Object> body = new HashMap<>();
    body.put("input_key1", "value1");
    body.put("input_key2", 45.3d);
    input.setBody(body);
    input.setMethod("POST");
    task.getInputData().put(HttpTask.REQUEST_PARAMETER_NAME, input);
    task.getInputData().put("asyncComplete", true);
    httpTask.start(workflow, task, workflowExecutor);
    assertEquals(task.getReasonForIncompletion(), Status.IN_PROGRESS, task.getStatus());
    Map<String, Object> hr = (Map<String, Object>) task.getOutputData().get("response");
    Object response = hr.get("body");
    assertEquals(Status.IN_PROGRESS, task.getStatus());
    assertTrue("response is: " + response, response instanceof Map);
    Map<String, Object> map = (Map<String, Object>) response;
    Set<String> inputKeys = body.keySet();
    Set<String> responseKeys = map.keySet();
    inputKeys.containsAll(responseKeys);
    responseKeys.containsAll(inputKeys);
}
Also used : Task(com.netflix.conductor.common.metadata.tasks.Task) WorkflowTask(com.netflix.conductor.common.metadata.workflow.WorkflowTask) Input(com.netflix.conductor.contribs.http.HttpTask.Input) HashMap(java.util.HashMap) HashMap(java.util.HashMap) Map(java.util.Map) Test(org.junit.Test)

Aggregations

Task (com.netflix.conductor.common.metadata.tasks.Task)12 WorkflowTask (com.netflix.conductor.common.metadata.workflow.WorkflowTask)12 Input (com.netflix.conductor.contribs.http.HttpTask.Input)12 Test (org.junit.Test)12 HashMap (java.util.HashMap)8 Map (java.util.Map)7 WorkflowDef (com.netflix.conductor.common.metadata.workflow.WorkflowDef)1 Workflow (com.netflix.conductor.common.run.Workflow)1 Configuration (com.netflix.conductor.core.config.Configuration)1 DeciderService (com.netflix.conductor.core.execution.DeciderService)1 ParametersUtils (com.netflix.conductor.core.execution.ParametersUtils)1 TaskMapper (com.netflix.conductor.core.execution.mapper.TaskMapper)1 ExternalPayloadStorageUtils (com.netflix.conductor.core.utils.ExternalPayloadStorageUtils)1 MetadataDAO (com.netflix.conductor.dao.MetadataDAO)1 Instant (java.time.Instant)1