C++程序  |  111行  |  3.95 KB

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