blob: 0b09d88c8d15c1dc9d37a2afc8c2eb57b98113b1 [file] [log] [blame]
/*
* Copyright (C) 2019 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 <netdb.h>
#include <cutils/properties.h>
#include <gmock/gmock-matchers.h>
#include <gtest/gtest.h>
#include "netd_resolv/stats.h"
#include "resolv_cache.h"
constexpr int TEST_NETID = 30;
namespace {
constexpr int EAI_OK = 0;
constexpr char DNS_EVENT_SUBSAMPLING_MAP_FLAG[] =
"persist.device_config.netd_native.dns_event_subsample_map";
class ScopedCacheCreate {
public:
explicit ScopedCacheCreate(unsigned netid, const char* subsampling_map,
const char* property = DNS_EVENT_SUBSAMPLING_MAP_FLAG)
: mStoredNetId(netid), mStoredProperty(property) {
property_get(property, mStoredMap, "");
property_set(property, subsampling_map);
EXPECT_EQ(0, resolv_create_cache_for_net(netid));
}
~ScopedCacheCreate() {
resolv_delete_cache_for_net(mStoredNetId);
property_set(mStoredProperty, mStoredMap);
}
private:
unsigned mStoredNetId;
const char* mStoredProperty;
char mStoredMap[PROPERTY_VALUE_MAX]{};
};
} // namespace
TEST(ResolvCacheTest, DnsEventSubsampling) {
// Test defaults, default flag is "default:1 0:100 7:10" if no experiment flag is set
{
ScopedCacheCreate scopedCacheCreate(TEST_NETID, "");
EXPECT_EQ(resolv_cache_get_subsampling_denom(TEST_NETID, EAI_NODATA), 10U);
EXPECT_EQ(resolv_cache_get_subsampling_denom(TEST_NETID, EAI_OK), 100U);
EXPECT_EQ(resolv_cache_get_subsampling_denom(TEST_NETID, EAI_BADFLAGS),
1U); // default
EXPECT_THAT(resolv_cache_dump_subsampling_map(TEST_NETID),
testing::UnorderedElementsAreArray({"default:1", "0:100", "7:10"}));
}
// Now change the experiment flag to "0:42 default:666"
{
ScopedCacheCreate scopedCacheCreate(TEST_NETID, "0:42 default:666");
EXPECT_EQ(resolv_cache_get_subsampling_denom(TEST_NETID, EAI_OK), 42U);
EXPECT_EQ(resolv_cache_get_subsampling_denom(TEST_NETID, EAI_NODATA),
666U); // default
EXPECT_THAT(resolv_cache_dump_subsampling_map(TEST_NETID),
testing::UnorderedElementsAreArray({"default:666", "0:42"}));
}
// Now change the experiment flag to something illegal
{
ScopedCacheCreate scopedCacheCreate(TEST_NETID, "asvaxx");
// 0(disable log) is the default value if experiment flag is invalid.
EXPECT_EQ(resolv_cache_get_subsampling_denom(TEST_NETID, EAI_OK), 0U);
EXPECT_EQ(resolv_cache_get_subsampling_denom(TEST_NETID, EAI_NODATA), 0U);
EXPECT_TRUE(resolv_cache_dump_subsampling_map(TEST_NETID).empty());
}
// Test negative and zero denom
{
ScopedCacheCreate scopedCacheCreate(TEST_NETID, "0:-42 default:-666 7:10 10:0");
// 0(disable log) is the default value if no valid denom is set
EXPECT_EQ(resolv_cache_get_subsampling_denom(TEST_NETID, EAI_OK), 0U);
EXPECT_EQ(resolv_cache_get_subsampling_denom(TEST_NETID, EAI_BADFLAGS), 0U);
EXPECT_EQ(resolv_cache_get_subsampling_denom(TEST_NETID, EAI_NODATA), 10U);
EXPECT_EQ(resolv_cache_get_subsampling_denom(TEST_NETID, EAI_SOCKTYPE), 0U);
EXPECT_THAT(resolv_cache_dump_subsampling_map(TEST_NETID),
testing::UnorderedElementsAreArray({"7:10", "10:0"}));
}
}