Index: chrome/browser/thumbnails/advanced_thumbnail_crop_unittest.cc |
diff --git a/chrome/browser/thumbnails/advanced_thumbnail_crop_unittest.cc b/chrome/browser/thumbnails/advanced_thumbnail_crop_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..34f4905eece0432082ae7c1e872d35e8298f702a |
--- /dev/null |
+++ b/chrome/browser/thumbnails/advanced_thumbnail_crop_unittest.cc |
@@ -0,0 +1,160 @@ |
+// Copyright (c) 2013 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "base/message_loop.h" |
+#include "chrome/browser/thumbnails/advanced_thumbnail_crop.h" |
+#include "chrome/browser/thumbnails/simple_thumbnail_crop.h" |
+#include "content/public/browser/browser_thread.h" |
+#include "content/public/test/test_browser_thread.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+#include "third_party/skia/include/core/SkBitmap.h" |
+#include "ui/gfx/canvas.h" |
+#include "ui/gfx/scrollbar_size.h" |
+ |
+namespace thumbnails { |
+ |
+using content::BrowserThread; |
mazda
2013/05/23 19:13:57
It looks this is used only once. Why don't you del
motek.
2013/05/27 16:54:54
Done.
|
+ |
+typedef testing::Test AdvancedThumbnailCropTest; |
+ |
+struct MockThumbnailingContext : public ThumbnailingContext { |
+ public: |
+ explicit MockThumbnailingContext(const gfx::Size& size) { |
+ requested_copy_size = size; |
+ clip_result = CLIP_RESULT_UNPROCESSED; |
+ } |
+}; |
+ |
+class ConsumerCallbackCatcher { |
+ public: |
+ ConsumerCallbackCatcher() |
+ : called_back_(false), clip_result_(CLIP_RESULT_UNPROCESSED) { |
+ } |
+ |
+ void UiThreadCallback(const ThumbnailingContext& context, |
+ const SkBitmap& bitmap) { |
+ called_back_ = true; |
+ captured_bitmap_ = bitmap; |
+ clip_result_ = context.clip_result; |
+ score_ = context.score; |
+ clip_result_ = context.clip_result; |
+ } |
+ |
+ SkBitmap captured_bitmap_; |
+ bool called_back_; |
+ ClipResult clip_result_; |
+ ThumbnailScore score_; |
+ |
+ private: |
+ DISALLOW_COPY_AND_ASSIGN(ConsumerCallbackCatcher); |
+}; |
+ |
+TEST_F(AdvancedThumbnailCropTest, GetCanvasCopyInfo) { |
+ // We will want to use the entirety of the image as the source. Usually, |
+ // an image in its original size should be requested, except for reakky large |
+ // canvas. In that case, image will be shrunk but wit aspect ratio preserved. |
+ const gfx::Size thumbnail_size(312, 165); |
+ scoped_refptr<ThumbnailingAlgorithm> algorithm( |
+ new AdvancedThumbnailCrop(thumbnail_size)); |
+ |
+ gfx::Rect clipping_rect; |
+ gfx::Size target_size; |
+ gfx::Size source_size(1000, 600); |
+ |
+ ClipResult clip_result = algorithm->GetCanvasCopyInfo( |
+ source_size, ui::SCALE_FACTOR_100P, &clipping_rect, &target_size); |
+ EXPECT_EQ(clip_result, CLIP_RESULT_SOURCE_SAME_AS_TARGET); |
mazda
2013/05/23 19:13:57
Please write expectation in the first argument of
motek.
2013/05/27 16:54:54
Done.
|
+ EXPECT_EQ(clipping_rect.size(), source_size); |
+ EXPECT_EQ(clipping_rect.origin(), gfx::Point(0, 0)); |
mazda
2013/05/23 19:13:57
Using ToString makes the test results more readabl
motek.
2013/05/27 16:54:54
Done.
|
+ EXPECT_EQ(target_size, source_size); |
+ |
+ source_size.SetSize(6000, 3000); |
+ clip_result = algorithm->GetCanvasCopyInfo( |
+ source_size, ui::SCALE_FACTOR_100P, &clipping_rect, &target_size); |
+ EXPECT_EQ(clip_result, CLIP_RESULT_NOT_CLIPPED); |
+ EXPECT_EQ(clipping_rect.size(), source_size); |
+ EXPECT_EQ(clipping_rect.origin(), gfx::Point(0, 0)); |
+ EXPECT_LT(target_size.width(), source_size.width()); |
+ EXPECT_LT(target_size.height(), source_size.height()); |
+ EXPECT_NEAR(static_cast<float>(target_size.width()) / target_size.height(), |
+ static_cast<float>(source_size.width()) / source_size.height(), |
+ 0.1f); |
+ source_size.SetSize(300, 200); |
+ clip_result = algorithm->GetCanvasCopyInfo( |
+ source_size, ui::SCALE_FACTOR_100P, &clipping_rect, &target_size); |
+ EXPECT_EQ(clip_result, CLIP_RESULT_SOURCE_IS_SMALLER); |
+ EXPECT_EQ(clipping_rect.size(), |
+ SimpleThumbnailCrop::GetCopySizeForThumbnail(ui::SCALE_FACTOR_100P, |
+ thumbnail_size)); |
+ EXPECT_EQ(clipping_rect.origin(), gfx::Point(0, 0)); |
+} |
+ |
+TEST_F(AdvancedThumbnailCropTest, PrepareSourceBitmap) { |
+ const gfx::Size thumbnail_size(312, 165); |
+ const gfx::Size copy_size(400, 200); |
+ scoped_refptr<ThumbnailingContext> context( |
+ new MockThumbnailingContext(copy_size)); |
+ |
+ // This calls for exercising two distinct paths: with prior clipping and |
+ // without. |
+ SkBitmap source; |
+ source.setConfig(SkBitmap::kARGB_8888_Config, 800, 600); |
+ source.allocPixels(); |
+ source.eraseRGB(50, 150, 200); |
+ SkBitmap result = AdvancedThumbnailCrop::PrepareSourceBitmap( |
+ source, thumbnail_size, context); |
+ EXPECT_EQ(CLIP_RESULT_SOURCE_SAME_AS_TARGET, context->clip_result); |
+ EXPECT_GE(result.width(), copy_size.width()); |
+ EXPECT_GE(result.height(), copy_size.height()); |
+ EXPECT_LT(result.width(), source.width()); |
+ EXPECT_LT(result.height(), source.height()); |
+ // The check below is a bit of a side effect: since the image was clipped |
+ // by scrollbar_size, it cannot be shrunk and thus what we get below is |
+ // true. |
+ EXPECT_NEAR(result.width(), source.width(), gfx::scrollbar_size()); |
+ EXPECT_NEAR(result.height(), source.height(), gfx::scrollbar_size()); |
+ |
+ result = AdvancedThumbnailCrop::PrepareSourceBitmap( |
+ source, thumbnail_size, context); |
+ EXPECT_EQ(CLIP_RESULT_SOURCE_SAME_AS_TARGET, context->clip_result); |
+ EXPECT_GE(result.width(), copy_size.width()); |
+ EXPECT_GE(result.height(), copy_size.height()); |
+ EXPECT_LT(result.width(), source.width()); |
+ EXPECT_LT(result.height(), source.height()); |
+} |
+ |
+TEST_F(AdvancedThumbnailCropTest, CreateRetargettedThumbnail) { |
+ // This tests the invocation of the main thumbnail-making apparatus. |
+ // The actual content is not really of concern here, just check the plumbing. |
+ const gfx::Size image_size(1200, 800); |
+ gfx::Canvas canvas(image_size, ui::SCALE_FACTOR_100P, true); |
+ |
+ // The image consists of vertical non-overlapping stripes 150 pixels wide. |
+ canvas.FillRect(gfx::Rect(200, 200, 800, 400), SkColorSetRGB(255, 255, 255)); |
+ SkBitmap source = |
+ skia::GetTopDevice(*canvas.sk_canvas())->accessBitmap(false); |
+ |
+ ConsumerCallbackCatcher catcher; |
+ const gfx::Size thumbnail_size(432, 284); |
+ scoped_refptr<ThumbnailingContext> context( |
+ new MockThumbnailingContext(image_size)); |
+ |
+ context->clip_result = CLIP_RESULT_SOURCE_SAME_AS_TARGET; |
+ MessageLoopForUI message_loop; |
+ content::TestBrowserThread ui_thread(BrowserThread::UI, &message_loop); |
+ AdvancedThumbnailCrop::CreateRetargettedThumbnail( |
+ source, |
+ thumbnail_size, |
+ context, |
+ base::Bind(&ConsumerCallbackCatcher::UiThreadCallback, |
+ base::Unretained(&catcher))); |
+ message_loop.RunUntilIdle(); |
+ ASSERT_TRUE(catcher.called_back_); |
+ EXPECT_TRUE(catcher.score_.good_clipping); |
+ EXPECT_FALSE(catcher.captured_bitmap_.empty()); |
+ EXPECT_LT(catcher.captured_bitmap_.width(), source.width()); |
+ EXPECT_LT(catcher.captured_bitmap_.height(), source.height()); |
+} |
+ |
+} // namespace thumbnails |