1 /* Copyright 2019 Google LLC. All Rights Reserved.
2
3 Licensed under the Apache License, Version 2.0 (the "License");
4 you may not use this file except in compliance with the License.
5 You may obtain a copy of the License at
6
7 http://www.apache.org/licenses/LICENSE-2.0
8
9 Unless required by applicable law or agreed to in writing, software
10 distributed under the License is distributed on an "AS IS" BASIS,
11 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 See the License for the specific language governing permissions and
13 limitations under the License.
14 ==============================================================================*/
15
16 #include "tensorflow/lite/experimental/ruy/allocator.h"
17
18 #include <gtest/gtest.h>
19
20 namespace ruy {
21 namespace {
22
TEST(AllocatorTest,ReturnsValidMemory)23 TEST(AllocatorTest, ReturnsValidMemory) {
24 Allocator allocator;
25 int *p;
26 allocator.Allocate(1, &p);
27 ASSERT_NE(p, nullptr);
28
29 // If this is bogus memory, ASan will cause this test to fail.
30 *p = 42;
31
32 allocator.FreeAll();
33 }
34
TEST(AllocatorTest,NoLeak)35 TEST(AllocatorTest, NoLeak) {
36 Allocator allocator;
37 // Allocate and free some ridiculously large total amount of memory, so
38 // that a leak will hopefully cause some sort of resource exhaustion.
39 //
40 // Despite the large number of allocations, this test is actually quite
41 // fast, since our fast-path allocation logic is very fast.
42 constexpr int kNumAllocations = 100 * 1024;
43 constexpr int kAllocationSize = 1024 * 1024;
44 for (int i = 0; i < kNumAllocations; i++) {
45 char *p;
46 allocator.Allocate(kAllocationSize, &p);
47 allocator.FreeAll();
48 }
49 }
50
TEST(AllocatorTest,IncreasingSizes)51 TEST(AllocatorTest, IncreasingSizes) {
52 Allocator allocator;
53 // Allocate sizes that increase by small amounts across FreeAll calls.
54 for (int i = 1; i < 100 * 1024; i++) {
55 char *p;
56 allocator.Allocate(i, &p);
57 allocator.FreeAll();
58 }
59 }
60
TEST(AllocatorTest,ManySmallAllocations)61 TEST(AllocatorTest, ManySmallAllocations) {
62 Allocator allocator;
63 // Allocate many small allocations between FreeAll calls.
64 for (int i = 0; i < 10 * 1024; i += 100) {
65 for (int j = 0; j < i; j++) {
66 char *p;
67 allocator.Allocate(1, &p);
68 }
69 allocator.FreeAll();
70 }
71 }
72
TEST(AllocatorTest,DestructorHandlesMainBumpPtr)73 TEST(AllocatorTest, DestructorHandlesMainBumpPtr) {
74 // This is a white-box test.
75 Allocator allocator;
76 allocator.AllocateBytes(1);
77 allocator.FreeAll();
78 // After the call to FreeAll, the allocator will consolidate all of the memory
79 // into the main bump-ptr allocator's block, which we then expect to be freed
80 // in the destructor.
81 //
82 // We have no test assertions -- we primarily expect that this trigger a leak
83 // checker and cause the test to fail.
84 }
85
TEST(AllocatorTest,DestructorHandlesFallbackBlocks)86 TEST(AllocatorTest, DestructorHandlesFallbackBlocks) {
87 // This is a white-box test.
88 Allocator allocator;
89 // Since we just created the allocator, this will allocate a fallback block,
90 // which we then expect to be freed in the destructor.
91 //
92 // We have no test assertions -- we primarily expect that this trigger a leak
93 // checker and cause the test to fail.
94 allocator.AllocateBytes(1);
95 }
96
97 } // namespace
98 } // namespace ruy
99
main(int argc,char ** argv)100 int main(int argc, char **argv) {
101 ::testing::InitGoogleTest(&argc, argv);
102 return RUN_ALL_TESTS();
103 }
104