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

org.conqat.engine.sourcecode.coverage.testwise_coverage.TestInfo Maven / Gradle / Ivy

package org.conqat.engine.sourcecode.coverage.testwise_coverage;

import java.util.List;
import java.util.Map;

import org.checkerframework.checker.nullness.qual.Nullable;
import org.conqat.engine.index.shared.tests.ETestExecutionResult;
import org.conqat.lib.commons.collections.CollectionUtils;
import org.conqat.lib.commons.collections.IntList;

import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonProperty;

/**
 * Generic container of all information about a specific test as written to the
 * report.
 *
 * This class is a DTO used to deserialize testwise coverage reports. Field
 * names and structure may not be changed.
 */
public class TestInfo {

	/** The name of the JSON property name for {@link #uniformPath}. */
	private static final String UNIFORM_PATH_PROPERTY = "uniformPath";

	/** The name of the JSON property name for {@link #testLocations}. */
	private static final String TEST_LOCATION_PROPERTY = "testLocations";

	/** The name of the JSON property name for {@link #content}. */
	private static final String CONTENT_PROPERTY = "content";

	/** The name of the JSON property name for {@link #duration}. */
	private static final String DURATION_PROPERTY = "duration";

	/** The name of the JSON property name for {@link #result}. */
	private static final String RESULT_PROPERTY = "result";

	/** The name of the JSON property name for {@link #message}. */
	private static final String MESSAGE_PROPERTY = "message";

	/** The name of the JSON property for {@link #readableName}. */
	private static final String READABLE_NAME_PROPERTY = "readableName";

	/** The name of the JSON property for {@link #parameters}. */
	private static final String PARAMETERS_PROPERTY = "parameters";

	/** The name of the JSON property for {@link #hash}. */
	private static final String HASH_PROPERTY = "hash";

	/** The name of the JSON property for {@link #coverage}. */
	private static final String COVERAGE_PROPERTY = "coverage";

	/** The name of the JSON property for {@link #properties}. */
	private static final String PROPERTIES_PROPERTY = "properties";

	/** The name of the JSON property for {@link #externalLink}. */
	private static final String EXTERNAL_LINK_PROPERTY = "externalLink";

	/** The name of the JSON property for {@link #associatedSpecItems}. */
	private static final String ASSOCIATED_SPEC_ITEMS_PROPERTY = "associatedSpecItems";

	/**
	 * Unique name of the test case by using a path like hierarchical description,
	 * which can be shown in the UI. Present in reports of all versions.
	 */
	@JsonProperty(UNIFORM_PATH_PROPERTY)
	public final String uniformPath;

	/**
	 * A list of ANT-patterns limiting the search space for a corresponding test
	 * implementation.
	 */
	@JsonProperty(TEST_LOCATION_PROPERTY)
	public final List testLocations;

	/**
	 * A list of parameters with which the test has been executed. The order of the
	 * parameters in the list is significant.
	 * 
	 * Present in reports of version 2+.
	 */
	@JsonProperty(PARAMETERS_PROPERTY)
	@Nullable
	public final List parameters;

	/**
	 * Some kind of content to tell whether the test specification has changed. Can
	 * be revision number or hash over the specification or similar. Present in
	 * reports of version 1.
	 */
	@JsonProperty(CONTENT_PROPERTY)
	@Nullable
	public final String content;

	/** Duration of the execution in seconds. Present in reports of all versions. */
	@JsonProperty(DURATION_PROPERTY)
	public final Double duration;

	/** The actual execution result state. Present in reports of all versions. */
	@JsonProperty(RESULT_PROPERTY)
	public final ETestExecutionResult result;

	/**
	 * Optional message given for test failures (normally contains a stack trace).
	 * May be {@code null}. Present in reports of all versions.
	 */
	@JsonProperty(MESSAGE_PROPERTY)
	@Nullable
	public final String message;

	/** Present in reports of version 1. */
	@JsonProperty("paths")
	@Nullable
	public List paths;

	/**
	 * A readable name for the test that must not be unique which can be shown in
	 * the UI. Present in reports of version 2+.
	 */
	@JsonProperty(READABLE_NAME_PROPERTY)
	@Nullable
	public final String readableName;

	/**
	 * A hash determining the version of the test implementation. Present in reports
	 * of version 2+.
	 */
	@JsonProperty(HASH_PROPERTY)
	@Nullable
	public final String hash;

	/**
	 * A map of strings to line range strings. The keys are the integer indexes in
	 * string form of the {@link FileInfo} objects in the top-level files array. The
	 * values are the line range strings representing the covered lines. If omitted,
	 * only the values of the other fields are updated in Teamscale, but the
	 * coverage isn't modified. Present in reports of version 2+.
	 */
	@JsonProperty(COVERAGE_PROPERTY)
	@Nullable
	public final Map coverage;

