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

Unified Diff: ui/gl/gl_image_shared_memory_unittest.cc

Issue 1354483004: Re-land: ui: Add GLImage unit test framework. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Add clean up code Created 5 years, 3 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: ui/gl/gl_image_shared_memory_unittest.cc
diff --git a/ui/gl/gl_image_shared_memory_unittest.cc b/ui/gl/gl_image_shared_memory_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..44c8e97999669133dcf13088bbf29bd7cb57fd4c
--- /dev/null
+++ b/ui/gl/gl_image_shared_memory_unittest.cc
@@ -0,0 +1,43 @@
+// Copyright 2015 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 "base/memory/shared_memory.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "ui/gl/gl_image_shared_memory.h"
+#include "ui/gl/test/gl_image_test_template.h"
+
+namespace gfx {
+namespace {
+
+class GLImageSharedMemoryTestDelegate {
+ public:
+ scoped_refptr<GLImage> CreateSolidColorImage(const Size& size,
+ unsigned internalformat,
+ BufferFormat format,
+ const uint8_t color[4]) const {
+ DCHECK_EQ(NumberOfPlanesForBufferFormat(format), 1u);
+ base::SharedMemory shared_memory;
+ bool rv = shared_memory.CreateAndMapAnonymous(
+ BufferSizeForBufferFormat(size, format));
+ DCHECK(rv);
Daniele Castagna 2015/09/30 19:17:35 Isn't it preferred to use ASSERT instead of DCHECK
reveman 2015/10/01 04:01:36 Not sure how to do that outside the main body of t
+ GLImageTestSupport::SetBufferDataToColor(
+ size.width(), size.height(),
+ static_cast<int>(RowSizeForBufferFormat(size.width(), format, 0)),
+ format, color, reinterpret_cast<uint8_t*>(shared_memory.memory()));
+ scoped_refptr<GLImageSharedMemory> image(
+ new GLImageSharedMemory(size, internalformat));
+ rv = image->Initialize(
+ base::SharedMemory::DuplicateHandle(shared_memory.handle()),
+ GenericSharedMemoryId(0), format);
+ EXPECT_TRUE(rv);
+ return image;
+ }
+};
+
+INSTANTIATE_TYPED_TEST_CASE_P(GLImageSharedMemory,
+ GLImageTest,
+ GLImageSharedMemoryTestDelegate);
+
+} // namespace
+} // namespace gfx

Powered by Google App Engine
This is Rietveld 408576698