diff options
author | Simon Hausmann <simon.hausmann@nokia.com> | 2012-08-21 10:57:44 +0200 |
---|---|---|
committer | Simon Hausmann <simon.hausmann@nokia.com> | 2012-08-21 10:57:44 +0200 |
commit | 5ef7c8a6a70875d4430752d146bdcb069605d71d (patch) | |
tree | f6256640b6c46d7da221435803cae65326817ba2 /Source/WebKit/chromium/tests/PopupContainerTest.cpp | |
parent | decad929f578d8db641febc8740649ca6c574638 (diff) | |
download | qtwebkit-5ef7c8a6a70875d4430752d146bdcb069605d71d.tar.gz |
Imported WebKit commit 356d83016b090995d08ad568f2d2c243aa55e831 (http://svn.webkit.org/repository/webkit/trunk@126147)
New snapshot including various build fixes for newer Qt 5
Diffstat (limited to 'Source/WebKit/chromium/tests/PopupContainerTest.cpp')
-rw-r--r-- | Source/WebKit/chromium/tests/PopupContainerTest.cpp | 159 |
1 files changed, 159 insertions, 0 deletions
diff --git a/Source/WebKit/chromium/tests/PopupContainerTest.cpp b/Source/WebKit/chromium/tests/PopupContainerTest.cpp new file mode 100644 index 000000000..a721b4cbb --- /dev/null +++ b/Source/WebKit/chromium/tests/PopupContainerTest.cpp @@ -0,0 +1,159 @@ +/* + * Copyright (C) 2012 Google Inc. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER + * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + */ + +#include "config.h" +#include "PopupContainer.h" + +#include <gtest/gtest.h> + +using namespace WebCore; + +class MockPopupContent : public PopupContent { +public: + virtual void setMaxHeight(int max) OVERRIDE { maxHeight = max; } + virtual int popupContentHeight() const OVERRIDE { return height; } + virtual ~MockPopupContent() { } + + virtual void layout() OVERRIDE + { + layoutCount++; + width = std::min(maxWidth, width); + height = std::min(maxHeight, height); + height -= height % 16; + } + + virtual void setMaxWidthAndLayout(int max) OVERRIDE + { + maxWidth = max; + layout(); + } + + MockPopupContent(const IntSize& widgetSize) + : width(widgetSize.width() - borderSize * 2) + , height(widgetSize.height() - borderSize * 2) + , maxWidth(width) + , maxHeight(height) + , layoutCount(0) + { + } + + int width; + int height; + int maxWidth; + int maxHeight; + unsigned layoutCount; + + static const int borderSize = 1; // Should match to kBorderSize in PopupContainer.cpp. +}; + +const int screenMaxX = 1024; +const int screenMaxY = 768; +const int targetControlWidth = 130; + +static IntRect calculatePosition(const IntRect& initialRect, PopupContent* content) +{ + const bool isRTL = true; + const int targetControlHeight = 20; + const FloatRect screenRect(0, 0, screenMaxX, screenMaxY); + const FloatRect windowRect(0, 0, 512, 512); + int rtlOffset = targetControlWidth - initialRect.width(); + bool needToResizeView = false; + return PopupContainer::layoutAndCalculateWidgetRectInternal(initialRect, targetControlHeight, windowRect, screenRect, !isRTL, rtlOffset, content, needToResizeView); +} + +TEST(PopupContainerTest, PopupPosition) +{ + // Suppose that initialRect.location is the bottom-left corner of the target + // control such as <select>. + + { + // If initialRect is in the screen, nothing should happen. + IntRect initialRect(100, 100, 256, 258); + MockPopupContent content(initialRect.size()); + IntRect resultRect = calculatePosition(initialRect, &content); + EXPECT_EQ(initialRect, resultRect); + EXPECT_EQ(0u, content.layoutCount); + } + + { + // If the left edge of the control is projecting from the screen, making + // the widget aligned to the right edge of the control. + IntRect initialRect(-10, 100, 100, 258); + MockPopupContent content(initialRect.size()); + IntRect resultRect = calculatePosition(initialRect, &content); + EXPECT_EQ(IntRect(20, 100, 100, 258), resultRect); + } + + { + // Made the widget aligned to the right edge. But it's still projecting + // from the screen. + IntRect initialRect(-10, 100, targetControlWidth, 258); + MockPopupContent content(initialRect.size()); + IntRect resultRect = calculatePosition(initialRect, &content); + EXPECT_EQ(IntRect(0, 100, 120, 258), resultRect); + EXPECT_EQ(118, content.width); + EXPECT_TRUE(content.layoutCount); + } + + { + // If the right edge of the control is projecting from the screen, + // shrink the width of the widget. + IntRect initialRect(screenMaxX - 100, 100, targetControlWidth, 258); + MockPopupContent content(initialRect.size()); + IntRect resultRect = calculatePosition(initialRect, &content); + EXPECT_EQ(IntRect(screenMaxX - 100, 100, 100, 258), resultRect); + EXPECT_EQ(98, content.width); + EXPECT_TRUE(content.layoutCount); + } + + { + // If there is no enough room below, move the widget upwards. + IntRect initialRect(100, 700, targetControlWidth, 258); + MockPopupContent content(initialRect.size()); + IntRect resultRect = calculatePosition(initialRect, &content); + EXPECT_EQ(IntRect(100, 422, targetControlWidth, 258), resultRect); + EXPECT_EQ(0u, content.layoutCount); + } + + { + // There is no enough room below and above, and the below space is larger. + IntRect initialRect(100, 300, targetControlWidth, 514); + MockPopupContent content(initialRect.size()); + IntRect resultRect = calculatePosition(initialRect, &content); + EXPECT_EQ(IntRect(100, 300, targetControlWidth, 466), resultRect); + EXPECT_TRUE(content.layoutCount); + EXPECT_EQ(464, content.height); + } + + { + // There is no enough room below and above, and the above space is larger. + IntRect initialRect(100, 400, targetControlWidth, 514); + MockPopupContent content(initialRect.size()); + IntRect resultRect = calculatePosition(initialRect, &content); + EXPECT_EQ(IntRect(100, 10, targetControlWidth, 370), resultRect); + EXPECT_TRUE(content.layoutCount); + EXPECT_EQ(368, content.height); + } +} |