summaryrefslogtreecommitdiff
path: root/Tools/TestWebKitAPI/Tests/WTF/CrossThreadTask.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'Tools/TestWebKitAPI/Tests/WTF/CrossThreadTask.cpp')
-rw-r--r--Tools/TestWebKitAPI/Tests/WTF/CrossThreadTask.cpp150
1 files changed, 150 insertions, 0 deletions
diff --git a/Tools/TestWebKitAPI/Tests/WTF/CrossThreadTask.cpp b/Tools/TestWebKitAPI/Tests/WTF/CrossThreadTask.cpp
new file mode 100644
index 000000000..52c0bcd41
--- /dev/null
+++ b/Tools/TestWebKitAPI/Tests/WTF/CrossThreadTask.cpp
@@ -0,0 +1,150 @@
+/*
+ * Copyright (C) 2016 Apple 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 <wtf/CrossThreadTask.h>
+#include <wtf/HashCountedSet.h>
+#include <wtf/text/StringBuilder.h>
+#include <wtf/text/StringHash.h>
+
+namespace TestWebKitAPI {
+
+static size_t totalDestructorCalls;
+static size_t totalIsolatedCopyCalls;
+
+static HashCountedSet<String> defaultConstructorSet;
+static HashCountedSet<String> nameConstructorSet;
+static HashCountedSet<String> copyConstructorSet;
+static HashCountedSet<String> moveConstructorSet;
+
+struct LifetimeLogger {
+ LifetimeLogger()
+ {
+ defaultConstructorSet.add(fullName());
+ }
+
+ LifetimeLogger(const char* inputName)
+ : name(*inputName)
+ {
+ nameConstructorSet.add(fullName());
+ }
+
+ LifetimeLogger(const LifetimeLogger& other)
+ : name(other.name)
+ , copyGeneration(other.copyGeneration + 1)
+ , moveGeneration(other.moveGeneration)
+ {
+ copyConstructorSet.add(fullName());
+ }
+
+ LifetimeLogger(LifetimeLogger&& other)
+ : name(other.name)
+ , copyGeneration(other.copyGeneration)
+ , moveGeneration(other.moveGeneration + 1)
+ {
+ moveConstructorSet.add(fullName());
+ }
+
+ ~LifetimeLogger()
+ {
+ ++totalDestructorCalls;
+ }
+
+ LifetimeLogger isolatedCopy() const
+ {
+ ++totalIsolatedCopyCalls;
+ return LifetimeLogger(*this);
+ }
+
+ String fullName()
+ {
+ StringBuilder builder;
+ builder.append(&name);
+ builder.append("-");
+ builder.append(String::number(copyGeneration));
+ builder.append("-");
+ builder.append(String::number(moveGeneration));
+
+ return builder.toString();
+ }
+
+ const char& name { *"<default>" };
+ int copyGeneration { 0 };
+ int moveGeneration { 0 };
+};
+
+void testFunction(const LifetimeLogger&, const LifetimeLogger&, const LifetimeLogger&)
+{
+ // Do nothing - Just need to check the side effects of the arguments getting in here.
+}
+
+TEST(WTF_CrossThreadTask, Basic)
+{
+ {
+ LifetimeLogger logger1;
+ LifetimeLogger logger2(logger1);
+ LifetimeLogger logger3("logger");
+
+ auto task = createCrossThreadTask(testFunction, logger1, logger2, logger3);
+ task.performTask();
+ }
+
+ ASSERT_EQ(1u, defaultConstructorSet.size());
+ ASSERT_EQ(1u, defaultConstructorSet.count("<default>-0-0"));
+
+ ASSERT_EQ(1u, nameConstructorSet.size());
+ ASSERT_EQ(1u, nameConstructorSet.count("logger-0-0"));
+
+ ASSERT_EQ(3u, copyConstructorSet.size());
+ ASSERT_EQ(1u, copyConstructorSet.count("logger-1-0"));
+ ASSERT_EQ(2u, copyConstructorSet.count("<default>-1-0"));
+ ASSERT_EQ(1u, copyConstructorSet.count("<default>-2-0"));
+
+#if !COMPILER(MSVC)
+ ASSERT_EQ(6u, moveConstructorSet.size());
+#else
+ // The number of times the move constructor is called is different on Windows in this test.
+ // This seems to be caused by differences in MSVC's implementation of lambdas or std functions like std::make_tuple.
+ ASSERT_EQ(9u, moveConstructorSet.size());
+#endif
+ ASSERT_EQ(1u, moveConstructorSet.count("logger-1-1"));
+ ASSERT_EQ(1u, moveConstructorSet.count("logger-1-2"));
+ ASSERT_EQ(1u, moveConstructorSet.count("<default>-2-1"));
+ ASSERT_EQ(1u, moveConstructorSet.count("<default>-2-2"));
+ ASSERT_EQ(1u, moveConstructorSet.count("<default>-1-1"));
+ ASSERT_EQ(1u, moveConstructorSet.count("<default>-1-2"));
+
+#if !COMPILER(MSVC)
+ ASSERT_EQ(12u, totalDestructorCalls);
+#else
+ // Since the move constructor is called 3 more times on Windows (see above), we will have 3 more destructor calls.
+ ASSERT_EQ(15u, totalDestructorCalls);
+#endif
+ ASSERT_EQ(3u, totalIsolatedCopyCalls);
+
+}
+
+} // namespace TestWebKitAPI