File: TestPerfTimer.cpp

package info (click to toggle)
ecflow 5.15.2-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 51,868 kB
  • sloc: cpp: 269,341; python: 22,756; sh: 3,609; perl: 770; xml: 333; f90: 204; ansic: 141; makefile: 70
file content (89 lines) | stat: -rw-r--r-- 3,147 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
/*
 * Copyright 2009- ECMWF.
 *
 * This software is licensed under the terms of the Apache Licence version 2.0
 * which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
 * In applying this licence, ECMWF does not waive the privileges and immunities
 * granted to it by virtue of its status as an intergovernmental organisation
 * nor does it submit to any jurisdiction.
 */

#include <boost/test/unit_test.hpp>

#include "ecflow/core/Converter.hpp"
#include "ecflow/core/Timer.hpp"
#include "ecflow/test/scaffold/Naming.hpp"

using namespace std;

BOOST_AUTO_TEST_SUITE(U_Core)

BOOST_AUTO_TEST_SUITE(T_PerfTimer)

static void func(int const count = 100000) {
    for (int i = 0; i < count; i++) {
        std::string s = std::string("fred");
        s += ecf::convert_to<std::string>(i);
    }
}

BOOST_AUTO_TEST_CASE(test_perf_with_chrono) {
    ECF_NAME_THIS_TEST();

    // using namespace std::chrono_literals;

    [[maybe_unused]] auto t = ecf::FunctionPerformanceTimer<>::duration(func, 100000);

    // This does not work, ie calling func with no arguments ?? with our hacked invoke, wait till c++ 17
    // auto t0= perf_timer<std::chrono::nanoseconds>::duration(func);

    [[maybe_unused]] auto t1 = ecf::FunctionPerformanceTimer<std::chrono::nanoseconds>::duration(func, 10);
    [[maybe_unused]] auto t2 = ecf::FunctionPerformanceTimer<std::chrono::microseconds>::duration(func, 100);
    [[maybe_unused]] auto t3 = ecf::FunctionPerformanceTimer<std::chrono::milliseconds>::duration(func, 100000);

#if PRINT_TIMING_RESULTS
    ECF_TEST_DBG(<< "   " << std::chrono::duration<double, std::micro>(t).count() << " micro");
    ECF_TEST_DBG(<< "   " << std::chrono::duration<double, std::milli>(t).count() << " milli");
    ECF_TEST_DBG(<< "   " << std::chrono::duration<double, std::nano>(t).count() << " nano");
    ECF_TEST_DBG(<< "   " << std::chrono::duration<double, std::milli>(t1 + t2 + t3).count() << " milli");
#endif

    BOOST_CHECK_MESSAGE(true, "dummy to keep unit test happy");
}

BOOST_AUTO_TEST_CASE(test_chrono_timer) {
    ECF_NAME_THIS_TEST();

    {
        Timer<std::chrono::milliseconds> timer;
        func();
        timer.elapsed("   func with default args , milliseconds");

#if PRINT_TIMING_RESULTS
        using namespace std::chrono;
        ECF_TEST_DBG(<< "    " << duration<double, std::micro>(timer.elapsed()).count() << " micro");
        ECF_TEST_DBG(<< "    " << duration<double, std::milli>(timer.elapsed()).count() << " milli");
        ECF_TEST_DBG(<< "    " << duration<double, std::nano>(timer.elapsed()).count() << " nano");
#endif
    }
    {
        Timer<std::chrono::microseconds> timer;
        func();
        timer.elapsed("   func with default args , microseconds");
    }
    {
        Timer<std::chrono::nanoseconds> timer;
        func();
        timer.elapsed("   func with default args , nanoseconds");
    }
    {
        Timer<std::chrono::seconds> timer;
        func();
        timer.elapsed("   func with default args , seconds");
    }
    BOOST_CHECK_MESSAGE(true, "dummy to keep unit test happy");
}

BOOST_AUTO_TEST_SUITE_END()

BOOST_AUTO_TEST_SUITE_END()