use of com.qasymphony.ci.plugin.utils.ClientRequestException in project jenkin-qtest-plugin by QASymphony.
the class JunitQtestSubmitterImpl method getTaskResponse.
private AutomationTestResponse getTaskResponse(JunitSubmitterRequest request, SubmittedTask task, Map<String, String> headers) throws SubmittedException {
ResponseEntity responseEntity;
try {
// get task status
responseEntity = AutomationTestService.getTaskStatus(request.getqTestURL(), task.getId(), headers);
} catch (ClientRequestException e) {
LoggerUtils.formatError(request.getListener().getLogger(), "Cannot get response of taskId: %s, error: %s", task.getId(), e.getMessage());
throw new SubmittedException(e.getMessage(), -1);
}
LOG.info(String.format("project:%s, status:%s, body:%s", request.getJenkinsProjectName(), null == responseEntity ? -1 : responseEntity.getStatusCode(), null == responseEntity ? "" : responseEntity.getBody()));
if ((null == responseEntity) || (responseEntity.getStatusCode() != HttpStatus.SC_OK)) {
throw new SubmittedException(ConfigService.getErrorMessage(responseEntity.getBody()), responseEntity.getStatusCode());
}
return new AutomationTestResponse(responseEntity.getBody());
}
use of com.qasymphony.ci.plugin.utils.ClientRequestException in project jenkin-qtest-plugin by QASymphony.
the class AutomationTestService method push.
public static ResponseEntity push(String buildNumber, String buildPath, List<AutomationTestResult> testResults, JunitSubmitterRequest request, String accessToken) throws SubmittedException {
if (testResults.size() <= 0)
return null;
String url;
AutomationTestResultWrapper wrapper = new AutomationTestResultWrapper();
wrapper.setBuildNumber(buildNumber);
wrapper.setBuildPath(buildPath);
wrapper.setSkipCreatingAutomationModule(true);
Long moduleId = request.getModuleID();
if (null != moduleId && 0 < moduleId) {
wrapper.setParent_module(moduleId);
}
if (request.getSubmitToExistingContainer()) {
String fullURL = request.getJenkinsServerURL();
if (!fullURL.endsWith("/")) {
fullURL += "/";
}
fullURL += buildPath;
for (int i = 0; i < testResults.size(); i++) {
AutomationTestResult result = testResults.get(i);
result.setBuildNumber(buildNumber);
result.setBuildURL(fullURL);
}
url = String.format(AUTO_TEST_LOG_ENDPOINT_V3_1, request.getqTestURL(), request.getProjectID(), 0);
Long testSuiteId = prepareTestSuite(request, accessToken);
if (-1 == testSuiteId) {
throw new SubmittedException("Could not find or create test suite to submit test logs", -1);
}
wrapper.setTest_suite(testSuiteId);
wrapper.setTest_logs(testResults);
} else {
/**
* using {@link String#format(Locale, String, Object...)} instead {@link java.text.MessageFormat#format(String, Object...)}
* to avoid unexpected formatted link. see: QTE-2798 for more details.
*/
url = String.format(AUTO_TEST_LOG_ENDPOINT_V3, request.getqTestURL(), request.getProjectID(), 0, request.getConfigurationID());
wrapper.setTestResults(testResults);
}
Map<String, String> headers = OauthProvider.buildHeaders(accessToken, null);
ResponseEntity responseEntity = null;
try {
String data = JsonUtils.toJson(wrapper);
responseEntity = HttpClientUtils.post(url, headers, data);
} catch (ClientRequestException e) {
throw new SubmittedException(e.getMessage(), null == responseEntity ? 0 : responseEntity.getStatusCode());
}
return responseEntity;
}
use of com.qasymphony.ci.plugin.utils.ClientRequestException in project jenkin-qtest-plugin by QASymphony.
the class AutomationTestService method getTaskStatus.
public static ResponseEntity getTaskStatus(String qTestURL, long taskId, Map<String, String> headers) throws ClientRequestException {
String url = String.format(API_SUBMIT_TASK_STATUS, qTestURL, taskId);
ResponseEntity responseEntity = null;
try {
responseEntity = HttpClientUtils.get(url, headers);
} catch (ClientRequestException e) {
throw e;
}
return responseEntity;
}
Aggregations