blob: 3d50eba2978787294ae3378dbee64043f85cf524 [file] [log] [blame]
// Copyright 2018 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "extensions/common/permissions/api_permission.h"
#include <map>
#include <set>
#include <string>
#include "base/files/file_path.h"
#include "base/files/file_util.h"
#include "base/path_service.h"
#include "base/strings/stringprintf.h"
#include "base/test/metrics/histogram_enum_reader.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace extensions {
// Tests that the ExtensionPermission3 enum in enums.xml exactly matches the
// APIPermission::ID enum in C++.
TEST(ExtensionAPIPermissionTest, CheckEnums) {
base::Optional<base::HistogramEnumEntryMap> enums =
base::ReadEnumFromEnumsXml("ExtensionPermission3");
ASSERT_TRUE(enums);
// The number of enums in the histogram entry should be equal to the number of
// enums in the C++ file.
EXPECT_EQ(enums->size(), APIPermission::kEnumBoundary);
base::FilePath src_root;
ASSERT_TRUE(base::PathService::Get(base::DIR_SOURCE_ROOT, &src_root));
base::FilePath permission_histogram_value =
src_root.AppendASCII("extensions")
.AppendASCII("common")
.AppendASCII("permissions")
.AppendASCII("api_permission.h");
ASSERT_TRUE(base::PathExists(permission_histogram_value));
std::string file_contents;
ASSERT_TRUE(
base::ReadFileToString(permission_histogram_value, &file_contents));
for (const auto& entry : *enums) {
// Check that the C++ file has a definition equal to the histogram file.
// For now, we do this in a simple, but reasonably effective, manner:
// expecting to find the string "ENTRY = <value>" somewhere in the file.
std::string expected_string =
base::StringPrintf("%s = %d", entry.second.c_str(), entry.first);
EXPECT_NE(std::string::npos, file_contents.find(expected_string))
<< "Failed to find entry " << entry.second << " with value "
<< entry.first;
}
}
} // namespace extensions