// 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