All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.teamscale.client.ITeamscaleService Maven / Gradle / Ivy

Go to download

A tiny service client that only supports Teamscale's the external upload interface and impacted-tests service.

There is a newer version: 34.0.2
Show newest version
package com.teamscale.client;

import okhttp3.MultipartBody;
import okhttp3.RequestBody;
import okhttp3.ResponseBody;
import retrofit2.Call;
import retrofit2.Response;
import retrofit2.Retrofit;
import retrofit2.http.Body;
import retrofit2.http.DELETE;
import retrofit2.http.GET;
import retrofit2.http.Multipart;
import retrofit2.http.POST;
import retrofit2.http.PUT;
import retrofit2.http.Part;
import retrofit2.http.Path;
import retrofit2.http.Query;

import java.io.IOException;
import java.util.List;

/** {@link Retrofit} API specification for Teamscale. */
public interface ITeamscaleService {

	/**
	 * Report upload API.
	 *
	 * @param commit           A branch and timestamp to upload the report to. Can be null if revision is specified.
	 * @param moveToLastCommit Whether to move the upload timestamp to right after the last commit
	 * @param revision         This parameter allows to pass a revision instead of a timestamp. Can be null if a
	 *                         timestamp is given.
	 * @param partition        The name of the logical partition to store the results into. All existing data in this
	 *                         partition will be invalidated. A partition typically corresponds to one analysis run,
	 *                         i.e. if there are two independent builds/runs, they must use different partitions.
	 * @apiNote How to Upload
	 * External Analysis Results to Teamscale for details.
	 */
	@Multipart
	@POST("api/v5.9.0/projects/{projectAliasOrId}/external-analysis/session/auto-create/report")
	Call uploadExternalReport(
			@Path("projectAliasOrId") String projectAliasOrId,
			@Query("format") String format,
			@Query("t") CommitDescriptor commit,
			@Query("revision") String revision,
			@Query("repository") String repository,
			@Query("movetolastcommit") Boolean moveToLastCommit,
			@Query("partition") String partition,
			@Query("message") String message,
			@Part("report") RequestBody report
	);

	/**
	 * Report upload API with {@link EReportFormat}.
	 *
	 * @see #uploadExternalReport(String, String, CommitDescriptor, String, String, Boolean, String, String,
	 * RequestBody)
	 */
	default Call uploadExternalReport(
			String projectName,
			EReportFormat format,
			CommitDescriptor commit,
			String revision,
			String repository,
			Boolean moveToLastCommit,
			String partition,
			String message,
			RequestBody report
	) {
		return uploadExternalReport(projectName, format.name(), commit, revision, repository, moveToLastCommit,
				partition, message, report);
	}

	/**
	 * Report upload API for multiple reports at once.
	 *
	 * @see #uploadExternalReport(String, String, CommitDescriptor, String, String, Boolean, String, String,
	 * RequestBody)
	 */
	@Multipart
	@POST("api/v5.9.0/projects/{projectName}/external-analysis/session/auto-create/report")
	Call uploadExternalReports(
			@Path("projectName") String projectName,
			@Query("format") EReportFormat format,
			@Query("t") CommitDescriptor commit,
			@Query("revision") String revision,
			@Query("repository") String repository,
			@Query("movetolastcommit") boolean moveToLastCommit,
			@Query("partition") String partition,
			@Query("message") String message,
			@Part List report
	);

	/**
	 * Report upload API for multiple reports at once. This is an overloaded version that takes a string as report
	 * format so that consumers can add support for new report formats without the requirement that the teamscale-client
	 * needs to be adjusted beforehand.
	 *
	 * @see #uploadExternalReport(String, String, CommitDescriptor, String, String, Boolean, String, String,
	 * RequestBody)
	 */
	@Multipart
	@POST("api/v5.9.0/projects/{projectName}/external-analysis/session/auto-create/report")
	Call uploadExternalReports(
			@Path("projectName") String projectName,
			@Query("format") String format,
			@Query("t") CommitDescriptor commit,
			@Query("revision") String revision,
			@Query("repository") String repository,
			@Query("movetolastcommit") boolean moveToLastCommit,
			@Query("partition") String partition,
			@Query("message") String message,
			@Part List report
	);

	/** Retrieve clustered impacted tests based on the given available tests and baseline timestamp. */
	@PUT("api/v9.4.0/projects/{projectName}/impacted-tests")
	Call> getImpactedTests(
			@Path("projectName") String projectName,
			@Query("baseline") String baseline,
			@Query("baseline-revision") String baselineRevision,
			@Query("end") CommitDescriptor end,
			@Query("end-revision") String endRevision,
			@Query("repository") String repository,
			@Query("partitions") List partitions,
			@Query("include-non-impacted") boolean includeNonImpacted,
			@Query("include-failed-and-skipped") boolean includeFailedAndSkippedTests,
			@Query("ensure-processed") boolean ensureProcessed,
			@Query("include-added-tests") boolean includeAddedTests,
			@Body List availableTests
	);

	/** Retrieve unclustered impacted tests based on all tests known to Teamscale and the given baseline timestamp. */
	@GET("api/v9.4.0/projects/{projectName}/impacted-tests")
	Call> getImpactedTests(
			@Path("projectName") String projectName,
			@Query("baseline") String baseline,
			@Query("baseline-revision") String baselineRevision,
			@Query("end") CommitDescriptor end,
			@Query("end-revision") String endRevision,
			@Query("repository") String repository,
			@Query("partitions") List partitions,
			@Query("include-non-impacted") boolean includeNonImpacted,
			@Query("include-failed-and-skipped") boolean includeFailedAndSkippedTests,
			@Query("ensure-processed") boolean ensureProcessed,
			@Query("include-added-tests") boolean includeAddedTests
	);

	/** Registers a profiler to Teamscale and returns the profiler configuration it should be started with. */
	@POST("api/v9.4.0/running-profilers")
	Call registerProfiler(
			@Query("configuration-id") String configurationId,
			@Body ProcessInformation processInformation
	);

	/** Updates the profiler infos and sets the profiler to still alive. */
	@PUT("api/v9.4.0/running-profilers/{profilerId}")
	Call sendHeartbeat(
			@Path("profilerId") String profilerId,
			@Body ProfilerInfo profilerInfo
	);

	/** Removes the profiler identified by given ID. */
	@DELETE("api/v9.4.0/running-profilers/{profilerId}")
	Call unregisterProfiler(@Path("profilerId") String profilerId);

	/**
	 * Uploads the given report body to Teamscale as blocking call with movetolastcommit set to false.
	 *
	 * @return Returns the request body if successful, otherwise throws an IOException.
	 */
	default String uploadReport(
			String projectName,
			CommitDescriptor commit,
			String revision,
			String repository,
			String partition,
			EReportFormat reportFormat,
			String message,
			RequestBody report
	) throws IOException {
		Boolean moveToLastCommit = false;
		if (revision != null) {
			// When uploading to a revision, we don't need commit adjustment.
			commit = null;
			moveToLastCommit = null;
		}

		try {
			Response response = uploadExternalReport(
					projectName,
					reportFormat,
					commit,
					revision,
					repository,
					moveToLastCommit,
					partition,
					message,
					report
			).execute();

			ResponseBody body = response.body();
			if (response.isSuccessful()) {
				if (body == null) {
					return "";
				}
				return body.string();
			}

			String errorBody = HttpUtils.getErrorBodyStringSafe(response);
			throw new IOException(
					"Request failed with error code " + response.code() + ". Response body: " + errorBody);
		} catch (IOException e) {
			throw new IOException("Failed to upload report. " + e.getMessage(), e);
		}
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy