// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
package org.chromium.base.test.util;
import android.os.Build;
import org.junit.runners.model.FrameworkMethod;
import org.chromium.base.Log;
/** Checks the device's SDK level against any specified minimum or maximum requirement. */
public class AndroidSdkLevelSkipCheck extends SkipCheck {
private static final String TAG = "base_test";
/**
* If either {@link MinAndroidSdkLevel} or {@link MaxAndroidSdkLevel} is present, checks its
* boundary against the device's SDK level.
*
* @param testCase The test to check.
* @return true if the device's SDK level is below the specified minimum.
*/
@Override
public boolean shouldSkip(FrameworkMethod frameworkMethod) {
int minSdkLevel = 0;
for (MinAndroidSdkLevel m :
AnnotationProcessingUtils.getAnnotations(
frameworkMethod.getMethod(), MinAndroidSdkLevel.class)) {
minSdkLevel = Math.max(minSdkLevel, m.value());
}
int maxSdkLevel = Integer.MAX_VALUE;
for (MaxAndroidSdkLevel m :
AnnotationProcessingUtils.getAnnotations(
frameworkMethod.getMethod(), MaxAndroidSdkLevel.class)) {
maxSdkLevel = Math.min(maxSdkLevel, m.value());
}
if (Build.VERSION.SDK_INT < minSdkLevel || Build.VERSION.SDK_INT > maxSdkLevel) {
Log.i(
TAG,
"Test "
+ frameworkMethod.getDeclaringClass().getName()
+ "#"
+ frameworkMethod.getName()
+ " is not enabled at SDK level "
+ Build.VERSION.SDK_INT
+ ".");
return true;
}
return false;
}
}