summaryrefslogtreecommitdiff
path: root/Source/WebKit/chromium/tests/FloatQuadTest.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'Source/WebKit/chromium/tests/FloatQuadTest.cpp')
-rw-r--r--Source/WebKit/chromium/tests/FloatQuadTest.cpp76
1 files changed, 76 insertions, 0 deletions
diff --git a/Source/WebKit/chromium/tests/FloatQuadTest.cpp b/Source/WebKit/chromium/tests/FloatQuadTest.cpp
new file mode 100644
index 000000000..7633dcf15
--- /dev/null
+++ b/Source/WebKit/chromium/tests/FloatQuadTest.cpp
@@ -0,0 +1,76 @@
+/*
+ * Copyright (C) 2011 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 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 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 "FloatQuad.h"
+
+#include "TransformationMatrix.h"
+
+#include <gtest/gtest.h>
+
+using namespace WebCore;
+
+namespace {
+
+TEST(FloatQuadTest, IsRectilinearTest)
+{
+ const int numRectilinear = 8;
+ TransformationMatrix rectilinearTrans[numRectilinear];
+ rectilinearTrans[1].rotate(90);
+ rectilinearTrans[2].rotate(180);
+ rectilinearTrans[3].rotate(270);
+ rectilinearTrans[4].skewX(0.00000000001);
+ rectilinearTrans[5].skewY(0.00000000001);
+ rectilinearTrans[6].scale(0.00001);
+ rectilinearTrans[6].rotate(180);
+ rectilinearTrans[7].scale(100000);
+ rectilinearTrans[7].rotate(180);
+
+ for (int i = 0; i < numRectilinear; ++i) {
+ FloatQuad quad = rectilinearTrans[i].mapQuad(FloatRect(0.01010101, 0.01010101, 100.01010101, 100.01010101));
+ EXPECT_TRUE(quad.isRectilinear());
+ }
+
+ const int numNonRectilinear = 10;
+ TransformationMatrix nonRectilinearTrans[numNonRectilinear];
+ nonRectilinearTrans[0].rotate(359.999);
+ nonRectilinearTrans[1].rotate(0.0000001);
+ nonRectilinearTrans[2].rotate(89.999999);
+ nonRectilinearTrans[3].rotate(90.0000001);
+ nonRectilinearTrans[4].rotate(179.999999);
+ nonRectilinearTrans[5].rotate(180.0000001);
+ nonRectilinearTrans[6].rotate(269.999999);
+ nonRectilinearTrans[7].rotate(270.0000001);
+ nonRectilinearTrans[8].skewX(0.00001);
+ nonRectilinearTrans[9].skewY(0.00001);
+
+ for (int i = 0; i < numNonRectilinear; ++i) {
+ FloatQuad quad = nonRectilinearTrans[i].mapQuad(FloatRect(0.01010101, 0.01010101, 100.01010101, 100.01010101));
+ EXPECT_FALSE(quad.isRectilinear());
+ }
+}
+
+} // empty namespace