	/**
	 * A map of strings that can carry additional properties that are displayed on
	 * the test details page. E.g., ID that identifies the test case or the test run
	 * in an external system or the name of a tester if the test is executed
	 * manually. Present in reports of version 2+.
	 */
	@JsonProperty(PROPERTIES_PROPERTY)
	@Nullable
	public final Map properties;

	/**
	 * Link to an external build or test management tool that offers information
	 * about the run of the execution unit. Present in reports of version 2+.
	 */
	@JsonProperty(EXTERNAL_LINK_PROPERTY)
	@Nullable
	public final String externalLink;

	/**
	 * List of unparsed spec items that are verified by this test.
	 */
	@JsonProperty(ASSOCIATED_SPEC_ITEMS_PROPERTY)
	@Nullable
	public final List associatedSpecItems;

	public TestInfo(String uniformPath) {
		this.uniformPath = uniformPath;
		testLocations = null;
		parameters = null;
		content = null;
		duration = null;
		result = null;
		message = null;
		readableName = null;
		hash = null;
		coverage = null;
		properties = null;
		externalLink = null;
		associatedSpecItems = null;
	}

	public TestInfo(String uniformPath, @Nullable Double duration, @Nullable ETestExecutionResult result,
			@Nullable Map coverage) {
		this.uniformPath = uniformPath;
		this.duration = duration;
		this.result = result;
		this.coverage = coverage;
		testLocations = null;
		parameters = null;
		content = null;
		message = null;
		readableName = null;
		hash = null;
		paths = null;
		properties = null;
		externalLink = null;
		associatedSpecItems = null;
	}

	/**
	 * A constructor that copies all the fields of an existing TestInfo object,
	 * except of a few fields calculated by teamscale-build. This is a means to
	 * reduce the maintenance work in teamscale-build if the TestInfo object is
	 * updated with additional fields (as they can then be set by the metadata.json,
	 * see teamscale-build).
	 */
	public TestInfo(TestInfo other, @Nullable Double duration, @Nullable ETestExecutionResult result,
			@Nullable Map coverage, @Nullable String content) {
		this.uniformPath = other.uniformPath;
		this.testLocations = other.testLocations;
		this.parameters = other.parameters;
		this.content = content;
		this.duration = duration;
		this.result = result;
		this.message = other.message;
		this.readableName = other.readableName;
		this.hash = other.hash;
		this.coverage = coverage;
		this.properties = other.properties;
		this.externalLink = other.externalLink;
		this.associatedSpecItems = other.associatedSpecItems;
	}

	@JsonCreator
	public TestInfo(@JsonProperty(UNIFORM_PATH_PROPERTY) String uniformPath,
			@JsonProperty(TEST_LOCATION_PROPERTY) List testLocations,
			@JsonProperty(PARAMETERS_PROPERTY) @Nullable List parameters,
			@JsonProperty(CONTENT_PROPERTY) @Nullable String content, @JsonProperty(DURATION_PROPERTY) Double duration,
			@JsonProperty(RESULT_PROPERTY) ETestExecutionResult result,
			@JsonProperty(MESSAGE_PROPERTY) @Nullable String message,
			@JsonProperty(READABLE_NAME_PROPERTY) @Nullable String readableName,
			@JsonProperty(HASH_PROPERTY) @Nullable String hash,
			@JsonProperty(COVERAGE_PROPERTY) @Nullable Map coverage,
			@JsonProperty(PROPERTIES_PROPERTY) @Nullable Map properties,
			@JsonProperty(EXTERNAL_LINK_PROPERTY) @Nullable String externalLink,
			@JsonProperty(ASSOCIATED_SPEC_ITEMS_PROPERTY) @Nullable List associatedSpecItems) {
		this.uniformPath = uniformPath;
		this.testLocations = testLocations;
		this.parameters = parameters;
		this.content = content;
		this.duration = duration;
		this.result = result;
		this.message = message;
		this.readableName = readableName;
		this.hash = hash;
		this.coverage = coverage;
		this.properties = properties;
		this.externalLink = externalLink;
		this.associatedSpecItems = associatedSpecItems;
	}

	/**
	 * Returns whether all required fields in testwise coverage V1 are empty. This
	 * meant that the test was not executed, but still exists and should not be
	 * deleted as part of the upload.
	 */
	@JsonIgnore
	public boolean isEmpty() {
		return content == null && duration == null && result == null && CollectionUtils.isNullOrEmpty(paths);
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy