aboutsummaryrefslogtreecommitdiffhomepage
path: root/tests/ProxyTest.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tests/ProxyTest.cpp')
-rw-r--r--tests/ProxyTest.cpp172
1 files changed, 0 insertions, 172 deletions
diff --git a/tests/ProxyTest.cpp b/tests/ProxyTest.cpp
deleted file mode 100644
index 68fc1f142e..0000000000
--- a/tests/ProxyTest.cpp
+++ /dev/null
@@ -1,172 +0,0 @@
-/*
- * Copyright 2016 Google Inc.
- *
- * Use of this source code is governed by a BSD-style license that can be
- * found in the LICENSE file.
- */
-
-// This is a GPU-backend specific test.
-
-#include "Test.h"
-
-#if SK_SUPPORT_GPU
-#include "GrSurfaceProxy.h"
-#include "GrTextureProxy.h"
-#include "GrRenderTargetProxy.h"
-
-static void check_surface(skiatest::Reporter* reporter,
- GrSurfaceProxy* proxy,
- GrSurfaceOrigin origin,
- int width, int height,
- GrPixelConfig config) {
- REPORTER_ASSERT(reporter, proxy->origin() == origin);
- REPORTER_ASSERT(reporter, proxy->width() == width);
- REPORTER_ASSERT(reporter, proxy->height() == height);
- REPORTER_ASSERT(reporter, proxy->config() == config);
-}
-
-static void check_rendertarget(skiatest::Reporter* reporter,
- GrTextureProvider* provider,
- GrRenderTargetProxy* rtProxy,
- SkBackingFit fit) {
- REPORTER_ASSERT(reporter, rtProxy->asTextureProxy() == nullptr); // for now
- REPORTER_ASSERT(reporter, rtProxy->asRenderTargetProxy() == rtProxy);
-
- GrRenderTarget* rt = rtProxy->instantiate(provider);
- REPORTER_ASSERT(reporter, rt);
-
- REPORTER_ASSERT(reporter, rt->origin() == rtProxy->origin());
- if (SkBackingFit::kExact == fit) {
- REPORTER_ASSERT(reporter, rt->width() == rtProxy->width());
- REPORTER_ASSERT(reporter, rt->height() == rtProxy->height());
- } else {
- REPORTER_ASSERT(reporter, rt->width() >= rtProxy->width());
- REPORTER_ASSERT(reporter, rt->height() >= rtProxy->height());
- }
- REPORTER_ASSERT(reporter, rt->config() == rtProxy->config());
-
- REPORTER_ASSERT(reporter, rt->isUnifiedMultisampled() == rtProxy->isUnifiedMultisampled());
- REPORTER_ASSERT(reporter, rt->isStencilBufferMultisampled() ==
- rtProxy->isStencilBufferMultisampled());
- REPORTER_ASSERT(reporter, rt->numColorSamples() == rtProxy->numColorSamples());
- REPORTER_ASSERT(reporter, rt->numStencilSamples() == rtProxy->numStencilSamples());
- REPORTER_ASSERT(reporter, rt->hasMixedSamples() == rtProxy->hasMixedSamples());
-}
-
-static void check_texture(skiatest::Reporter* reporter,
- GrTextureProvider* provider,
- GrTextureProxy* texProxy,
- SkBackingFit fit) {
- REPORTER_ASSERT(reporter, texProxy->asTextureProxy() == texProxy);
- REPORTER_ASSERT(reporter, texProxy->asRenderTargetProxy() == nullptr); // for now
-
- GrTexture* tex = texProxy->instantiate(provider);
- REPORTER_ASSERT(reporter, tex);
-
- REPORTER_ASSERT(reporter, tex->origin() == texProxy->origin());
- if (SkBackingFit::kExact == fit) {
- REPORTER_ASSERT(reporter, tex->width() == texProxy->width());
- REPORTER_ASSERT(reporter, tex->height() == texProxy->height());
- } else {
- REPORTER_ASSERT(reporter, tex->width() >= texProxy->width());
- REPORTER_ASSERT(reporter, tex->height() >= texProxy->height());
- }
- REPORTER_ASSERT(reporter, tex->config() == texProxy->config());
-}
-
-
-DEF_GPUTEST_FOR_GL_RENDERING_CONTEXTS(AllocedProxyTest, reporter, ctxInfo) {
- GrTextureProvider* provider = ctxInfo.fGrContext->textureProvider();
-
- for (auto origin : { kBottomLeft_GrSurfaceOrigin, kTopLeft_GrSurfaceOrigin }) {
- for (auto widthHeight : { 100, 128 }) {
- for (auto config : { kAlpha_8_GrPixelConfig, kRGBA_8888_GrPixelConfig }) {
- for (auto fit : { SkBackingFit::kExact, SkBackingFit::kApprox }) {
- for (auto budgeted : { SkBudgeted::kYes, SkBudgeted::kNo }) {
- for (auto numSamples : { 0, 4}) {
- bool renderable = ctxInfo.fGrContext->caps()->isConfigRenderable(
- config, numSamples > 0);
-
- GrSurfaceDesc desc;
- desc.fOrigin = origin;
- desc.fWidth = widthHeight;
- desc.fHeight = widthHeight;
- desc.fConfig = config;
- desc.fSampleCnt = numSamples;
-
- if (renderable) {
- sk_sp<GrRenderTargetProxy> rtProxy(GrRenderTargetProxy::Make(
- *ctxInfo.fGrContext->caps(),
- desc,
- fit,
- budgeted));
- check_surface(reporter, rtProxy.get(), origin,
- widthHeight, widthHeight, config);
- check_rendertarget(reporter, provider, rtProxy.get(), fit);
- }
-
- desc.fSampleCnt = 0;
-
- sk_sp<GrTextureProxy> texProxy(GrTextureProxy::Make(desc,
- fit,
- budgeted));
- check_surface(reporter, texProxy.get(), origin,
- widthHeight, widthHeight, config);
- check_texture(reporter, provider, texProxy.get(), fit);
- }
- }
- }
- }
- }
- }
-}
-
-DEF_GPUTEST_FOR_GL_RENDERING_CONTEXTS(WrappedProxyTest, reporter, ctxInfo) {
- GrTextureProvider* provider = ctxInfo.fGrContext->textureProvider();
-
- static const int kWidthHeight = 100;
-
- for (auto origin : { kBottomLeft_GrSurfaceOrigin, kTopLeft_GrSurfaceOrigin }) {
- for (auto config : { kAlpha_8_GrPixelConfig, kRGBA_8888_GrPixelConfig }) {
- for (auto budgeted : { SkBudgeted::kYes, SkBudgeted::kNo }) {
- for (auto numSamples: { 0, 4}) {
- bool renderable = ctxInfo.fGrContext->caps()->isConfigRenderable(
- config, numSamples > 0);
-
- GrSurfaceDesc desc;
- desc.fOrigin = origin;
- desc.fWidth = kWidthHeight;
- desc.fHeight = kWidthHeight;
- desc.fConfig = config;
- desc.fSampleCnt = numSamples;
-
- sk_sp<GrTexture> tex;
-
- if (renderable) {
- desc.fFlags = kRenderTarget_GrSurfaceFlag;
- tex.reset(provider->createTexture(desc, budgeted));
- sk_sp<GrRenderTarget> rt(sk_ref_sp(tex->asRenderTarget()));
-
- sk_sp<GrRenderTargetProxy> rtProxy(GrRenderTargetProxy::Make(rt));
- check_surface(reporter, rtProxy.get(), origin,
- kWidthHeight, kWidthHeight, config);
- check_rendertarget(reporter, provider, rtProxy.get(), SkBackingFit::kExact);
- }
-
- if (!tex) {
- SkASSERT(kNone_GrSurfaceFlags == desc.fFlags );
- desc.fSampleCnt = 0;
- tex.reset(provider->createTexture(desc, budgeted));
- }
-
- sk_sp<GrTextureProxy> texProxy(GrTextureProxy::Make(tex));
- check_surface(reporter, texProxy.get(), origin,
- kWidthHeight, kWidthHeight, config);
- check_texture(reporter, provider, texProxy.get(), SkBackingFit::kExact);
- }
- }
- }
- }
-}
-
-#endif