File: inbound_path.cpp

package info (click to toggle)
actor-framework 0.17.6-3.2
  • links: PTS
  • area: main
  • in suites: forky, sid
  • size: 9,008 kB
  • sloc: cpp: 77,684; sh: 674; python: 309; makefile: 13
file content (90 lines) | stat: -rw-r--r-- 3,452 bytes parent folder | download | duplicates (4)
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
90
/******************************************************************************
 *                       ____    _    _____                                   *
 *                      / ___|  / \  |  ___|    C++                           *
 *                     | |     / _ \ | |_       Actor                         *
 *                     | |___ / ___ \|  _|      Framework                     *
 *                      \____/_/   \_|_|                                      *
 *                                                                            *
 * Copyright 2011-2018 Dominik Charousset                                     *
 *                                                                            *
 * Distributed under the terms and conditions of the BSD 3-Clause License or  *
 * (at your option) under the terms and conditions of the Boost Software      *
 * License 1.0. See accompanying files LICENSE and LICENSE_ALTERNATIVE.       *
 *                                                                            *
 * If you did not receive a copy of the license files, see                    *
 * http://opensource.org/licenses/BSD-3-Clause and                            *
 * http://www.boost.org/LICENSE_1_0.txt.                                      *
 ******************************************************************************/

#include "caf/config.hpp"

#define CAF_SUITE inbound_path
#include "caf/test/unit_test.hpp"

#include <string>

#include "caf/inbound_path.hpp"

using namespace std;
using namespace caf;

namespace {

#define PRINT(format, ...)                                                     \
  {                                                                            \
    char buf[200];                                                             \
    snprintf(buf, 200, format, __VA_ARGS__);                                   \
    CAF_MESSAGE(buf);                                                          \
  }

struct fixture {
  inbound_path::stats_t x;

  void calculate(int32_t total_items, int32_t total_time) {
    int32_t c = 1000;
    int32_t d = 100;
    int32_t n = total_items;
    int32_t t = total_time;
    int32_t m = t > 0 ? std::max((c * n) / t, 1) : 1;
    int32_t b = t > 0 ? std::max((d * n) / t, 1) : 1;
    PRINT("with a cycle C = %dns, desied complexity D = %d,", c, d);
    PRINT("number of items N = %d, and time delta t = %d:", n, t);
    PRINT("- throughput M = max(C * N / t, 1) = max(%d * %d / %d, 1) = %d",
          c, n, t, m);
    PRINT("- items/batch B = max(D * N / t, 1) = max(%d * %d / %d, 1) = %d",
          d, n, t, b);
    auto cr = x.calculate(timespan(c), timespan(d));
    CAF_CHECK_EQUAL(cr.items_per_batch, b);
    CAF_CHECK_EQUAL(cr.max_throughput, m);
  }

  void store(int32_t batch_size, int32_t calculation_time_ns) {
    inbound_path::stats_t::measurement m{batch_size,
                                         timespan{calculation_time_ns}};
    x.store(m);
  }
};

} // namespace

CAF_TEST_FIXTURE_SCOPE(inbound_path_tests, fixture)

CAF_TEST(default_constructed) {
  calculate(0, 0);
}

CAF_TEST(one_store) {
  CAF_MESSAGE("store a measurement for 500ns with batch size of 50");
  store(50, 500);
  calculate(50, 500);
}

CAF_TEST(multiple_stores) {
  CAF_MESSAGE("store measurements: (50, 500ns), (60, 400ns), (40, 600ns)");
  store(50, 500);
  store(40, 600);
  store(60, 400);
  calculate(150, 1500);
}

CAF_TEST_FIXTURE_SCOPE_END()