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

Side by Side Diff: ui/gl/gl_api_unittest.cc

Issue 1110923003: Added switch to disable specified GL extensions. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Added gl_api_unittest under gfx_unittests Created 5 years, 7 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "base/command_line.h"
6 #include "base/strings/string_split.h"
7 #include "base/strings/string_util.h"
8 #include "testing/gtest/include/gtest/gtest.h"
9 #include "ui/gl/gl_gl_api_implementation.h"
10 #include "ui/gl/gl_surface.h"
no sievers 2015/05/01 21:54:59 nit: gl_surface.h not needed. what about string_ut
David Yen 2015/05/01 22:34:38 Done.
11 #include "ui/gl/gl_switches.h"
12
13 namespace gfx {
14
15 class GLApiTest : public testing::Test {
16 public:
17 void SetUp() override {
18 g_fake_extension_string = "";
no sievers 2015/05/01 21:55:00 nit: no "g_" prefix here and for other static vari
David Yen 2015/05/01 22:34:38 Done.
19 g_num_fake_extension_strings = 0;
20 g_fake_extension_strings = nullptr;
21
22 driver_.fn.glGetStringFn = &FakeGetString;
23 driver_.fn.glGetStringiFn = &FakeGetStringi;
24 driver_.fn.glGetIntegervFn = &FakeGetIntegervFn;
25 }
26
27 void TearDown() override {
28 SetGLImplementation(kGLImplementationNone);
29 g_fake_extension_string = "";
30 g_num_fake_extension_strings = 0;
31 g_fake_extension_strings = nullptr;
32 }
33
34 void SetFakeExtensionString(const char* fake_string) {
35 SetGLImplementation(kGLImplementationDesktopGL);
36 g_fake_extension_string = fake_string;
37 }
38
39 void SetFakeExtensionStrings(const char** fake_strings, uint32_t count) {
40 SetGLImplementation(kGLImplementationDesktopGLCoreProfile);
41 g_num_fake_extension_strings = count;
42 g_fake_extension_strings = fake_strings;
43 }
44
45 static const GLubyte* FakeGetString(GLenum name) {
46 return reinterpret_cast<const GLubyte*>(g_fake_extension_string);
47 }
48
49 static void FakeGetIntegervFn(GLenum pname, GLint* params) {
50 *params = g_num_fake_extension_strings;
51 }
52
53 static const GLubyte* FakeGetStringi(GLenum name, GLuint index) {
54 return (index < g_num_fake_extension_strings) ?
55 reinterpret_cast<const GLubyte*>(g_fake_extension_strings[index]) :
56 nullptr;
57 }
58
59 const char* GetExtensions() {
60 return reinterpret_cast<const char*>(api_.glGetStringFn(GL_EXTENSIONS));
61 }
62
63 uint32_t GetNumExtensions() {
64 GLint num_extensions = 0;
65 api_.glGetIntegervFn(GL_NUM_EXTENSIONS, &num_extensions);
66 return static_cast<uint32_t>(num_extensions);
67 }
68
69 const char* GetExtensioni(uint32_t index) {
70 return reinterpret_cast<const char*>(api_.glGetStringiFn(GL_EXTENSIONS,
71 index));
72 }
73
74 protected:
75 static const char* g_fake_extension_string;
76
77 static uint32_t g_num_fake_extension_strings;
no sievers 2015/05/01 21:55:00 Actually can you make them non-static since you ar
David Yen 2015/05/01 22:34:38 They are being modified in static functions so the
no sievers 2015/05/01 22:44:49 Why do the functions have to be static? If they ar
David Yen 2015/05/01 22:46:03 FakeGetString, FakeGetIntegervFn, FakeGetStringi a
78 static const char** g_fake_extension_strings;
79
80 DriverGL driver_;
81 RealGLApi api_;
82 };
83
84 const char* GLApiTest::g_fake_extension_string = "";
85
86 uint32_t GLApiTest::g_num_fake_extension_strings = 0;
87 const char** GLApiTest::g_fake_extension_strings = nullptr;
88
89 TEST_F(GLApiTest, DisabledExtensionStringTest) {
90 static const char* kFakeExtensions = "GL_EXT_1 GL_EXT_2 GL_EXT_3 GL_EXT_4";
91 static const char* kFakeDisabledExtensions = "GL_EXT_1,GL_EXT_2,GL_FAKE";
92 static const char* kFilteredExtensions = "GL_EXT_3 GL_EXT_4";
93
94 SetFakeExtensionString(kFakeExtensions);
95 api_.Initialize(&driver_);
96
97 EXPECT_STREQ(kFakeExtensions, GetExtensions());
98
99 base::CommandLine command_line(base::CommandLine::NO_PROGRAM);
100 command_line.AppendSwitchASCII(switches::kDisableGLExtensions,
101 kFakeDisabledExtensions);
102 api_.InitializeWithCommandLine(&driver_, &command_line);
103
104 EXPECT_STREQ(kFilteredExtensions, GetExtensions());
105 }
106
107 TEST_F(GLApiTest, DisabledExtensionStringIndexTest) {
108 static const char* kFakeExtensions[] = {
109 "GL_EXT_1",
110 "GL_EXT_2",
111 "GL_EXT_3",
112 "GL_EXT_4"
113 };
114 static const char* kFakeDisabledExtensions = "GL_EXT_1,GL_EXT_2,GL_FAKE";
115 static const char* kFilteredExtensions[] = {
116 "GL_EXT_3",
117 "GL_EXT_4"
118 };
119
120 SetFakeExtensionStrings(kFakeExtensions, arraysize(kFakeExtensions));
121 api_.Initialize(&driver_);
122
123 EXPECT_EQ(arraysize(kFakeExtensions), GetNumExtensions());
124 for (uint32_t i = 0; i < arraysize(kFakeExtensions); ++i) {
125 EXPECT_STREQ(kFakeExtensions[i], GetExtensioni(i));
126 }
127
128 base::CommandLine command_line(base::CommandLine::NO_PROGRAM);
129 command_line.AppendSwitchASCII(switches::kDisableGLExtensions,
130 kFakeDisabledExtensions);
131 api_.InitializeWithCommandLine(&driver_, &command_line);
132
133 EXPECT_EQ(arraysize(kFilteredExtensions), GetNumExtensions());
134 for (uint32_t i = 0; i < arraysize(kFilteredExtensions); ++i) {
135 EXPECT_STREQ(kFilteredExtensions[i], GetExtensioni(i));
136 }
137 }
138
139 } // namespace gpu
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698