diff options
Diffstat (limited to 'Tools/TestWebKitAPI/Tests/WTF/CrossThreadTask.cpp')
| -rw-r--r-- | Tools/TestWebKitAPI/Tests/WTF/CrossThreadTask.cpp | 150 | 
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 | 
