Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
package com.testfabrik.webmate.javasdk.jobs;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.node.JsonNodeFactory;
import com.fasterxml.jackson.databind.node.NullNode;
import com.google.common.base.Optional;
import com.google.common.collect.ImmutableMap;
import com.testfabrik.webmate.javasdk.*;
import org.apache.http.HttpResponse;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.util.EntityUtils;
import java.io.IOException;
import java.util.*;
/**
* Facade that provides access to the webmate JobEngine service.
*/
public class JobEngine {
private static class JobEngineApiClient extends WebmateApiClient {
private final static UriTemplate createJobTemplate = new UriTemplate("/projects/${projectId}/job/jobs");
private final static UriTemplate startJobTemplate = new UriTemplate("/job/jobs/${jobId}/jobruns");
private final static UriTemplate jobRunsForJobTemplate = new UriTemplate("/job/jobs/${jobId}/jobruns");
private final static UriTemplate jobRunSummaryTemplate = new UriTemplate("/job/jobruns/${jobRunId}/summary");
private final static UriTemplate jobsForProjectTemplate = new UriTemplate("/projects/${projectId}/job/jobs");
public JobEngineApiClient(WebmateAuthInfo webmateAuthInfo, WebmateEnvironment environment, HttpClientBuilder httpClientBuilder) {
super(webmateAuthInfo, environment, httpClientBuilder);
}
public JobEngineApiClient(WebmateAuthInfo webmateAuthInfo, WebmateEnvironment environment) {
super(webmateAuthInfo, environment);
}
/**
* Create new Job.
*
* @param projectId ProjectId of Project where Job should be started in.
* @param jobConfigName Name of new JobConfig.
* @param nameForJobInstance Name describing the current Job.
* @param inputValues Input values for Job.
* @return Id of new Job.
*/
public JobId createJob(ProjectId projectId, JobConfigName jobConfigName, String nameForJobInstance, Map inputValues) {
ObjectMapper mapper = new ObjectMapper();
Map simpleInputValues = new HashMap<>();
for (PortName key : inputValues.keySet()) {
simpleInputValues.put(key.toString(), mapper.valueToTree(inputValues.get(key)));
}
JsonNode inputValuesJson = mapper.valueToTree(simpleInputValues);
Map createJobDto;
try {
createJobDto = ImmutableMap.of(
"nameForJobInstance", JsonNodeFactory.instance.textNode(nameForJobInstance),
"inputValues", inputValuesJson,
"scheduling", mapper.readTree("{ \"jobSchedulingSpec\": { \"ExecuteLater\": {} } }"),
"jobConfigIdOrName", JsonNodeFactory.instance.textNode(jobConfigName.jobConfigName));
} catch (IOException e) {
throw new WebmateApiClientException("Error creating JSON", e);
}
ApiResponse response = this.sendPOST(createJobTemplate, ImmutableMap.of("projectId", projectId.toString()), mapper.valueToTree(createJobDto));
Optional optHttpResponse = response.getOptHttpResponse();
if (!optHttpResponse.isPresent()) {
throw new WebmateApiClientException("Could not start Job. Got no response");
}
String jobId;
try {
jobId = EntityUtils.toString(optHttpResponse.get().getEntity());
} catch (IOException e) {
throw new WebmateApiClientException("Could not start Job. Got no JobId");
}
return new JobId(UUID.fromString(jobId));
}
/**
* Start existing job and return id of new jobrun
*/
public JobRunId startExistingJob(JobId id) {
ApiResponse response = this.sendPOST(startJobTemplate, ImmutableMap.of("jobId", id.toString()), NullNode.getInstance());
Optional optHttpResponse = response.getOptHttpResponse();
if (!optHttpResponse.isPresent()) {
throw new WebmateApiClientException("Could not start Job with id "+id+". Got no response");
}
try {
String jobRunId = EntityUtils.toString(optHttpResponse.get().getEntity()).replaceAll("\"", "");
return new JobRunId(UUID.fromString(jobRunId));
} catch (IOException e) {
throw new WebmateApiClientException("Could not start Job with id "+id+". Got no JobRunId");
}
}
/**
* Return list of JobRuns for the given JobId.
*/
public List getJobRunsForJob(JobId jobId) {
ApiResponse response = this.sendGET(jobRunsForJobTemplate, ImmutableMap.of("jobId", jobId.toString()));
Optional optHttpResponse = response.getOptHttpResponse();
if (!optHttpResponse.isPresent()) {
throw new WebmateApiClientException("Could not get JobRuns for Job " + jobId + ". Got no response");
}
if (optHttpResponse.get().getStatusLine().getStatusCode() != 200) {
throw new WebmateApiClientException("Retrieving JobRuns" + jobId + ". Got no response");
}
List jobRunIds = new ArrayList<>();
ObjectMapper om = new ObjectMapper();
try {
String[] jsonIds = om.readValue(optHttpResponse.get().getEntity().getContent(), String[].class);
for (String jsonId : jsonIds) {
jobRunIds.add(new JobRunId(UUID.fromString(jsonId)));
}
} catch (IOException e) {
throw new WebmateApiClientException("Could not read JobRun ids", e);
}
return jobRunIds;
}
/**
* Get JobRunSummary jor JobRun
*/
public JobRunSummary getSummaryOfJobRun(JobRunId jobRunId) {
ApiResponse response = this.sendGET(jobRunSummaryTemplate, ImmutableMap.of("jobRunId", jobRunId.toString()));
Optional optHttpResponse = response.getOptHttpResponse();
if (!optHttpResponse.isPresent()) {
throw new WebmateApiClientException("Could not get summary of JobRun " + jobRunId + ". Got no response");
}
ObjectMapper om = JacksonMapper.getInstance();
try {
String jobRunSummaryJson = EntityUtils.toString(optHttpResponse.get().getEntity());
return om.readValue(jobRunSummaryJson, JobRunSummary.class);
} catch (IOException e) {
throw new WebmateApiClientException("Could not read JobRunSummary", e);
}
}
public List getJobsInProject(ProjectId projectId) {
ApiResponse response = this.sendGET(jobsForProjectTemplate, ImmutableMap.of("projectId", projectId.toString()));
Optional optHttpResponse = response.getOptHttpResponse();
if (!optHttpResponse.isPresent()) {
throw new WebmateApiClientException("Could not get Jobs for Project " + projectId + ". Got no response");
}
if (optHttpResponse.get().getStatusLine().getStatusCode() != 200) {
throw new WebmateApiClientException("Retrieving Jobs for Project " + projectId + ". Got no response");
}
List jobIds = new ArrayList<>();
ObjectMapper om = new ObjectMapper();
try {
JsonNode result = om.readTree(EntityUtils.toString(optHttpResponse.get().getEntity()));
for (String jsonId : result.findValuesAsText("id")) {
jobIds.add(new JobId(UUID.fromString(jsonId)));
}
} catch (IOException e) {
throw new WebmateApiClientException("Could not read Job ids", e);
}
return jobIds;
}
}
private JobEngineApiClient apiClient;
public JobEngine(WebmateAPISession session, HttpClientBuilder httpClientBuilder) {
this.apiClient = new JobEngineApiClient(session.authInfo, session.environment, httpClientBuilder);
}
public JobEngine(WebmateAPISession session) {
this.apiClient = new JobEngineApiClient(session.authInfo, session.environment);
}
/**
* Create a new webmate Job and directly start a new JobRun for this Job.
*
* @param jobConfigName Name of new JobConfig.
* @param nameForJobInstance Name describing JobRun.
* @param inputValues Input values for Job.
* @param projectId ProjectId of Project where Job should be started in.
* @return Id of new JobRun
*/
public JobRunId startJob(JobConfigName jobConfigName, String nameForJobInstance, Map inputValues, ProjectId projectId) {
// create Job
JobId jobId = this.apiClient.createJob(projectId, jobConfigName, nameForJobInstance, inputValues);
JobRunId firstJobRun = startJob(jobId);
return firstJobRun;
}
/**
* Create a new webmate Job and directly start a new JobRun for this Job.
*
* @param nameForJobInstance Name describing JobRun.
* @param config Configuration of one of webmate well-known Jobs, e.g. CrossbrowserLayoutAnalysis.
* @param projectId ProjectId of Project where Job should be started in.
* @return Id of new JobRun
*/
public JobRunId startJob(String nameForJobInstance, WellKnownJobInput config, ProjectId projectId) {
JobConfigName configName = config.getName();
Map inputValues = config.makeInputValues();
return startJob(configName, nameForJobInstance, inputValues, projectId);
}
/**
* Start a Job which already exists. (i.e. to run a Job again)
* @param id Id of the Job to run.
* @return The id of the JobRun that was created
*/
public JobRunId startJob(JobId id) {
return this.apiClient.startExistingJob(id);
}
/**
* Return list of JobRunIds for the given JobId.
* @param jobId Id of Job, for which JobRuns should be retrieved.
* @return List of JobRun ids
*/
public List getJobRunsForJob(JobId jobId) {
return this.apiClient.getJobRunsForJob(jobId);
}
/**
* Get the current state summary of the JobRun with the given JobRunId
* @param jobRunId Id of the JobRun for which the current state should be retrieved.
* @return Summary of the current state of the JobRun
*/
public JobRunSummary getSummaryOfJobRun(JobRunId jobRunId) {
return this.apiClient.getSummaryOfJobRun(jobRunId);
}
/**
* Get all existing jobs in the specified project.
* @param projectId id of the project that jobs should be retrieved for.
* @return List of Job ids
*/
public List getJobsInProject(ProjectId projectId) {
return apiClient.getJobsInProject(projectId);
}
}