/* * Copyright (C) 2014 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. */ #include "RuleGenerator.h" #include "aapt/SdkConstants.h" #include "TestRules.h" #include <gtest/gtest.h> #include <utils/Vector.h> using namespace android; using namespace split::test; namespace split { TEST(RuleGeneratorTest, testAbiRules) { Vector<abi::Variant> abis; const ssize_t armeabiIndex = abis.add(abi::Variant_armeabi); const ssize_t armeabi_v7aIndex = abis.add(abi::Variant_armeabi_v7a); const ssize_t x86Index = abis.add(abi::Variant_x86); EXPECT_RULES_EQ(RuleGenerator::generateAbi(abis, armeabiIndex), ContainsAnyRule(Rule::NATIVE_PLATFORM, "armeabi") ); EXPECT_RULES_EQ(RuleGenerator::generateAbi(abis, armeabi_v7aIndex), ContainsAnyRule(Rule::NATIVE_PLATFORM, "armeabi-v7a", "arm64-v8a") ); EXPECT_RULES_EQ(RuleGenerator::generateAbi(abis, x86Index), ContainsAnyRule(Rule::NATIVE_PLATFORM, "x86", "x86_64") ); } TEST(RuleGeneratorTest, densityConstantsAreSane) { EXPECT_LT(263, (int) ConfigDescription::DENSITY_XHIGH); EXPECT_GT(262, (int) ConfigDescription::DENSITY_HIGH); EXPECT_LT(363, (int) ConfigDescription::DENSITY_XXHIGH); EXPECT_GT(362, (int) ConfigDescription::DENSITY_XHIGH); } TEST(RuleGeneratorTest, testDensityRules) { Vector<int> densities; const ssize_t highIndex = densities.add(ConfigDescription::DENSITY_HIGH); const ssize_t xhighIndex = densities.add(ConfigDescription::DENSITY_XHIGH); const ssize_t xxhighIndex = densities.add(ConfigDescription::DENSITY_XXHIGH); EXPECT_RULES_EQ(RuleGenerator::generateDensity(densities, highIndex), AndRule() .add(LtRule(Rule::SCREEN_DENSITY, 263)) ); EXPECT_RULES_EQ(RuleGenerator::generateDensity(densities, xhighIndex), AndRule() .add(GtRule(Rule::SCREEN_DENSITY, 262)) .add(LtRule(Rule::SCREEN_DENSITY, 363)) ); EXPECT_RULES_EQ(RuleGenerator::generateDensity(densities, xxhighIndex), AndRule() .add(GtRule(Rule::SCREEN_DENSITY, 362)) ); } TEST(RuleGeneratorTest, testDensityRulesWithAnyDpi) { Vector<int> densities; const ssize_t highIndex = densities.add(ConfigDescription::DENSITY_HIGH); const ssize_t xhighIndex = densities.add(ConfigDescription::DENSITY_XHIGH); const ssize_t xxhighIndex = densities.add(ConfigDescription::DENSITY_XXHIGH); const ssize_t anyIndex = densities.add(ConfigDescription::DENSITY_ANY); EXPECT_RULES_EQ(RuleGenerator::generateDensity(densities, highIndex), AndRule() .add(LtRule(Rule::SDK_VERSION, SDK_LOLLIPOP)) .add(LtRule(Rule::SCREEN_DENSITY, 263)) ); EXPECT_RULES_EQ(RuleGenerator::generateDensity(densities, xhighIndex), AndRule() .add(LtRule(Rule::SDK_VERSION, SDK_LOLLIPOP)) .add(GtRule(Rule::SCREEN_DENSITY, 262)) .add(LtRule(Rule::SCREEN_DENSITY, 363)) ); EXPECT_RULES_EQ(RuleGenerator::generateDensity(densities, xxhighIndex), AndRule() .add(LtRule(Rule::SDK_VERSION, SDK_LOLLIPOP)) .add(GtRule(Rule::SCREEN_DENSITY, 362)) ); // We expect AlwaysTrue because anydpi always has attached v21 to the configuration // and the rest of the rule generation code generates the sdk version checks. EXPECT_RULES_EQ(RuleGenerator::generateDensity(densities, anyIndex), AlwaysTrue()); } } // namespace split