| /* |
| * 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.expect.Expectation; |
| import vogar.expect.ExpectationStore; |
| import vogar.expect.ModeId; |
| import vogar.expect.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; |
| } |
| } |