Index: graph_utils_unittest.cc |
diff --git a/graph_utils_unittest.cc b/graph_utils_unittest.cc |
index d947ddd49ddafd8e73cb4a07b8184fdc2ce6b538..cfa2b5c657517f1eaff52a00a5c500a1e1f8a284 100644 |
--- a/graph_utils_unittest.cc |
+++ b/graph_utils_unittest.cc |
@@ -4,8 +4,11 @@ |
#include <utility> |
#include <vector> |
+ |
#include <gtest/gtest.h> |
+ |
#include "update_engine/graph_utils.h" |
+#include "update_engine/extent_ranges.h" |
using std::make_pair; |
using std::vector; |
@@ -38,4 +41,62 @@ TEST(GraphUtilsTest, SimpleTest) { |
EXPECT_EQ(4, graph_utils::EdgeWeight(graph, make_pair(0, 1))); |
} |
+TEST(GraphUtilsTest, BlocksInExtentsTest) { |
+ { |
+ vector<Extent> extents; |
+ EXPECT_EQ(0, graph_utils::BlocksInExtents(extents)); |
+ extents.push_back(ExtentForRange(0, 1)); |
+ EXPECT_EQ(1, graph_utils::BlocksInExtents(extents)); |
+ extents.push_back(ExtentForRange(23, 55)); |
+ EXPECT_EQ(56, graph_utils::BlocksInExtents(extents)); |
+ extents.push_back(ExtentForRange(1, 2)); |
+ EXPECT_EQ(58, graph_utils::BlocksInExtents(extents)); |
+ } |
+ { |
+ google::protobuf::RepeatedPtrField<Extent> extents; |
+ EXPECT_EQ(0, graph_utils::BlocksInExtents(extents)); |
+ *extents.Add() = ExtentForRange(0, 1); |
+ EXPECT_EQ(1, graph_utils::BlocksInExtents(extents)); |
+ *extents.Add() = ExtentForRange(23, 55); |
+ EXPECT_EQ(56, graph_utils::BlocksInExtents(extents)); |
+ *extents.Add() = ExtentForRange(1, 2); |
+ EXPECT_EQ(58, graph_utils::BlocksInExtents(extents)); |
+ } |
+} |
+ |
+TEST(GraphUtilsTest, DepsTest) { |
+ Graph graph(3); |
+ |
+ graph_utils::AddReadBeforeDep(&graph[0], 1, 3); |
+ EXPECT_EQ(1, graph[0].out_edges.size()); |
+ { |
+ Extent& extent = graph[0].out_edges[1].extents[0]; |
+ EXPECT_EQ(3, extent.start_block()); |
+ EXPECT_EQ(1, extent.num_blocks()); |
+ } |
+ graph_utils::AddReadBeforeDep(&graph[0], 1, 4); |
+ EXPECT_EQ(1, graph[0].out_edges.size()); |
+ { |
+ Extent& extent = graph[0].out_edges[1].extents[0]; |
+ EXPECT_EQ(3, extent.start_block()); |
+ EXPECT_EQ(2, extent.num_blocks()); |
+ } |
+ graph_utils::AddReadBeforeDepExtents(&graph[2], 1, |
+ vector<Extent>(1, ExtentForRange(5, 2))); |
+ EXPECT_EQ(1, graph[2].out_edges.size()); |
+ { |
+ Extent& extent = graph[2].out_edges[1].extents[0]; |
+ EXPECT_EQ(5, extent.start_block()); |
+ EXPECT_EQ(2, extent.num_blocks()); |
+ } |
+ // Change most recent edge from read-before to write-before |
+ graph[2].out_edges[1].write_extents.swap(graph[2].out_edges[1].extents); |
+ graph_utils::DropWriteBeforeDeps(&graph[2].out_edges); |
+ EXPECT_EQ(0, graph[2].out_edges.size()); |
+ |
+ EXPECT_EQ(1, graph[0].out_edges.size()); |
+ graph_utils::DropIncomingEdgesTo(&graph, 1); |
+ EXPECT_EQ(0, graph[0].out_edges.size()); |
+} |
+ |
} // namespace chromeos_update_engine |