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

Unified Diff: gpu/command_buffer/service/gles2_cmd_decoder_unittest_textures.cc

Issue 2814583002: Service/ClientDiscardableManager (Closed)
Patch Set: Feedback Created 3 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 side-by-side diff with in-line comments
Download patch
Index: gpu/command_buffer/service/gles2_cmd_decoder_unittest_textures.cc
diff --git a/gpu/command_buffer/service/gles2_cmd_decoder_unittest_textures.cc b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_textures.cc
index 760974b17f7b4db8f254d2b75a4a696d93f53ee0..99eb588e7425d16f161dcaf5ea3552cf116d7ca8 100644
--- a/gpu/command_buffer/service/gles2_cmd_decoder_unittest_textures.cc
+++ b/gpu/command_buffer/service/gles2_cmd_decoder_unittest_textures.cc
@@ -21,6 +21,7 @@
#include "gpu/command_buffer/service/mailbox_manager.h"
#include "gpu/command_buffer/service/mocks.h"
#include "gpu/command_buffer/service/program_manager.h"
+#include "gpu/command_buffer/service/service_discardable_manager.h"
#include "gpu/command_buffer/service/test_helper.h"
#include "gpu/config/gpu_switches.h"
#include "testing/gtest/include/gtest/gtest.h"
@@ -35,6 +36,7 @@
using ::gl::MockGLInterface;
using ::testing::_;
+using ::testing::AnyNumber;
using ::testing::DoAll;
using ::testing::InSequence;
using ::testing::Invoke;
@@ -4859,6 +4861,88 @@ TEST_P(WebGL2DecoderTest, TexSwizzleDisabled) {
}
}
+TEST_P(GLES2DecoderTest, TestInitDiscardableTexture) {
+ EXPECT_EQ(0u, group().discardable_manager()->NumCacheEntriesForTesting());
+ DoInitializeDiscardableTextureCHROMIUM(client_texture_id_);
+ EXPECT_EQ(1u, group().discardable_manager()->NumCacheEntriesForTesting());
+}
+
+TEST_P(GLES2DecoderTest, TestInitInvalidDiscardableTexture) {
+ EXPECT_EQ(0u, group().discardable_manager()->NumCacheEntriesForTesting());
+ DoInitializeDiscardableTextureCHROMIUM(0);
+ EXPECT_EQ(0u, group().discardable_manager()->NumCacheEntriesForTesting());
+ EXPECT_EQ(GL_INVALID_VALUE, GetGLError());
+}
+
+TEST_P(GLES2DecoderTest, TestUnlockDiscardableTexture) {
+ const ContextGroup& context_group = group();
+ EXPECT_EQ(0u,
+ context_group.discardable_manager()->NumCacheEntriesForTesting());
+ DoInitializeDiscardableTextureCHROMIUM(client_texture_id_);
+ EXPECT_TRUE(context_group.discardable_manager()->IsEntryLockedForTesting(
+ client_texture_id_, context_group.texture_manager()));
+ DoUnlockDiscardableTextureCHROMIUM(client_texture_id_);
+ EXPECT_FALSE(context_group.discardable_manager()->IsEntryLockedForTesting(
+ client_texture_id_, context_group.texture_manager()));
+}
+
+TEST_P(GLES2DecoderTest, TestDeleteDiscardableTexture) {
+ EXPECT_EQ(0u, group().discardable_manager()->NumCacheEntriesForTesting());
+ DoInitializeDiscardableTextureCHROMIUM(client_texture_id_);
+ EXPECT_EQ(1u, group().discardable_manager()->NumCacheEntriesForTesting());
+ DoDeleteTexture(client_texture_id_, kServiceTextureId);
+ EXPECT_EQ(0u, group().discardable_manager()->NumCacheEntriesForTesting());
+}
+
+TEST_P(GLES2DecoderManualInitTest,
+ TestDiscardableTextureUnusableWhileUnlocked) {
+ base::CommandLine command_line(0, NULL);
+ InitState init;
+ init.bind_generates_resource = false;
+ InitDecoderWithCommandLine(init, &command_line);
+
+ DoInitializeDiscardableTextureCHROMIUM(client_texture_id_);
+ DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kServiceTextureId);
+ EXPECT_EQ(GL_NO_ERROR, GetGLError());
+ EXPECT_CALL(*gl_, BindTexture(GL_TEXTURE_2D, 0)).RetiresOnSaturation();
+ DoUnlockDiscardableTextureCHROMIUM(client_texture_id_);
+ {
+ // Avoid DoBindTexture, as we expect failure.
+ cmds::BindTexture cmd;
+ cmd.Init(GL_TEXTURE_2D, client_texture_id_);
+ EXPECT_EQ(error::kNoError, ExecuteCmd(cmd));
+ }
+ EXPECT_EQ(GL_INVALID_OPERATION, GetGLError());
+ DoLockDiscardableTextureCHROMIUM(client_texture_id_);
+ DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kServiceTextureId);
+ EXPECT_EQ(GL_NO_ERROR, GetGLError());
+}
+
+TEST_P(GLES2DecoderTest, TestDiscardableTextureBindGeneratesUnlocked) {
+ DoInitializeDiscardableTextureCHROMIUM(client_texture_id_);
+ DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kServiceTextureId);
+ EXPECT_EQ(GL_NO_ERROR, GetGLError());
+ // Unlock will unbind the texture.
+ EXPECT_CALL(*gl_, BindTexture(GL_TEXTURE_2D, 0)).RetiresOnSaturation();
+ DoUnlockDiscardableTextureCHROMIUM(client_texture_id_);
+
+ // At this point, the texture is unlocked and unusable. Bind will generate a
+ // new resource.
+ EXPECT_CALL(*gl_, GenTextures(_, _))
+ .WillOnce(SetArgPointee<1>(kNewServiceId))
+ .RetiresOnSaturation();
+ DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kNewServiceId);
+ EXPECT_EQ(GL_NO_ERROR, GetGLError());
+
+ // Re-locking should unbind and overwrite the generated resource (leading to
+ // it's deletion).
piman 2017/05/12 18:01:27 nit: not sure about this comment... I think the be
ericrk 2017/05/12 20:24:00 yup. Updated
+ EXPECT_CALL(*gl_, DeleteTextures(1, Pointee(kServiceTextureId)))
+ .RetiresOnSaturation();
+ DoLockDiscardableTextureCHROMIUM(client_texture_id_);
+ DoBindTexture(GL_TEXTURE_2D, client_texture_id_, kNewServiceId);
+ EXPECT_EQ(GL_NO_ERROR, GetGLError());
+}
+
// TODO(gman): Complete this test.
// TEST_P(GLES2DecoderTest, CompressedTexImage2DGLError) {
// }

Powered by Google App Engine
This is Rietveld 408576698