Merge test folder of test branch
[iotivity.git] / test / src / common / commonutil / c_cpp / CommonTestUtil.cpp
1 /******************************************************************
2  *
3  * Copyright 2017 Samsung Electronics All Rights Reserved.
4  *
5  *
6  *
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  * http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  *
19  ******************************************************************/
20
21 #include "CommonTestUtil.h"
22
23 using namespace boost::assign;
24
25
26 long CommonTestUtil::s_setUpDynamicMemoryUsage = 0;
27 long CommonTestUtil::s_tearDownDynamicMemoryUsage = 0;
28 long CommonTestUtil::s_memoryDiffSum = 0;
29
30 long CommonTestUtil::getCurrentAllocatedMemory()
31 {
32 #ifndef __WINDOWS__
33     return mallinfo().uordblks;
34 #else
35     return 0;
36 #endif
37 }
38
39 void CommonTestUtil::runCommonTCSetUpPart()
40 {
41     s_setUpDynamicMemoryUsage = getCurrentAllocatedMemory();
42 }
43
44 void CommonTestUtil::runCommonTCTearDownPart()
45 {
46     s_tearDownDynamicMemoryUsage = getCurrentAllocatedMemory();
47     s_memoryDiffSum += s_tearDownDynamicMemoryUsage - s_setUpDynamicMemoryUsage;
48
49     //TODO: It will be printed using new logger
50     //printf("[Memory] Dynamic Memory Diff Sum : %ld bytes\n", s_memoryDiffSum);
51
52     ::testing::Test::RecordProperty("MemoryUsage", s_memoryDiffSum);
53     s_tearDownDynamicMemoryUsage = s_setUpDynamicMemoryUsage = 0;
54 }