OSDN Git Service

ANRdaemon: move trace result from /sdcard to /data am: d93aa41807
[android-x86/system-extras.git] / memory_replay / tests / PointersTest.cpp
1 /*
2  * Copyright (C) 2015 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 #include <gtest/gtest.h>
18
19 #include "Pointers.h"
20
21 TEST(PointersTest, smoke) {
22   Pointers pointers(1);
23
24   pointers.Add(0x1234, reinterpret_cast<void*>(0xabcd));
25   void* memory_pointer = pointers.Remove(0x1234);
26   ASSERT_EQ(reinterpret_cast<void*>(0xabcd), memory_pointer);
27 }
28
29 TEST(PointersTest, readd_pointer) {
30   Pointers pointers(1);
31
32   pointers.Add(0x1234, reinterpret_cast<void*>(0xabcd));
33   void* memory_pointer = pointers.Remove(0x1234);
34   ASSERT_EQ(reinterpret_cast<void*>(0xabcd), memory_pointer);
35   pointers.Add(0x1234, reinterpret_cast<void*>(0x5555));
36   memory_pointer = pointers.Remove(0x1234);
37   ASSERT_EQ(reinterpret_cast<void*>(0x5555), memory_pointer);
38 }
39
40
41 TEST(PointersTest, expect_collision) {
42   Pointers pointers(2);
43
44   // This assumes the simple hash being used will result in a collision
45   // hitting the same entry.
46   pointers.Add(0x1234, reinterpret_cast<void*>(0xabcd));
47   pointers.Add(0x11234, reinterpret_cast<void*>(0xabcf));
48   void* memory_pointer = pointers.Remove(0x11234);
49   ASSERT_EQ(reinterpret_cast<void*>(0xabcf), memory_pointer);
50   memory_pointer = pointers.Remove(0x1234);
51   ASSERT_EQ(reinterpret_cast<void*>(0xabcd), memory_pointer);
52 }
53
54 TEST(PointersTest, multiple_add_removes) {
55   Pointers pointers(4);
56
57   pointers.Add(0x1234, reinterpret_cast<void*>(0xabcd));
58   pointers.Add(0x1235, reinterpret_cast<void*>(0xabcf));
59   pointers.Add(0x1236, reinterpret_cast<void*>(0xabc1));
60   pointers.Add(0x1237, reinterpret_cast<void*>(0xabc2));
61
62   void* memory_pointer = pointers.Remove(0x1236);
63   ASSERT_EQ(reinterpret_cast<void*>(0xabc1), memory_pointer);
64
65   pointers.Add(0x2349, reinterpret_cast<void*>(0x2abcd));
66
67   memory_pointer = pointers.Remove(0x1234);
68   ASSERT_EQ(reinterpret_cast<void*>(0xabcd), memory_pointer);
69   memory_pointer = pointers.Remove(0x1237);
70   ASSERT_EQ(reinterpret_cast<void*>(0xabc2), memory_pointer);
71
72   pointers.Add(0x3500, reinterpret_cast<void*>(0x3abcd));
73
74   memory_pointer = pointers.Remove(0x3500);
75   ASSERT_EQ(reinterpret_cast<void*>(0x3abcd), memory_pointer);
76   memory_pointer = pointers.Remove(0x2349);
77   ASSERT_EQ(reinterpret_cast<void*>(0x2abcd), memory_pointer);
78 }
79
80 static void TestNoEntriesLeft() {
81   Pointers pointers(1);
82
83   // Even though we've requested only one pointer, we get more due
84   // to the way the data is allocated.
85   for (size_t i = 0; i <= pointers.max_pointers(); i++) {
86     pointers.Add(0x1234 + i, reinterpret_cast<void*>(0xabcd + i));
87   }
88 }
89
90 TEST(PointersTest_DeathTest, no_entries_left) {
91   ASSERT_EXIT(TestNoEntriesLeft(), ::testing::ExitedWithCode(1), "");
92 }
93
94 static void TestFindNoPointer() {
95   Pointers pointers(1);
96
97   pointers.Remove(0x1234);
98 }
99
100 TEST(PointersTest_DeathTest, find_no_pointer) {
101   ASSERT_EXIT(TestFindNoPointer(), ::testing::ExitedWithCode(1), "");
102 }
103
104 static void TestRemoveZeroValue() {
105   Pointers pointers(1);
106
107   void* memory = pointers.Remove(0);
108   if (memory) {}
109 }
110
111 TEST(PointersTest_DeathTest, remove_zero_value) {
112   ASSERT_EXIT(TestRemoveZeroValue(), ::testing::ExitedWithCode(1), "");
113 }