| Index: third_party/WebKit/Source/platform/graphics/Canvas2DLayerBridgeTest.cpp
|
| diff --git a/third_party/WebKit/Source/platform/graphics/Canvas2DLayerBridgeTest.cpp b/third_party/WebKit/Source/platform/graphics/Canvas2DLayerBridgeTest.cpp
|
| index 955971852239e57a4cab3f5762f5ed5c88df8278..9773207dca17e3858729cb390b3b0064fe9c162a 100644
|
| --- a/third_party/WebKit/Source/platform/graphics/Canvas2DLayerBridgeTest.cpp
|
| +++ b/third_party/WebKit/Source/platform/graphics/Canvas2DLayerBridgeTest.cpp
|
| @@ -31,8 +31,7 @@
|
| #include "platform/WaitableEvent.h"
|
| #include "platform/graphics/ImageBuffer.h"
|
| #include "platform/graphics/UnacceleratedImageBufferSurface.h"
|
| -#include "platform/graphics/test/MockGLES2Interface.h"
|
| -#include "platform/graphics/test/MockWebGraphicsContext3D.h"
|
| +#include "platform/graphics/test/FakeGLES2Interface.h"
|
| #include "public/platform/Platform.h"
|
| #include "public/platform/WebExternalBitmap.h"
|
| #include "public/platform/WebGraphicsContext3DProvider.h"
|
| @@ -63,18 +62,10 @@ namespace blink {
|
|
|
| namespace {
|
|
|
| -class MockCanvasContext : public MockWebGraphicsContext3D {
|
| +class FakeWebGraphicsContext3DProvider : public WebGraphicsContext3DProvider {
|
| public:
|
| - MOCK_METHOD0(flush, void(void));
|
| - MOCK_METHOD0(createTexture, unsigned(void));
|
| - MOCK_METHOD1(deleteTexture, void(unsigned));
|
| -};
|
| -
|
| -class MockWebGraphicsContext3DProvider : public WebGraphicsContext3DProvider {
|
| -public:
|
| - MockWebGraphicsContext3DProvider(WebGraphicsContext3D* context3d, gpu::gles2::GLES2Interface* gl)
|
| - : m_context3d(context3d)
|
| - , m_gl(gl)
|
| + FakeWebGraphicsContext3DProvider(gpu::gles2::GLES2Interface* gl)
|
| + : m_gl(gl)
|
| {
|
| RefPtr<const GrGLInterface> glInterface = adoptRef(GrGLCreateNullInterface());
|
| m_grContext = adoptRef(GrContext::Create(kOpenGL_GrBackend, reinterpret_cast<GrBackendContext>(glInterface.get())));
|
| @@ -82,7 +73,7 @@ public:
|
|
|
| WebGraphicsContext3D* context3d() override
|
| {
|
| - return m_context3d;
|
| + return nullptr;
|
| }
|
|
|
| GrContext* grContext() override
|
| @@ -98,7 +89,6 @@ public:
|
| void setLostContextCallback(WebClosure) override {}
|
|
|
| private:
|
| - WebGraphicsContext3D* m_context3d;
|
| gpu::gles2::GLES2Interface* m_gl;
|
| RefPtr<GrContext> m_grContext;
|
| };
|
| @@ -156,7 +146,7 @@ public:
|
|
|
| class Canvas2DLayerBridgeTest : public Test {
|
| public:
|
| - PassRefPtr<Canvas2DLayerBridge> makeBridge(PassOwnPtr<MockWebGraphicsContext3DProvider> provider, const IntSize& size, Canvas2DLayerBridge::AccelerationMode accelerationMode)
|
| + PassRefPtr<Canvas2DLayerBridge> makeBridge(PassOwnPtr<FakeWebGraphicsContext3DProvider> provider, const IntSize& size, Canvas2DLayerBridge::AccelerationMode accelerationMode)
|
| {
|
| return adoptRef(new Canvas2DLayerBridge(provider, size, 0, NonOpaque, accelerationMode));
|
| }
|
| @@ -164,122 +154,86 @@ public:
|
| protected:
|
| void fullLifecycleTest()
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| - OwnPtr<MockWebGraphicsContext3DProvider> mainMockProvider = adoptPtr(new MockWebGraphicsContext3DProvider(&mainMock, &mockGL));
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| + FakeGLES2Interface gl;
|
| + OwnPtr<FakeWebGraphicsContext3DProvider> contextProvider = adoptPtr(new FakeWebGraphicsContext3DProvider(&gl));
|
|
|
| - {
|
| - Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(mainMockProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::DisableAcceleration)));
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| -
|
| - const GrGLTextureInfo* textureInfo = skia::GrBackendObjectToGrGLTextureInfo(bridge->newImageSnapshot(PreferAcceleration, SnapshotReasonUnknown)->getTextureHandle(true));
|
| - EXPECT_EQ(textureInfo, nullptr);
|
| + Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(contextProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::DisableAcceleration)));
|
|
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| - } // bridge goes out of scope here
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| + const GrGLTextureInfo* textureInfo = skia::GrBackendObjectToGrGLTextureInfo(bridge->newImageSnapshot(PreferAcceleration, SnapshotReasonUnknown)->getTextureHandle(true));
|
| + EXPECT_EQ(textureInfo, nullptr);
|
| + bridge.clear();
|
| }
|
|
|
| void fallbackToSoftwareIfContextLost()
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| - OwnPtr<MockWebGraphicsContext3DProvider> mainMockProvider = adoptPtr(new MockWebGraphicsContext3DProvider(&mainMock, &mockGL));
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| + FakeGLES2Interface gl;
|
| + OwnPtr<FakeWebGraphicsContext3DProvider> contextProvider = adoptPtr(new FakeWebGraphicsContext3DProvider(&gl));
|
|
|
| - {
|
| - mockGL.setIsContextLost(true);
|
| - Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(mainMockProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::EnableAcceleration)));
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| - EXPECT_TRUE(bridge->checkSurfaceValid());
|
| - EXPECT_FALSE(bridge->isAccelerated());
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| - }
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| + gl.setIsContextLost(true);
|
| + Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(contextProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::EnableAcceleration)));
|
| + EXPECT_TRUE(bridge->checkSurfaceValid());
|
| + EXPECT_FALSE(bridge->isAccelerated());
|
| }
|
|
|
| void fallbackToSoftwareOnFailedTextureAlloc()
|
| {
|
| - MockCanvasContext mainMock;
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| -
|
| {
|
| - // No fallback case
|
| - MockGLES2Interface mockGL;
|
| - OwnPtr<MockWebGraphicsContext3DProvider> mainMockProvider = adoptPtr(new MockWebGraphicsContext3DProvider(&mainMock, &mockGL));
|
| - Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(mainMockProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::EnableAcceleration)));
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| + // No fallback case.
|
| + FakeGLES2Interface gl;
|
| + OwnPtr<FakeWebGraphicsContext3DProvider> contextProvider = adoptPtr(new FakeWebGraphicsContext3DProvider(&gl));
|
| + Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(contextProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::EnableAcceleration)));
|
| EXPECT_TRUE(bridge->checkSurfaceValid());
|
| EXPECT_TRUE(bridge->isAccelerated());
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| RefPtr<SkImage> snapshot = bridge->newImageSnapshot(PreferAcceleration, SnapshotReasonUnknown);
|
| EXPECT_TRUE(bridge->isAccelerated());
|
| EXPECT_TRUE(snapshot->isTextureBacked());
|
| }
|
|
|
| {
|
| - // Fallback case
|
| - MockGLES2Interface mockGL;
|
| - OwnPtr<MockWebGraphicsContext3DProvider> mainMockProvider = adoptPtr(new MockWebGraphicsContext3DProvider(&mainMock, &mockGL));
|
| - GrContext* gr = mainMockProvider->grContext();
|
| - Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(mainMockProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::EnableAcceleration)));
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| + // Fallback case.
|
| + FakeGLES2Interface gl;
|
| + OwnPtr<FakeWebGraphicsContext3DProvider> contextProvider = adoptPtr(new FakeWebGraphicsContext3DProvider(&gl));
|
| + GrContext* gr = contextProvider->grContext();
|
| + Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(contextProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::EnableAcceleration)));
|
| EXPECT_TRUE(bridge->checkSurfaceValid());
|
| EXPECT_TRUE(bridge->isAccelerated()); // We don't yet know that allocation will fail
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| - gr->abandonContext(); // This will cause SkSurface_Gpu creation to fail without Canvas2DLayerBridge otherwise detecting that anything was disabled.
|
| + // This will cause SkSurface_Gpu creation to fail without
|
| + // Canvas2DLayerBridge otherwise detecting that anything was disabled.
|
| + gr->abandonContext();
|
| RefPtr<SkImage> snapshot = bridge->newImageSnapshot(PreferAcceleration, SnapshotReasonUnknown);
|
| EXPECT_FALSE(bridge->isAccelerated());
|
| EXPECT_FALSE(snapshot->isTextureBacked());
|
| }
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| }
|
|
|
| void noDrawOnContextLostTest()
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| - OwnPtr<MockWebGraphicsContext3DProvider> mainMockProvider = adoptPtr(new MockWebGraphicsContext3DProvider(&mainMock, &mockGL));
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| -
|
| - {
|
| - Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(mainMockProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::ForceAccelerationForTesting)));
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| - EXPECT_TRUE(bridge->checkSurfaceValid());
|
| - SkPaint paint;
|
| - uint32_t genID = bridge->getOrCreateSurface()->generationID();
|
| - bridge->canvas()->drawRect(SkRect::MakeXYWH(0, 0, 1, 1), paint);
|
| - EXPECT_EQ(genID, bridge->getOrCreateSurface()->generationID());
|
| - mockGL.setIsContextLost(true);
|
| - EXPECT_EQ(genID, bridge->getOrCreateSurface()->generationID());
|
| - bridge->canvas()->drawRect(SkRect::MakeXYWH(0, 0, 1, 1), paint);
|
| - EXPECT_EQ(genID, bridge->getOrCreateSurface()->generationID());
|
| - EXPECT_FALSE(bridge->checkSurfaceValid()); // This results in the internal surface being torn down in response to the context loss
|
| - EXPECT_EQ(nullptr, bridge->getOrCreateSurface());
|
| - // The following passes by not crashing
|
| - bridge->canvas()->drawRect(SkRect::MakeXYWH(0, 0, 1, 1), paint);
|
| - bridge->flush();
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| - }
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| + FakeGLES2Interface gl;
|
| + OwnPtr<FakeWebGraphicsContext3DProvider> contextProvider = adoptPtr(new FakeWebGraphicsContext3DProvider(&gl));
|
| +
|
| + Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(contextProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::ForceAccelerationForTesting)));
|
| + EXPECT_TRUE(bridge->checkSurfaceValid());
|
| + SkPaint paint;
|
| + uint32_t genID = bridge->getOrCreateSurface()->generationID();
|
| + bridge->canvas()->drawRect(SkRect::MakeXYWH(0, 0, 1, 1), paint);
|
| + EXPECT_EQ(genID, bridge->getOrCreateSurface()->generationID());
|
| + gl.setIsContextLost(true);
|
| + EXPECT_EQ(genID, bridge->getOrCreateSurface()->generationID());
|
| + bridge->canvas()->drawRect(SkRect::MakeXYWH(0, 0, 1, 1), paint);
|
| + EXPECT_EQ(genID, bridge->getOrCreateSurface()->generationID());
|
| + // This results in the internal surface being torn down in response to the context loss.
|
| + EXPECT_FALSE(bridge->checkSurfaceValid());
|
| + EXPECT_EQ(nullptr, bridge->getOrCreateSurface());
|
| + // The following passes by not crashing
|
| + bridge->canvas()->drawRect(SkRect::MakeXYWH(0, 0, 1, 1), paint);
|
| + bridge->flush();
|
| }
|
|
|
| void prepareMailboxWithBitmapTest()
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| - OwnPtr<MockWebGraphicsContext3DProvider> mainMockProvider = adoptPtr(new MockWebGraphicsContext3DProvider(&mainMock, &mockGL));
|
| - Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(mainMockProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::ForceAccelerationForTesting)));
|
| + FakeGLES2Interface gl;
|
| + OwnPtr<FakeWebGraphicsContext3DProvider> contextProvider = adoptPtr(new FakeWebGraphicsContext3DProvider(&gl));
|
| + Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(contextProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::ForceAccelerationForTesting)));
|
| bridge->m_lastImageId = 1;
|
|
|
| NullWebExternalBitmap bitmap;
|
| @@ -289,31 +243,31 @@ protected:
|
|
|
| void prepareMailboxAndLoseResourceTest()
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| bool lostResource = true;
|
|
|
| // Prepare a mailbox, then report the resource as lost.
|
| // This test passes by not crashing and not triggering assertions.
|
| {
|
| + FakeGLES2Interface gl;
|
| + OwnPtr<FakeWebGraphicsContext3DProvider> contextProvider = adoptPtr(new FakeWebGraphicsContext3DProvider(&gl));
|
| + Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(contextProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::ForceAccelerationForTesting)));
|
| WebExternalTextureMailbox mailbox;
|
| - OwnPtr<MockWebGraphicsContext3DProvider> mainMockProvider = adoptPtr(new MockWebGraphicsContext3DProvider(&mainMock, &mockGL));
|
| - Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(mainMockProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::ForceAccelerationForTesting)));
|
| bridge->prepareMailbox(&mailbox, 0);
|
| bridge->mailboxReleased(mailbox, lostResource);
|
| }
|
|
|
| - // Retry with mailbox released while bridge destruction is in progress
|
| + // Retry with mailbox released while bridge destruction is in progress.
|
| {
|
| - OwnPtr<MockWebGraphicsContext3DProvider> mainMockProvider = adoptPtr(new MockWebGraphicsContext3DProvider(&mainMock, &mockGL));
|
| + FakeGLES2Interface gl;
|
| + OwnPtr<FakeWebGraphicsContext3DProvider> contextProvider = adoptPtr(new FakeWebGraphicsContext3DProvider(&gl));
|
| WebExternalTextureMailbox mailbox;
|
| Canvas2DLayerBridge* rawBridge;
|
| {
|
| - Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(mainMockProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::ForceAccelerationForTesting)));
|
| + Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(contextProvider.release(), IntSize(300, 150), 0, NonOpaque, Canvas2DLayerBridge::ForceAccelerationForTesting)));
|
| bridge->prepareMailbox(&mailbox, 0);
|
| rawBridge = bridge.get();
|
| - } // bridge goes out of scope, but object is kept alive by self references
|
| - // before fixing crbug.com/411864, the following line you cause a memory use after free
|
| + } // bridge goes out of scope, but object is kept alive by self references.
|
| + // Before fixing crbug.com/411864, the following line you cause a memory use after free
|
| // that sometimes causes a crash in normal builds and crashes consistently with ASAN.
|
| rawBridge->mailboxReleased(mailbox, lostResource); // This should self-destruct the bridge.
|
| }
|
| @@ -321,36 +275,27 @@ protected:
|
|
|
| void accelerationHintTest()
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| {
|
| -
|
| - OwnPtr<MockWebGraphicsContext3DProvider> mainMockProvider = adoptPtr(new MockWebGraphicsContext3DProvider(&mainMock, &mockGL));
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| - Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(mainMockProvider.release(), IntSize(300, 300), 0, NonOpaque, Canvas2DLayerBridge::EnableAcceleration)));
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| + FakeGLES2Interface gl;
|
| + OwnPtr<FakeWebGraphicsContext3DProvider> contextProvider = adoptPtr(new FakeWebGraphicsContext3DProvider(&gl));
|
| + Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(contextProvider.release(), IntSize(300, 300), 0, NonOpaque, Canvas2DLayerBridge::EnableAcceleration)));
|
| SkPaint paint;
|
| bridge->canvas()->drawRect(SkRect::MakeXYWH(0, 0, 1, 1), paint);
|
| RefPtr<SkImage> image = bridge->newImageSnapshot(PreferAcceleration, SnapshotReasonUnknown);
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| EXPECT_TRUE(bridge->checkSurfaceValid());
|
| EXPECT_TRUE(bridge->isAccelerated());
|
| }
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
|
|
| {
|
| - OwnPtr<MockWebGraphicsContext3DProvider> mainMockProvider = adoptPtr(new MockWebGraphicsContext3DProvider(&mainMock, &mockGL));
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| - Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(mainMockProvider.release(), IntSize(300, 300), 0, NonOpaque, Canvas2DLayerBridge::EnableAcceleration)));
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| + FakeGLES2Interface gl;
|
| + OwnPtr<FakeWebGraphicsContext3DProvider> contextProvider = adoptPtr(new FakeWebGraphicsContext3DProvider(&gl));
|
| + Canvas2DLayerBridgePtr bridge(adoptRef(new Canvas2DLayerBridge(contextProvider.release(), IntSize(300, 300), 0, NonOpaque, Canvas2DLayerBridge::EnableAcceleration)));
|
| SkPaint paint;
|
| bridge->canvas()->drawRect(SkRect::MakeXYWH(0, 0, 1, 1), paint);
|
| RefPtr<SkImage> image = bridge->newImageSnapshot(PreferNoAcceleration, SnapshotReasonUnknown);
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| EXPECT_TRUE(bridge->checkSurfaceValid());
|
| EXPECT_FALSE(bridge->isAccelerated());
|
| }
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| }
|
| };
|
|
|
| @@ -396,10 +341,10 @@ public:
|
| virtual ~MockLogger() { }
|
| };
|
|
|
| -void runCreateBridgeTask(Canvas2DLayerBridgePtr* bridgePtr, MockCanvasContext* mockCanvasContext, gpu::gles2::GLES2Interface* gl, Canvas2DLayerBridgeTest* testHost, WaitableEvent* doneEvent)
|
| +void runCreateBridgeTask(Canvas2DLayerBridgePtr* bridgePtr, gpu::gles2::GLES2Interface* gl, Canvas2DLayerBridgeTest* testHost, WaitableEvent* doneEvent)
|
| {
|
| - OwnPtr<MockWebGraphicsContext3DProvider> mainMockProvider = adoptPtr(new MockWebGraphicsContext3DProvider(mockCanvasContext, gl));
|
| - *bridgePtr = testHost->makeBridge(mainMockProvider.release(), IntSize(300, 300), Canvas2DLayerBridge::EnableAcceleration);
|
| + OwnPtr<FakeWebGraphicsContext3DProvider> contextProvider = adoptPtr(new FakeWebGraphicsContext3DProvider(gl));
|
| + *bridgePtr = testHost->makeBridge(contextProvider.release(), IntSize(300, 300), Canvas2DLayerBridge::EnableAcceleration);
|
| // draw+flush to trigger the creation of a GPU surface
|
| (*bridgePtr)->didDraw(FloatRect(0, 0, 1, 1));
|
| (*bridgePtr)->finalizeFrame(FloatRect(0, 0, 1, 1));
|
| @@ -407,14 +352,13 @@ void runCreateBridgeTask(Canvas2DLayerBridgePtr* bridgePtr, MockCanvasContext* m
|
| doneEvent->signal();
|
| }
|
|
|
| -void postAndWaitCreateBridgeTask(const WebTraceLocation& location, WebThread* testThread, Canvas2DLayerBridgePtr* bridgePtr, MockCanvasContext* mockCanvasContext, gpu::gles2::GLES2Interface* gl, Canvas2DLayerBridgeTest* testHost)
|
| +void postAndWaitCreateBridgeTask(const WebTraceLocation& location, WebThread* testThread, Canvas2DLayerBridgePtr* bridgePtr, gpu::gles2::GLES2Interface* gl, Canvas2DLayerBridgeTest* testHost)
|
| {
|
| OwnPtr<WaitableEvent> bridgeCreatedEvent = adoptPtr(new WaitableEvent());
|
| testThread->getWebTaskRunner()->postTask(
|
| location,
|
| threadSafeBind(&runCreateBridgeTask,
|
| AllowCrossThreadAccess(bridgePtr),
|
| - AllowCrossThreadAccess(mockCanvasContext),
|
| AllowCrossThreadAccess(gl),
|
| AllowCrossThreadAccess(testHost),
|
| AllowCrossThreadAccess(bridgeCreatedEvent.get())));
|
| @@ -488,14 +432,13 @@ TEST_F(Canvas2DLayerBridgeTest, HibernationLifeCycle)
|
| TEST_F(Canvas2DLayerBridgeTest, DISABLED_HibernationLifeCycle)
|
| #endif
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| + FakeGLES2Interface gl;
|
| OwnPtr<WebThread> testThread = adoptPtr(Platform::current()->createThread("TestThread"));
|
|
|
| // The Canvas2DLayerBridge has to be created on the thread that will use it
|
| // to avoid WeakPtr thread check issues.
|
| Canvas2DLayerBridgePtr bridge;
|
| - postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &mainMock, &mockGL, this);
|
| + postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &gl, this);
|
|
|
| // Register an alternate Logger for tracking hibernation events
|
| OwnPtr<MockLogger> mockLogger = adoptPtr(new MockLogger);
|
| @@ -525,8 +468,6 @@ TEST_F(Canvas2DLayerBridgeTest, DISABLED_HibernationLifeCycle)
|
| // Tear down the bridge on the thread so that 'bridge' can go out of scope
|
| // without crashing due to thread checks
|
| postAndWaitDestroyBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge);
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| }
|
|
|
| #if CANVAS2D_HIBERNATION_ENABLED
|
| @@ -535,14 +476,13 @@ TEST_F(Canvas2DLayerBridgeTest, HibernationReEntry)
|
| TEST_F(Canvas2DLayerBridgeTest, DISABLED_HibernationReEntry)
|
| #endif
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| + FakeGLES2Interface gl;
|
| OwnPtr<WebThread> testThread = adoptPtr(Platform::current()->createThread("TestThread"));
|
|
|
| // The Canvas2DLayerBridge has to be created on the thread that will use it
|
| // to avoid WeakPtr thread check issues.
|
| Canvas2DLayerBridgePtr bridge;
|
| - postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &mainMock, &mockGL, this);
|
| + postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &gl, this);
|
|
|
| // Register an alternate Logger for tracking hibernation events
|
| OwnPtr<MockLogger> mockLogger = adoptPtr(new MockLogger);
|
| @@ -577,9 +517,6 @@ TEST_F(Canvas2DLayerBridgeTest, DISABLED_HibernationReEntry)
|
| // Tear down the bridge on the thread so that 'bridge' can go out of scope
|
| // without crashing due to thread checks
|
| postAndWaitDestroyBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge);
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| -
|
| }
|
|
|
| #if CANVAS2D_HIBERNATION_ENABLED
|
| @@ -588,14 +525,13 @@ TEST_F(Canvas2DLayerBridgeTest, HibernationLifeCycleWithDeferredRenderingDisable
|
| TEST_F(Canvas2DLayerBridgeTest, DISABLED_HibernationLifeCycleWithDeferredRenderingDisabled)
|
| #endif
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| + FakeGLES2Interface gl;
|
| OwnPtr<WebThread> testThread = adoptPtr(Platform::current()->createThread("TestThread"));
|
|
|
| // The Canvas2DLayerBridge has to be created on the thread that will use it
|
| // to avoid WeakPtr thread check issues.
|
| Canvas2DLayerBridgePtr bridge;
|
| - postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &mainMock, &mockGL, this);
|
| + postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &gl, this);
|
| bridge->disableDeferral(DisableDeferralReasonUnknown);
|
| MockImageBuffer mockImageBuffer;
|
| EXPECT_CALL(mockImageBuffer, resetCanvas(_)).Times(AnyNumber());
|
| @@ -632,8 +568,6 @@ TEST_F(Canvas2DLayerBridgeTest, DISABLED_HibernationLifeCycleWithDeferredRenderi
|
| // Tear down the bridge on the thread so that 'bridge' can go out of scope
|
| // without crashing due to thread checks
|
| postAndWaitDestroyBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge);
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| }
|
|
|
| void runRenderingTask(Canvas2DLayerBridge* bridge, WaitableEvent* doneEvent)
|
| @@ -661,14 +595,13 @@ TEST_F(Canvas2DLayerBridgeTest, BackgroundRenderingWhileHibernating)
|
| TEST_F(Canvas2DLayerBridgeTest, DISABLED_BackgroundRenderingWhileHibernating)
|
| #endif
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| + FakeGLES2Interface gl;
|
| OwnPtr<WebThread> testThread = adoptPtr(Platform::current()->createThread("TestThread"));
|
|
|
| // The Canvas2DLayerBridge has to be created on the thread that will use it
|
| // to avoid WeakPtr thread check issues.
|
| Canvas2DLayerBridgePtr bridge;
|
| - postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &mainMock, &mockGL, this);
|
| + postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &gl, this);
|
|
|
| // Register an alternate Logger for tracking hibernation events
|
| OwnPtr<MockLogger> mockLogger = adoptPtr(new MockLogger);
|
| @@ -705,8 +638,6 @@ TEST_F(Canvas2DLayerBridgeTest, DISABLED_BackgroundRenderingWhileHibernating)
|
| // Tear down the bridge on the thread so that 'bridge' can go out of scope
|
| // without crashing due to thread checks
|
| postAndWaitDestroyBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge);
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| }
|
|
|
| #if CANVAS2D_HIBERNATION_ENABLED && CANVAS2D_BACKGROUND_RENDER_SWITCH_TO_CPU
|
| @@ -715,14 +646,13 @@ TEST_F(Canvas2DLayerBridgeTest, BackgroundRenderingWhileHibernatingWithDeferredR
|
| TEST_F(Canvas2DLayerBridgeTest, DISABLED_BackgroundRenderingWhileHibernatingWithDeferredRenderingDisabled)
|
| #endif
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| + FakeGLES2Interface gl;
|
| OwnPtr<WebThread> testThread = adoptPtr(Platform::current()->createThread("TestThread"));
|
|
|
| // The Canvas2DLayerBridge has to be created on the thread that will use it
|
| // to avoid WeakPtr thread check issues.
|
| Canvas2DLayerBridgePtr bridge;
|
| - postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &mainMock, &mockGL, this);
|
| + postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &gl, this);
|
| MockImageBuffer mockImageBuffer;
|
| EXPECT_CALL(mockImageBuffer, resetCanvas(_)).Times(AnyNumber());
|
| bridge->setImageBuffer(&mockImageBuffer);
|
| @@ -777,14 +707,13 @@ TEST_F(Canvas2DLayerBridgeTest, DisableDeferredRenderingWhileHibernating)
|
| TEST_F(Canvas2DLayerBridgeTest, DISABLED_DisableDeferredRenderingWhileHibernating)
|
| #endif
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| + FakeGLES2Interface gl;
|
| OwnPtr<WebThread> testThread = adoptPtr(Platform::current()->createThread("TestThread"));
|
|
|
| // The Canvas2DLayerBridge has to be created on the thread that will use it
|
| // to avoid WeakPtr thread check issues.
|
| Canvas2DLayerBridgePtr bridge;
|
| - postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &mainMock, &mockGL, this);
|
| + postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &gl, this);
|
| MockImageBuffer mockImageBuffer;
|
| EXPECT_CALL(mockImageBuffer, resetCanvas(_)).Times(AnyNumber());
|
| bridge->setImageBuffer(&mockImageBuffer);
|
| @@ -838,14 +767,13 @@ TEST_F(Canvas2DLayerBridgeTest, TeardownWhileHibernating)
|
| TEST_F(Canvas2DLayerBridgeTest, DISABLED_TeardownWhileHibernating)
|
| #endif
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| + FakeGLES2Interface gl;
|
| OwnPtr<WebThread> testThread = adoptPtr(Platform::current()->createThread("TestThread"));
|
|
|
| // The Canvas2DLayerBridge has to be created on the thread that will use it
|
| // to avoid WeakPtr thread check issues.
|
| Canvas2DLayerBridgePtr bridge;
|
| - postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &mainMock, &mockGL, this);
|
| + postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &gl, this);
|
|
|
| // Register an alternate Logger for tracking hibernation events
|
| OwnPtr<MockLogger> mockLogger = adoptPtr(new MockLogger);
|
| @@ -867,8 +795,6 @@ TEST_F(Canvas2DLayerBridgeTest, DISABLED_TeardownWhileHibernating)
|
| // Tear down the bridge while hibernating
|
| EXPECT_CALL(*mockLoggerPtr, reportHibernationEvent(Canvas2DLayerBridge::HibernationEndedWithTeardown));
|
| postAndWaitDestroyBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge);
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| }
|
|
|
| class IdleFenceTask : public WebThread::IdleTask {
|
| @@ -894,14 +820,13 @@ TEST_F(Canvas2DLayerBridgeTest, TeardownWhileHibernationIsPending)
|
| TEST_F(Canvas2DLayerBridgeTest, DISABLED_TeardownWhileHibernationIsPending)
|
| #endif
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| + FakeGLES2Interface gl;
|
| OwnPtr<WebThread> testThread = adoptPtr(Platform::current()->createThread("TestThread"));
|
|
|
| // The Canvas2DLayerBridge has to be created on the thread that will use it
|
| // to avoid WeakPtr thread check issues.
|
| Canvas2DLayerBridgePtr bridge;
|
| - postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &mainMock, &mockGL, this);
|
| + postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &gl, this);
|
|
|
| // Register an alternate Logger for tracking hibernation events
|
| OwnPtr<MockLogger> mockLogger = adoptPtr(new MockLogger);
|
| @@ -927,8 +852,6 @@ TEST_F(Canvas2DLayerBridgeTest, DISABLED_TeardownWhileHibernationIsPending)
|
| OwnPtr<WaitableEvent> fenceEvent = adoptPtr(new WaitableEvent());
|
| testThread->scheduler()->postIdleTask(BLINK_FROM_HERE, new IdleFenceTask(fenceEvent.get()));
|
| fenceEvent->wait();
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| }
|
|
|
| #if CANVAS2D_HIBERNATION_ENABLED
|
| @@ -937,14 +860,13 @@ TEST_F(Canvas2DLayerBridgeTest, HibernationAbortedDueToPendingTeardown)
|
| TEST_F(Canvas2DLayerBridgeTest, DISABLED_HibernationAbortedDueToPendingTeardown)
|
| #endif
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| + FakeGLES2Interface gl;
|
| OwnPtr<WebThread> testThread = adoptPtr(Platform::current()->createThread("TestThread"));
|
|
|
| // The Canvas2DLayerBridge has to be created on the thread that will use it
|
| // to avoid WeakPtr thread check issues.
|
| Canvas2DLayerBridgePtr bridge;
|
| - postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &mainMock, &mockGL, this);
|
| + postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &gl, this);
|
|
|
| // Register an alternate Logger for tracking hibernation events
|
| OwnPtr<MockLogger> mockLogger = adoptPtr(new MockLogger);
|
| @@ -964,8 +886,6 @@ TEST_F(Canvas2DLayerBridgeTest, DISABLED_HibernationAbortedDueToPendingTeardown)
|
|
|
| // Tear down bridge on thread
|
| postAndWaitDestroyBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge);
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| }
|
|
|
| #if CANVAS2D_HIBERNATION_ENABLED
|
| @@ -974,14 +894,13 @@ TEST_F(Canvas2DLayerBridgeTest, HibernationAbortedDueToVisibilityChange)
|
| TEST_F(Canvas2DLayerBridgeTest, DISABLED_HibernationAbortedDueToVisibilityChange)
|
| #endif
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| + FakeGLES2Interface gl;
|
| OwnPtr<WebThread> testThread = adoptPtr(Platform::current()->createThread("TestThread"));
|
|
|
| // The Canvas2DLayerBridge has to be created on the thread that will use it
|
| // to avoid WeakPtr thread check issues.
|
| Canvas2DLayerBridgePtr bridge;
|
| - postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &mainMock, &mockGL, this);
|
| + postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &gl, this);
|
|
|
| // Register an alternate Logger for tracking hibernation events
|
| OwnPtr<MockLogger> mockLogger = adoptPtr(new MockLogger);
|
| @@ -1004,8 +923,6 @@ TEST_F(Canvas2DLayerBridgeTest, DISABLED_HibernationAbortedDueToVisibilityChange
|
| // Tear down the bridge on the thread so that 'bridge' can go out of scope
|
| // without crashing due to thread checks
|
| postAndWaitDestroyBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge);
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| }
|
|
|
| #if CANVAS2D_HIBERNATION_ENABLED
|
| @@ -1014,21 +931,20 @@ TEST_F(Canvas2DLayerBridgeTest, HibernationAbortedDueToLostContext)
|
| TEST_F(Canvas2DLayerBridgeTest, DISABLED_HibernationAbortedDueToLostContext)
|
| #endif
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| + FakeGLES2Interface gl;
|
| OwnPtr<WebThread> testThread = adoptPtr(Platform::current()->createThread("TestThread"));
|
|
|
| // The Canvas2DLayerBridge has to be created on the thread that will use it
|
| // to avoid WeakPtr thread check issues.
|
| Canvas2DLayerBridgePtr bridge;
|
| - postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &mainMock, &mockGL, this);
|
| + postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &gl, this);
|
|
|
| // Register an alternate Logger for tracking hibernation events
|
| OwnPtr<MockLogger> mockLogger = adoptPtr(new MockLogger);
|
| MockLogger* mockLoggerPtr = mockLogger.get();
|
| bridge->setLoggerForTesting(mockLogger.release());
|
|
|
| - mockGL.setIsContextLost(true);
|
| + gl.setIsContextLost(true);
|
| // Test entering hibernation
|
| OwnPtr<WaitableEvent> hibernationAbortedEvent = adoptPtr(new WaitableEvent());
|
| EXPECT_CALL(*mockLoggerPtr, reportHibernationEvent(Canvas2DLayerBridge::HibernationScheduled));
|
| @@ -1042,8 +958,6 @@ TEST_F(Canvas2DLayerBridgeTest, DISABLED_HibernationAbortedDueToLostContext)
|
| // Tear down the bridge on the thread so that 'bridge' can go out of scope
|
| // without crashing due to thread checks
|
| postAndWaitDestroyBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge);
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(&mainMock);
|
| }
|
|
|
| #if CANVAS2D_HIBERNATION_ENABLED
|
| @@ -1052,14 +966,13 @@ TEST_F(Canvas2DLayerBridgeTest, PrepareMailboxWhileHibernating)
|
| TEST_F(Canvas2DLayerBridgeTest, DISABLED_PrepareMailboxWhileHibernating)
|
| #endif
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| + FakeGLES2Interface gl;
|
| OwnPtr<WebThread> testThread = adoptPtr(Platform::current()->createThread("TestThread"));
|
|
|
| // The Canvas2DLayerBridge has to be created on the thread that will use it
|
| // to avoid WeakPtr thread check issues.
|
| Canvas2DLayerBridgePtr bridge;
|
| - postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &mainMock, &mockGL, this);
|
| + postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &gl, this);
|
|
|
| // Register an alternate Logger for tracking hibernation events
|
| OwnPtr<MockLogger> mockLogger = adoptPtr(new MockLogger);
|
| @@ -1092,14 +1005,13 @@ TEST_F(Canvas2DLayerBridgeTest, PrepareMailboxWhileBackgroundRendering)
|
| TEST_F(Canvas2DLayerBridgeTest, DISABLED_PrepareMailboxWhileBackgroundRendering)
|
| #endif
|
| {
|
| - MockCanvasContext mainMock;
|
| - MockGLES2Interface mockGL;
|
| + FakeGLES2Interface gl;
|
| OwnPtr<WebThread> testThread = adoptPtr(Platform::current()->createThread("TestThread"));
|
|
|
| // The Canvas2DLayerBridge has to be created on the thread that will use it
|
| // to avoid WeakPtr thread check issues.
|
| Canvas2DLayerBridgePtr bridge;
|
| - postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &mainMock, &mockGL, this);
|
| + postAndWaitCreateBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge, &gl, this);
|
|
|
| // Register an alternate Logger for tracking hibernation events
|
| OwnPtr<MockLogger> mockLogger = adoptPtr(new MockLogger);
|
|
|