/*
* Copyright (C) 2011 The Android Open Source Project
*
* 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.
*/
import vogar.Expectation;
import vogar.ExpectationStore;
import vogar.ModeId;
import vogar.Result;
import com.android.tradefed.util.AbiUtils;
import java.io.File;
import java.io.FilenameFilter;
import java.io.IOException;
import java.util.Arrays;
import java.util.HashSet;
import java.util.Set;
public class VogarUtils {
public static boolean isVogarKnownFailure(ExpectationStore[] expectationStores,
final String testClassName,
final String testMethodName) {
for (ExpectationStore expectationStore : expectationStores) {
if (isVogarKnownFailure(expectationStore, testClassName, testMethodName)) {
return true;
}
}
return false;
}
/**
* @return true iff the class/name is found in the vogar known failure list and it is not
* a known failure that is a result of an unsupported abi.
*/
public static boolean isVogarKnownFailure(ExpectationStore expectationStore,
final String testClassName,
final String testMethodName) {
if (expectationStore == null) {
return false;
}
String fullTestName = buildFullTestName(testClassName, testMethodName);
Expectation expectation = expectationStore.get(fullTestName);
if (expectation.getResult() == Result.SUCCESS) {
return false;
}
String description = expectation.getDescription();
boolean foundAbi = AbiUtils.parseAbiList(description).size() > 0;
return expectation.getResult() != Result.SUCCESS && !foundAbi;
}
public static ExpectationStore provideExpectationStore(String dir) throws IOException {
if (dir == null) {
return null;
}
ExpectationStore result = ExpectationStore.parse(getExpectationFiles(dir), ModeId.DEVICE);
return result;
}
private static Set<File> getExpectationFiles(String dir) {
Set<File> expectSet = new HashSet<File>();
File[] files = new File(dir).listFiles(new FilenameFilter() {
// ignore obviously temporary files
public boolean accept(File dir, String name) {
return !name.endsWith("~") && !name.startsWith(".");
}
});
if (files != null) {
expectSet.addAll(Arrays.asList(files));
}
return expectSet;
}
/** @return the test name in the form of com.android.myclass.TestClass#testMyMethod */
public static String buildFullTestName(String testClass, String testMethodName) {
return String.format("%s#%s", testClass, testMethodName);
}
/**
* This method looks in the description field of the Vogar entry for the ABI_LIST_MARKER
* and returns the list of abis found there.
*
* @return The Set of supported abis parsed from the {@code expectation}'s description.
*/
public static Set<String> extractSupportedAbis(String architecture, Expectation expectation) {
Set<String> supportedAbiSet = AbiUtils.getAbisForArch(architecture);
if (expectation == null || expectation.getDescription().isEmpty()) {
// Include all abis since there was no limitation found in the description
return supportedAbiSet;
}
// Remove any abis that are not supported for the test.
supportedAbiSet.removeAll(AbiUtils.parseAbiList(expectation.getDescription()));
return supportedAbiSet;
}
/**
* Determine the correct set of ABIs for the given className/testName.
*
* @return the set of ABIs that can be expected to pass for the given combination of
* {@code architecture}, {@code className} and {@code testName}.
*/
public static Set<String> extractSupportedAbis(String architecture,
ExpectationStore[] expectationStores,
String className,
String testName) {
String fullTestName = buildFullTestName(className, testName);
Set<String> supportedAbiSet = AbiUtils.getAbisForArch(architecture);
for (ExpectationStore expectationStore : expectationStores) {
Expectation expectation = expectationStore.get(fullTestName);
supportedAbiSet.retainAll(extractSupportedAbis(architecture, expectation));
}
return supportedAbiSet;
}
/**
* Returns the greatest timeout in minutes for the test in all
* expectation stores, or 0 if no timeout was found.
*/
public static int timeoutInMinutes(ExpectationStore[] expectationStores,
final String testClassName,
final String testMethodName) {
int timeoutInMinutes = 0;
for (ExpectationStore expectationStore : expectationStores) {
timeoutInMinutes = Math.max(timeoutInMinutes,
timeoutInMinutes(expectationStore,
testClassName,
testMethodName));
}
return timeoutInMinutes;
}
/**
* Returns the timeout in minutes for the test in the expectation
* stores, or 0 if no timeout was found.
*/
public static int timeoutInMinutes(ExpectationStore expectationStore,
final String testClassName,
final String testMethodName) {
if (expectationStore == null) {
return 0;
}
String fullTestName = buildFullTestName(testClassName, testMethodName);
return timeoutInMinutes(expectationStore.get(fullTestName));
}
/**
* Returns the timeout in minutes for the expectation. Currently a
* tag of large results in a 60 minute timeout, otherwise 0 is
* returned to indicate a default timeout should be used.
*/
public static int timeoutInMinutes(Expectation expectation) {
return expectation.getTags().contains("large") ? 60 : 0;
}
}