| /* |
| * 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 |