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

org.conqat.engine.index.shared.tests.ETestExecutionResult Maven / Gradle / Ivy

/*
 * Copyright (c) CQSE GmbH
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.conqat.engine.index.shared.tests;

import org.conqat.lib.commons.test.IndexValueClass;
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;

import org.checkerframework.checker.nullness.qual.Nullable;
import org.conqat.lib.commons.js_export.ExportToTypeScript;

/**
 * The result of a test execution. The order of the test executions is important when determining
 * the {@link #worst(ETestExecutionResult, ETestExecutionResult)} {@link ETestExecutionResult}. The
 * order must be from best to worst in order of definition in the {@link Enum} (i.e. highest ordinal
 * is worst {@link ETestExecutionResult}).
 */
@ExportToTypeScript
@IndexValueClass(containedInBackup = true)
public enum ETestExecutionResult {

	/** Test execution was successful. */
	PASSED("passed"),

	/** The test is currently marked as "do not execute" (e.g. JUnit @Ignore). */
	IGNORED("ignored"),

	/** Caused by a failing assumption. */
	SKIPPED("skipped"),

	/** Caused by a failing assertion. */
	FAILURE("failure"),

	/** Caused by an error during test execution (e.g. exception thrown). */
	ERROR("error"),

	/** Test execution without unambiguous result. */
	INCONCLUSIVE("inconclusive");

	/** Stores the readable names for the cases */
	private String readableName;

	/**
	 * To sum up all possible results in, e.g., parameter descriptions, a compile-time constant
	 * expression is needed. So we maintained manually a string representation of all possible results
	 * here.
	 */
	public static final String ALL_RESULTS = "PASSED, IGNORED, SKIPPED, FAILURE, ERROR";

	/** The best {@link ETestExecutionResult}. */
	public static final ETestExecutionResult BEST_RESULT = ETestExecutionResult.values()[0];

	/** Constructor */
	ETestExecutionResult(String readableName) {
		this.readableName = readableName;
	}

	/**
	 * Returns the worst {@link ETestExecutionResult} between the two {@link ETestExecutionResult}s.
	 */
	public static ETestExecutionResult worst(@Nullable ETestExecutionResult resultA,
			@Nullable ETestExecutionResult resultB) {
		if (resultA == null) {
			return resultB;
		}
		if (resultB == null) {
			return resultA;
		}
		if (resultA.ordinal() < resultB.ordinal()) {
			return resultB;
		}
		return resultA;
	}

	/** Returns the readableName */
	public String getReadableName() {
		return readableName;
	}

	/**
	 * Returns a list of all readable names (i.e. one readable name for each case)
	 */
	public static List getReadableNames() {
		return Arrays.stream(ETestExecutionResult.values()).map(ETestExecutionResult::getReadableName)
				.collect(Collectors.toList());
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy