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

Unified Diff: content/browser/android/scoped_surface_request_manager_unittest.cc

Issue 2285593002: Add ScopedSurfaceRequestManager (Closed)
Patch Set: Addressing comments 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
Index: content/browser/android/scoped_surface_request_manager_unittest.cc
diff --git a/content/browser/android/scoped_surface_request_manager_unittest.cc b/content/browser/android/scoped_surface_request_manager_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..c74c9ecc44ac34d91772d23bda79004f3359c388
--- /dev/null
+++ b/content/browser/android/scoped_surface_request_manager_unittest.cc
@@ -0,0 +1,211 @@
+// 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.
+
+#include "content/browser/android/scoped_surface_request_manager.h"
+
+#include "base/bind.h"
+#include "base/callback_forward.h"
+#include "base/run_loop.h"
+#include "content/public/test/test_browser_thread_bundle.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "ui/gl/android/scoped_java_surface.h"
+#include "ui/gl/android/surface_texture.h"
+
+namespace content {
+
+class ScopedSurfaceRequestManagerUnitTest : public testing::Test {
+ public:
+ ScopedSurfaceRequestManagerUnitTest() {
+ manager = ScopedSurfaceRequestManager::GetInstance();
+
+ // The need to reset the callbacks because the
+ // ScopedSurfaceRequestManager's lifetime outlive the tests.
+ manager->clear_callbacks_for_testing();
watk 2016/08/31 00:47:36 Can you create a new manager instead?
tguilbert 2016/08/31 17:58:56 Not really, the constructor is private. I would ha
+
+ surface_texture = gl::SurfaceTexture::Create(0);
+ dummy_request =
+ base::Bind(&ScopedSurfaceRequestManagerUnitTest::DummyCallback,
+ base::Unretained(this));
+ specific_logging_request =
+ base::Bind(&ScopedSurfaceRequestManagerUnitTest::LoggingCallback,
+ base::Unretained(this), kSpecificCallbackId);
+ }
+
+ // No-op callback.
+ void DummyCallback(gl::ScopedJavaSurface surface) {}
+
+ // Callback that updates |last_received_request| to allow differentiation
+ // between callback instances in tests.
+ void LoggingCallback(int request_id, gl::ScopedJavaSurface surface) {
+ last_received_request = request_id;
+ }
+
+ ScopedSurfaceRequestManager::ScopedSurfaceRequestCB dummy_request;
+ ScopedSurfaceRequestManager::ScopedSurfaceRequestCB specific_logging_request;
+ scoped_refptr<gl::SurfaceTexture> surface_texture;
+
+ uint64_t last_received_request;
+ const uint64_t kSpecificCallbackId = 1357;
+ const uint64_t kDummyToken = 0xABCDE;
+
+ ScopedSurfaceRequestManager* manager;
watk 2016/08/31 00:47:35 We usually use the underscore suffix for members i
tguilbert 2016/08/31 17:58:56 Interesting. TIL! In my mind underscores were only
+
+ content::TestBrowserThreadBundle thread_bundle_;
+
+ DISALLOW_COPY_AND_ASSIGN(ScopedSurfaceRequestManagerUnitTest);
+};
+
+// Makes sure we can successfully register a callback.
+TEST_F(ScopedSurfaceRequestManagerUnitTest, RegisterRequest_ShouldSucceed) {
+ EXPECT_EQ(0, manager->callback_count_for_testing());
+
+ manager->RegisterScopedSurfaceRequest(dummy_request);
+
+ EXPECT_EQ(1, manager->callback_count_for_testing());
+}
+
+// Makes sure we can successfully register multiple callbacks, and that they
+// return distinct request tokens.
+TEST_F(ScopedSurfaceRequestManagerUnitTest,
+ RegisterMultipleRequests_ShouldSucceed) {
+ EXPECT_EQ(0, manager->callback_count_for_testing());
watk 2016/08/31 00:47:35 This duplicates the assertion made in RegisterRequ
tguilbert 2016/08/31 17:58:56 Done.
+
+ uint64_t token1 = manager->RegisterScopedSurfaceRequest(dummy_request);
+ uint64_t token2 = manager->RegisterScopedSurfaceRequest(dummy_request);
+
+ EXPECT_EQ(2, manager->callback_count_for_testing());
+ EXPECT_NE(token1, token2);
+}
+
+// Makes sure GetInstance() is idempotent/that the class is a proper singleton.
+TEST_F(ScopedSurfaceRequestManagerUnitTest, VerifySingleton_ShouldSucceed) {
+ manager->RegisterScopedSurfaceRequest(dummy_request);
+
+ ScopedSurfaceRequestManager* manager_other =
+ ScopedSurfaceRequestManager::GetInstance();
+
+ EXPECT_EQ(manager, manager_other);
watk 2016/08/31 00:47:36 This test can be EXPECT_EQ(manager, ScopedSurfaceR
tguilbert 2016/08/31 17:58:56 Done.
+ EXPECT_EQ(1, manager_other->callback_count_for_testing());
+}
+
+// Makes sure we can unregister a callback after registering it.
+TEST_F(ScopedSurfaceRequestManagerUnitTest,
+ GetRegisteredRequest_ShouldSucceed) {
+ EXPECT_EQ(0, manager->callback_count_for_testing());
+
+ uint64_t token = manager->RegisterScopedSurfaceRequest(dummy_request);
+ EXPECT_EQ(1, manager->callback_count_for_testing());
+
+ manager->UnregisterScopedSurfaceRequest(token);
+
+ EXPECT_EQ(0, manager->callback_count_for_testing());
+}
+
+// Makes sure that unregistering a callback only affects the specified callback.
+TEST_F(ScopedSurfaceRequestManagerUnitTest,
+ GetRegisteredRequestFromMultipleRequests_ShouldSucceed) {
+ EXPECT_EQ(0, manager->callback_count_for_testing());
+
+ uint64_t token = manager->RegisterScopedSurfaceRequest(dummy_request);
+ manager->RegisterScopedSurfaceRequest(dummy_request);
+ EXPECT_EQ(2, manager->callback_count_for_testing());
+
+ manager->UnregisterScopedSurfaceRequest(token);
+
+ EXPECT_EQ(1, manager->callback_count_for_testing());
+}
+
+// Makes sure that unregistration is a noop permitted when there are no
+// registered requests.
+TEST_F(ScopedSurfaceRequestManagerUnitTest,
+ UnregisteredRequest_ShouldReturnNullCallback) {
+ EXPECT_EQ(0, manager->callback_count_for_testing());
+
+ manager->UnregisterScopedSurfaceRequest(123);
+
+ EXPECT_EQ(0, manager->callback_count_for_testing());
+}
+
+// Makes sure that unregistering and invalid |request_token| doesn't affect
watk 2016/08/31 00:47:36 an
tguilbert 2016/08/31 17:58:56 Done.
+// other registered callbacks.
+TEST_F(ScopedSurfaceRequestManagerUnitTest,
+ GetUnregisteredRequestFromMultipleRequests_ShouldReturnNullCallback) {
+ EXPECT_EQ(0, manager->callback_count_for_testing());
+
+ manager->RegisterScopedSurfaceRequest(dummy_request);
+
+ manager->UnregisterScopedSurfaceRequest(kDummyToken);
+
+ EXPECT_EQ(1, manager->callback_count_for_testing());
+}
+
+// Makes sure that trying to fulfill a request for an invalid |request_token|
+// does nothing, and does not affect other callbacks.
+TEST_F(ScopedSurfaceRequestManagerUnitTest,
+ FulfillUnregisteredRequest_ShouldDoNothing) {
+ EXPECT_EQ(0, manager->callback_count_for_testing());
+
+ manager->RegisterScopedSurfaceRequest(specific_logging_request);
+
+ last_received_request = 0;
+
+ manager->FulfillScopedSurfaceRequest(
+ kDummyToken, gl::ScopedJavaSurface(surface_texture.get()));
+
+ EXPECT_EQ(1, manager->callback_count_for_testing());
+ EXPECT_NE(kSpecificCallbackId, last_received_request);
+}
+
+// Makes sure that trying to fulfill a request fulfills the right request, and
+// does not affect other registered requests.
+TEST_F(ScopedSurfaceRequestManagerUnitTest,
+ FulfillRegisteredRequest_ShouldSucceed) {
+ EXPECT_EQ(0, manager->callback_count_for_testing());
+
+ const uint64_t kOtherCallbackId = 5678;
+
+ uint64_t specific_token =
+ manager->RegisterScopedSurfaceRequest(specific_logging_request);
+
+ manager->RegisterScopedSurfaceRequest(
+ base::Bind(&ScopedSurfaceRequestManagerUnitTest::LoggingCallback,
+ base::Unretained(this), kOtherCallbackId));
+
+ last_received_request = 0;
+
+ manager->FulfillScopedSurfaceRequest(
+ specific_token, gl::ScopedJavaSurface(surface_texture.get()));
+
+ EXPECT_EQ(1, manager->callback_count_for_testing());
+ EXPECT_EQ(kSpecificCallbackId, last_received_request);
+}
+
+// Makes sure that the code is resilient to empty callbacks.
watk 2016/08/31 00:47:35 Easier to DCHECK the request is not null IMO
tguilbert 2016/08/31 17:58:56 I added a DCHECK in the Register(), and replaced t
watk 2016/08/31 18:12:14 DCHECK in register SG. Yes, I'd say keep the if in
tguilbert 2016/08/31 20:44:44 Oops! Forgot about unregistered CBs returning null
+TEST_F(ScopedSurfaceRequestManagerUnitTest,
+ FulfillEmptyRequest_ShouldNotCrash) {
+ uint64_t token = manager->RegisterScopedSurfaceRequest(
+ base::Callback<void(gl::ScopedJavaSurface)>());
+
+ manager->FulfillScopedSurfaceRequest(
+ token, gl::ScopedJavaSurface(surface_texture.get()));
+
+ EXPECT_EQ(0, manager->callback_count_for_testing());
+}
+
+// Makes sure that the ScopedSurfaceRequestConduit implementation properly
+// fulfills requests.
+TEST_F(ScopedSurfaceRequestManagerUnitTest,
+ ForwardSurfaceTexture_ShouldFulfillRequest) {
+ uint64_t token =
+ manager->RegisterScopedSurfaceRequest(specific_logging_request);
+
+ last_received_request = 0;
watk 2016/08/31 00:47:35 initialize in the constructor/SetUp
tguilbert 2016/08/31 17:58:56 Done.
+
+ manager->ForwardSurfaceTextureForSurfaceRequest(token, surface_texture.get());
+
+ EXPECT_EQ(0, manager->callback_count_for_testing());
watk 2016/08/31 00:47:35 delete
tguilbert 2016/08/31 17:58:56 I feel like this one should stay, because, without
+ EXPECT_EQ(kSpecificCallbackId, last_received_request);
+}
+
+} // Content

Powered by Google App Engine
This is Rietveld 408576698