Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(453)

Unified Diff: google_apis/google_api_keys_mac_unittest.mm

Issue 2224473002: Add support for loading API keys from Info.plist on iOS and macOS. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix nits Created 4 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « google_apis/google_api_keys_mac.mm ('k') | google_apis/google_api_keys_unittest.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: google_apis/google_api_keys_mac_unittest.mm
diff --git a/google_apis/google_api_keys_mac_unittest.mm b/google_apis/google_api_keys_mac_unittest.mm
new file mode 100644
index 0000000000000000000000000000000000000000..90115c8d74811ef7da173948d08845d407d57866
--- /dev/null
+++ b/google_apis/google_api_keys_mac_unittest.mm
@@ -0,0 +1,124 @@
+// Copyright 2016 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.
+
+// Unit tests for implementation of google_api_keys namespace.
+//
+// Because the file deals with a lot of preprocessor defines and
+// optionally includes an internal header, the way we test is by
+// including the .cc file multiple times with different defines set.
+// This is a little unorthodox, but it lets us test the behavior as
+// close to unmodified as possible.
+
+#include "google_apis/google_api_keys_unittest.h"
+
+#include "base/mac/bundle_locations.h"
+#include "base/macros.h"
+#include "build/build_config.h"
+#include "google_apis/gaia/gaia_switches.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#import "third_party/ocmock/OCMock/OCMock.h"
+
+// We need to include everything included by google_api_keys.cc once
+// at global scope so that things like STL and classes from base don't
+// get defined when we re-include the google_api_keys.cc file
+// below. We used to include that file in its entirety here, but that
+// can cause problems if the linker decides the version of symbols
+// from that file included here is the "right" version.
+
+#include <stddef.h>
+
+#include <string>
+#include "base/command_line.h"
+#include "base/lazy_instance.h"
+#include "base/logging.h"
+#include "base/strings/stringize_macros.h"
+#include "google_apis/google_api_keys_mac.h"
+
+// After this test, for the remainder of this compilation unit, we
+// need official keys to not be used.
+#undef GOOGLE_CHROME_BUILD
+#undef USE_OFFICIAL_GOOGLE_API_KEYS
+
+// Override some keys using both preprocessor defines and Info.plist entries.
+// The Info.plist entries should win.
+namespace override_some_keys_info_plist {
+
+// We start every test by creating a clean environment for the
+// preprocessor defines used in google_api_keys.cc
+#undef DUMMY_API_TOKEN
+#undef GOOGLE_API_KEY
+#undef GOOGLE_CLIENT_ID_MAIN
+#undef GOOGLE_CLIENT_SECRET_MAIN
+#undef GOOGLE_CLIENT_ID_CLOUD_PRINT
+#undef GOOGLE_CLIENT_SECRET_CLOUD_PRINT
+#undef GOOGLE_CLIENT_ID_REMOTING
+#undef GOOGLE_CLIENT_SECRET_REMOTING
+#undef GOOGLE_CLIENT_ID_REMOTING_HOST
+#undef GOOGLE_CLIENT_SECRET_REMOTING_HOST
+#undef GOOGLE_DEFAULT_CLIENT_ID
+#undef GOOGLE_DEFAULT_CLIENT_SECRET
+
+#define GOOGLE_API_KEY "API_KEY"
+#define GOOGLE_CLIENT_ID_MAIN "ID_MAIN"
+#define GOOGLE_CLIENT_SECRET_MAIN "SECRET_MAIN"
+#define GOOGLE_CLIENT_ID_CLOUD_PRINT "ID_CLOUD_PRINT"
+#define GOOGLE_CLIENT_SECRET_CLOUD_PRINT "SECRET_CLOUD_PRINT"
+#define GOOGLE_CLIENT_ID_REMOTING "ID_REMOTING"
+#define GOOGLE_CLIENT_SECRET_REMOTING "SECRET_REMOTING"
+#define GOOGLE_CLIENT_ID_REMOTING_HOST "ID_REMOTING_HOST"
+#define GOOGLE_CLIENT_SECRET_REMOTING_HOST "SECRET_REMOTING_HOST"
+
+// Undef include guard so things get defined again, within this namespace.
+#undef GOOGLE_APIS_GOOGLE_API_KEYS_H_
+#undef GOOGLE_APIS_INTERNAL_GOOGLE_CHROME_API_KEYS_
+#include "google_apis/google_api_keys.cc"
+
+} // namespace override_all_keys_env
+
+TEST_F(GoogleAPIKeysTest, OverrideSomeKeysUsingInfoPlist) {
+ namespace testcase = override_some_keys_info_plist::google_apis;
+
+ id mock_bundle = [OCMockObject mockForClass:[NSBundle class]];
+ [[[mock_bundle stub] andReturn:@"plist-API_KEY"]
+ objectForInfoDictionaryKey:@"GOOGLE_API_KEY"];
+ [[[mock_bundle stub] andReturn:@"plist-ID_MAIN"]
+ objectForInfoDictionaryKey:@"GOOGLE_CLIENT_ID_MAIN"];
+ [[[mock_bundle stub] andReturn:nil] objectForInfoDictionaryKey:[OCMArg any]];
+ base::mac::SetOverrideFrameworkBundle(mock_bundle);
+
+ EXPECT_TRUE(testcase::HasKeysConfigured());
+
+ // Once the keys have been configured, the bundle isn't used anymore.
+ base::mac::SetOverrideFrameworkBundle(nil);
+
+ std::string api_key = testcase::g_api_key_cache.Get().api_key();
+ std::string id_main =
+ testcase::g_api_key_cache.Get().GetClientID(testcase::CLIENT_MAIN);
+ std::string secret_main =
+ testcase::g_api_key_cache.Get().GetClientSecret(testcase::CLIENT_MAIN);
+ std::string id_cloud_print =
+ testcase::g_api_key_cache.Get().GetClientID(testcase::CLIENT_CLOUD_PRINT);
+ std::string secret_cloud_print =
+ testcase::g_api_key_cache.Get().GetClientSecret(
+ testcase::CLIENT_CLOUD_PRINT);
+ std::string id_remoting =
+ testcase::g_api_key_cache.Get().GetClientID(testcase::CLIENT_REMOTING);
+ std::string secret_remoting = testcase::g_api_key_cache.Get().GetClientSecret(
+ testcase::CLIENT_REMOTING);
+ std::string id_remoting_host = testcase::g_api_key_cache.Get().GetClientID(
+ testcase::CLIENT_REMOTING_HOST);
+ std::string secret_remoting_host =
+ testcase::g_api_key_cache.Get().GetClientSecret(
+ testcase::CLIENT_REMOTING_HOST);
+
+ EXPECT_EQ("plist-API_KEY", api_key);
+ EXPECT_EQ("plist-ID_MAIN", id_main);
+ EXPECT_EQ("SECRET_MAIN", secret_main);
+ EXPECT_EQ("ID_CLOUD_PRINT", id_cloud_print);
+ EXPECT_EQ("SECRET_CLOUD_PRINT", secret_cloud_print);
+ EXPECT_EQ("ID_REMOTING", id_remoting);
+ EXPECT_EQ("SECRET_REMOTING", secret_remoting);
+ EXPECT_EQ("ID_REMOTING_HOST", id_remoting_host);
+ EXPECT_EQ("SECRET_REMOTING_HOST", secret_remoting_host);
+}
« no previous file with comments | « google_apis/google_api_keys_mac.mm ('k') | google_apis/google_api_keys_unittest.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698