// Copyright (c) 2012 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/basictypes.h" #include "testing/gtest/include/gtest/gtest.h" #include "ui/gfx/insets.h" #include "ui/gfx/shadow_value.h" namespace gfx { TEST(ShadowValueTest, GetMargin) { const struct TestCase { Insets expected_margin; size_t shadow_count; ShadowValue shadows[2]; } kTestCases[] = { { Insets(), 0, {}, }, { Insets(-2, -2, -2, -2), 1, { ShadowValue(gfx::Point(0, 0), 4, 0), }, }, { Insets(0, -1, -4, -3), 1, { ShadowValue(gfx::Point(1, 2), 4, 0), }, }, { Insets(-4, -3, 0, -1), 1, { ShadowValue(gfx::Point(-1, -2), 4, 0), }, }, { Insets(0, -1, -5, -4), 2, { ShadowValue(gfx::Point(1, 2), 4, 0), ShadowValue(gfx::Point(2, 3), 4, 0), }, }, { Insets(-4, -3, -5, -4), 2, { ShadowValue(gfx::Point(-1, -2), 4, 0), ShadowValue(gfx::Point(2, 3), 4, 0), }, }, }; for (size_t i = 0; i < ARRAYSIZE_UNSAFE(kTestCases); ++i) { Insets margin = ShadowValue::GetMargin( ShadowValues(kTestCases[i].shadows, kTestCases[i].shadows + kTestCases[i].shadow_count)); EXPECT_EQ(kTestCases[i].expected_margin, margin) << " i=" << i; } } } // namespace gfx