summaryrefslogtreecommitdiff
path: root/tests/unit/analyzers/breakdown/breakdown.cpp
blob: d9ac1c3b5ebf4427d7e381c066fd500a91fc5404 (plain)
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
//------------------------------------------------------------------------------
// Author: Andrey Kuznetsov
// Description: Unit tests
// Copyright (c) 2015 EPAM Systems
//------------------------------------------------------------------------------
/*
    This file is part of Nfstrace.

    Nfstrace is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, version 2 of the License.

    Nfstrace is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with Nfstrace.  If not, see <http://www.gnu.org/licenses/>.
*/
//------------------------------------------------------------------------------
#include <cstdlib>
#include <iostream>
#include <ctime>

#include <gmock/gmock.h>
#include <gtest/gtest.h>

#include "breakdowncounter.h"
//------------------------------------------------------------------------------
using namespace NST::breakdown;

using ::testing::Return;
using ::testing::AtLeast;
using ::testing::_;
//------------------------------------------------------------------------------
namespace
{

class BreakdownTest : public ::testing::Test
{
protected:
    size_t count;
    timeval t;
public:
    void SetUp()
    {
        std::srand(std::time(0)); //use current time as seed for random generator
        count = std::rand() % 100 + 3;
    }

    void TearDown()
    {
    }
};

}
//------------------------------------------------------------------------------
TEST_F(BreakdownTest, count)
{

    BreakdownCounter break_down(count);

    EXPECT_EQ(0U, break_down.get_total_count());

    break_down[1].add(t);
    break_down[1].add(t);
    break_down[0].add(t);

    EXPECT_EQ(3U, break_down.get_total_count());

}
//------------------------------------------------------------------------------