Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(489)

Unified Diff: test/unittests/compiler/node-cache-unittest.cc

Issue 1114903002: [test] Turn compiler/test-node-cache into a unit test. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@local_cleanup-test-node-algorithm
Patch Set: Created 5 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « test/cctest/compiler/test-node-cache.cc ('k') | test/unittests/unittests.gyp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: test/unittests/compiler/node-cache-unittest.cc
diff --git a/test/unittests/compiler/node-cache-unittest.cc b/test/unittests/compiler/node-cache-unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..3c92876abdae5244a6219348922d8d809f612904
--- /dev/null
+++ b/test/unittests/compiler/node-cache-unittest.cc
@@ -0,0 +1,159 @@
+// Copyright 2014 the V8 project authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "src/compiler/node-cache.h"
+#include "test/unittests/compiler/graph-unittest.h"
+#include "test/unittests/test-utils.h"
+#include "testing/gmock-support.h"
+
+using testing::Contains;
+
+namespace v8 {
+namespace internal {
+namespace compiler {
+
+typedef GraphTest NodeCacheTest;
+
+TEST_F(NodeCacheTest, Int32Constant_back_to_back) {
+ Int32NodeCache cache;
+
+ for (int i = -2000000000; i < 2000000000; i += 3315177) {
+ Node** pos = cache.Find(zone(), i);
+ ASSERT_TRUE(pos != nullptr);
+ for (int j = 0; j < 3; j++) {
+ Node** npos = cache.Find(zone(), i);
+ EXPECT_EQ(pos, npos);
+ }
+ }
+}
+
+
+TEST_F(NodeCacheTest, Int32Constant_five) {
+ Int32NodeCache cache;
+ int32_t constants[] = {static_cast<int32_t>(0x80000000), -77, 0, 1, -1};
+ Node* nodes[arraysize(constants)];
+
+ for (size_t i = 0; i < arraysize(constants); i++) {
+ int32_t k = constants[i];
+ Node* node = graph()->NewNode(common()->Int32Constant(k));
+ *cache.Find(zone(), k) = nodes[i] = node;
+ }
+
+ for (size_t i = 0; i < arraysize(constants); i++) {
+ int32_t k = constants[i];
+ EXPECT_EQ(nodes[i], *cache.Find(zone(), k));
+ }
+}
+
+
+TEST_F(NodeCacheTest, Int32Constant_hits) {
+ Int32NodeCache cache;
+ const int32_t kSize = 1500;
+ Node** nodes = zone()->NewArray<Node*>(kSize);
+
+ for (int i = 0; i < kSize; i++) {
+ int32_t v = i * -55;
+ nodes[i] = graph()->NewNode(common()->Int32Constant(v));
+ *cache.Find(zone(), v) = nodes[i];
+ }
+
+ int hits = 0;
+ for (int i = 0; i < kSize; i++) {
+ int32_t v = i * -55;
+ Node** pos = cache.Find(zone(), v);
+ if (*pos != NULL) {
+ EXPECT_EQ(nodes[i], *pos);
+ hits++;
+ }
+ }
+ EXPECT_LT(4, hits);
+}
+
+
+TEST_F(NodeCacheTest, Int64Constant_back_to_back) {
+ Int64NodeCache cache;
+
+ for (int64_t i = -2000000000; i < 2000000000; i += 3315177) {
+ Node** pos = cache.Find(zone(), i);
+ ASSERT_TRUE(pos != nullptr);
+ for (int j = 0; j < 3; j++) {
+ Node** npos = cache.Find(zone(), i);
+ EXPECT_EQ(pos, npos);
+ }
+ }
+}
+
+
+TEST_F(NodeCacheTest, Int64Constant_hits) {
+ Int64NodeCache cache;
+ const int32_t kSize = 1500;
+ Node** nodes = zone()->NewArray<Node*>(kSize);
+
+ for (int i = 0; i < kSize; i++) {
+ int64_t v = static_cast<int64_t>(i) * static_cast<int64_t>(5003001);
+ nodes[i] = graph()->NewNode(common()->Int32Constant(i));
+ *cache.Find(zone(), v) = nodes[i];
+ }
+
+ int hits = 0;
+ for (int i = 0; i < kSize; i++) {
+ int64_t v = static_cast<int64_t>(i) * static_cast<int64_t>(5003001);
+ Node** pos = cache.Find(zone(), v);
+ if (*pos != NULL) {
+ EXPECT_EQ(nodes[i], *pos);
+ hits++;
+ }
+ }
+ EXPECT_LT(4, hits);
+}
+
+
+TEST_F(NodeCacheTest, GetCachedNodes_int32) {
+ Int32NodeCache cache;
+ int32_t constants[] = {0, 311, 12, 13, 14, 555, -555, -44, -33, -22, -11,
+ 0, 311, 311, 412, 412, 11, 11, -33, -33, -22, -11};
+
+ for (size_t i = 0; i < arraysize(constants); i++) {
+ int32_t k = constants[i];
+ Node** pos = cache.Find(zone(), k);
+ if (*pos != NULL) {
+ ZoneVector<Node*> nodes(zone());
+ cache.GetCachedNodes(&nodes);
+ EXPECT_THAT(nodes, Contains(*pos));
+ } else {
+ ZoneVector<Node*> nodes(zone());
+ Node* n = graph()->NewNode(common()->Int32Constant(k));
+ *pos = n;
+ cache.GetCachedNodes(&nodes);
+ EXPECT_THAT(nodes, Contains(n));
+ }
+ }
+}
+
+
+TEST_F(NodeCacheTest, GetCachedNodes_int64) {
+ Int64NodeCache cache;
+ int64_t constants[] = {0, 311, 12, 13, 14, 555, -555, -44, -33, -22, -11,
+ 0, 311, 311, 412, 412, 11, 11, -33, -33, -22, -11};
+
+ for (size_t i = 0; i < arraysize(constants); i++) {
+ int64_t k = constants[i];
+ Node** pos = cache.Find(zone(), k);
+ if (*pos != NULL) {
+ ZoneVector<Node*> nodes(zone());
+ cache.GetCachedNodes(&nodes);
+ EXPECT_THAT(nodes, Contains(*pos));
+ } else {
+ ZoneVector<Node*> nodes(zone());
+ Node* n = graph()->NewNode(common()->Int64Constant(k));
+ *pos = n;
+ cache.GetCachedNodes(&nodes);
+ EXPECT_THAT(nodes, Contains(n));
+ }
+ }
+}
+
+} // namespace compiler
+} // namespace internal
+} // namespace v8
« no previous file with comments | « test/cctest/compiler/test-node-cache.cc ('k') | test/unittests/unittests.gyp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698