From eed6f1b76b6690796e3d40993b1504ba1eca2df5 Mon Sep 17 00:00:00 2001 From: "reed@google.com" Date: Thu, 18 Jul 2013 19:53:31 +0000 Subject: pull mipmap class into its own (private) header BUG= R=scroggo@google.com Review URL: https://codereview.chromium.org/19462007 git-svn-id: http://skia.googlecode.com/svn/trunk@10161 2bbb7eff-a529-9590-31e7-b0007b416f81 --- tests/MipMapTest.cpp | 59 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100644 tests/MipMapTest.cpp (limited to 'tests/MipMapTest.cpp') diff --git a/tests/MipMapTest.cpp b/tests/MipMapTest.cpp new file mode 100644 index 0000000000..c305532ebc --- /dev/null +++ b/tests/MipMapTest.cpp @@ -0,0 +1,59 @@ +/* + * Copyright 2013 Google Inc. + * + * Use of this source code is governed by a BSD-style license that can be + * found in the LICENSE file. + */ + +#include "Test.h" +#include "SkMipMap.h" +#include "SkBitmap.h" +#include "SkRandom.h" + +static void make_bitmap(SkBitmap* bm, SkRandom& rand) { + // for now, Build needs a min size of 2, otherwise it will return NULL. + // should fix that to support 1 X N, where N > 1 to return non-null. + int w = 2 + rand.nextU() % 1000; + int h = 2 + rand.nextU() % 1000; + bm->setConfig(SkBitmap::kARGB_8888_Config, w, h); + bm->allocPixels(); + bm->eraseColor(SK_ColorWHITE); +} + +static void TestMipMap(skiatest::Reporter* reporter) { + SkBitmap bm; + SkRandom rand; + + for (int i = 0; i < 500; ++i) { + make_bitmap(&bm, rand); + SkAutoTUnref mm(SkMipMap::Build(bm)); + + REPORTER_ASSERT(reporter, !mm->extractLevel(SK_Scalar1, NULL)); + REPORTER_ASSERT(reporter, !mm->extractLevel(SK_Scalar1 * 2, NULL)); + + SkMipMap::Level prevLevel; + prevLevel.fPixels = NULL; // sentinel + + SkScalar scale = SK_Scalar1; + for (int j = 0; j < 30; ++j) { + scale = scale * 2 / 3; + + SkMipMap::Level level; + if (mm->extractLevel(scale, &level)) { + REPORTER_ASSERT(reporter, level.fPixels); + REPORTER_ASSERT(reporter, level.fWidth > 0); + REPORTER_ASSERT(reporter, level.fHeight > 0); + REPORTER_ASSERT(reporter, level.fRowBytes >= level.fWidth * 4); + + if (prevLevel.fPixels) { + REPORTER_ASSERT(reporter, level.fWidth <= prevLevel.fWidth); + REPORTER_ASSERT(reporter, level.fHeight <= prevLevel.fHeight); + } + prevLevel = level; + } + } + } +} + +#include "TestClassDef.h" +DEFINE_TESTCLASS("MipMap", MipMapTestClass, TestMipMap) -- cgit v1.2.3