aboutsummaryrefslogtreecommitdiffhomepage
path: root/tensorflow/core/grappler/optimizers/data/latency_all_edges_test.cc
diff options
context:
space:
mode:
Diffstat (limited to 'tensorflow/core/grappler/optimizers/data/latency_all_edges_test.cc')
-rw-r--r--tensorflow/core/grappler/optimizers/data/latency_all_edges_test.cc92
1 files changed, 92 insertions, 0 deletions
diff --git a/tensorflow/core/grappler/optimizers/data/latency_all_edges_test.cc b/tensorflow/core/grappler/optimizers/data/latency_all_edges_test.cc
new file mode 100644
index 0000000000..6789cf5bd6
--- /dev/null
+++ b/tensorflow/core/grappler/optimizers/data/latency_all_edges_test.cc
@@ -0,0 +1,92 @@
+/* Copyright 2018 The TensorFlow Authors. All Rights Reserved.
+
+Licensed under the Apache License, Version 2.0 (the "License");
+you may not use this file except in compliance with the License.
+You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+Unless required by applicable law or agreed to in writing, software
+distributed under the License is distributed on an "AS IS" BASIS,
+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+See the License for the specific language governing permissions and
+limitations under the License.
+==============================================================================*/
+
+#include "tensorflow/core/grappler/optimizers/data/latency_all_edges.h"
+
+#include "tensorflow/core/framework/attr_value_util.h"
+#include "tensorflow/core/framework/function_testlib.h"
+#include "tensorflow/core/grappler/grappler_item.h"
+#include "tensorflow/core/grappler/optimizers/data/graph_utils.h"
+#include "tensorflow/core/lib/core/status_test_util.h"
+#include "tensorflow/core/platform/test.h"
+
+namespace tensorflow {
+namespace grappler {
+namespace {
+
+TEST(LatencyAllEdgesTest, AddLatenciesAfterTensorMapPrefetch) {
+ using test::function::NDef;
+ GrapplerItem item;
+ NodeDef component_node =
+ NDef("component_nodes", "Const", {}, {{"value", 1}, {"dtype", DT_INT32}});
+ NodeDef from_tensor_node =
+ NDef("from_tensor_nodes", "TensorDataset", {"component_nodes"},
+ {{"Toutput_types", {}}, {"output_shapes", {}}});
+
+ NodeDef captured_input_node = NDef("captured_input_node", "Const", {},
+ {{"value", ""}, {"dtype", DT_STRING}});
+ NodeDef map_node = NDef("map_node", "MapDataset",
+ {"from_tensor_node", "captured_input_node"},
+ {{"f", {}},
+ {"Targumemts", {}},
+ {"output_shapes", {}},
+ {"output_types", {}}});
+ NodeDef buffer_size_node = NDef("buffer_size_node", "Const", {},
+ {{"value", 1}, {"dtype", DT_INT32}});
+ NodeDef prefetch_node = NDef("prefetch_node", "Prefetch_Dataset",
+ {"map_node", "buffer_size_node"},
+ {{"output_shapes", {}}, {"output_types", {}}});
+
+ item.graph = test::function::GDef({component_node, from_tensor_node,
+ captured_input_node, map_node,
+ buffer_size_node, prefetch_node});
+
+ LatencyAllEdges optimizer;
+ GraphDef output;
+ TF_ASSERT_OK(optimizer.Optimize(nullptr, item, &output));
+
+ EXPECT_TRUE(graph_utils::ContainsNodeWithOp("LatencyStatsDataset", output));
+ std::vector<int> latency_node_indices =
+ graph_utils::FindAllGraphNodesWithOp("LatencyStatsDataset", output);
+ EXPECT_EQ(latency_node_indices.size(), 3);
+ std::vector<NodeDef> dataset_nodes = {std::move(from_tensor_node),
+ std::move(map_node),
+ std::move(prefetch_node)};
+ for (int i = 0; i < latency_node_indices.size(); i++) {
+ NodeDef latency_node = output.node(latency_node_indices[i]);
+ EXPECT_EQ(latency_node.input_size(), 2);
+ EXPECT_EQ(latency_node.input(0), dataset_nodes[i].name());
+ EXPECT_TRUE(
+ AreAttrValuesEqual(latency_node.attr().at("output_shapes"),
+ dataset_nodes[i].attr().at("output_shapes")));
+ if (dataset_nodes[i].attr().find("output_types") !=
+ dataset_nodes[i].attr().end()) {
+ EXPECT_TRUE(
+ AreAttrValuesEqual(latency_node.attr().at("output_types"),
+ dataset_nodes[i].attr().at("output_types")));
+ } else {
+ if (dataset_nodes[i].attr().find("Toutput_types") !=
+ dataset_nodes[i].attr().end()) {
+ EXPECT_TRUE(
+ AreAttrValuesEqual(latency_node.attr().at("output_types"),
+ dataset_nodes[i].attr().at("Toutput_types")));
+ }
+ }
+ }
+}
+
+} // namespace
+} // namespace grappler
+} // namespace tensorflow