pytorch/test/cpp/jit/test_cleanup_passes.cpp
Michael Suo 6d21d5f0b3 gtest-ify JIT tests, through the letter c (#45249)
Summary:
Pull Request resolved: https://github.com/pytorch/pytorch/pull/45249

Reland of https://github.com/pytorch/pytorch/pull/45055 and
https://github.com/pytorch/pytorch/pull/45020

See https://github.com/pytorch/pytorch/pull/45018 for context.

Test Plan: Imported from OSS

Reviewed By: jamesr66a

Differential Revision: D23892645

Pulled By: suo

fbshipit-source-id: e7fe58d5e1a5a0c44f4e2aec9694145afabde0fd
2020-09-24 00:21:20 -07:00

50 lines
1.4 KiB
C++

#include <gtest/gtest.h>
#include <torch/csrc/jit/frontend/ir_emitter.h>
#include <torch/csrc/jit/ir/ir.h>
#include <torch/csrc/jit/ir/irparser.h>
#include <torch/csrc/jit/testing/file_check.h>
namespace torch {
namespace jit {
TEST(CleanupPassTest, Basic) {
// Tests stability of clean up passes when dealing with constant pooling
// and constant propagation.
auto graph = std::make_shared<Graph>();
parseIR(
R"IR(
graph(%cond.1 : Tensor,
%suffix.1 : str):
%3 : bool = aten::Bool(%cond.1) # o.py:6:7
%25 : str = prim::If(%3) # o.py:6:4
block0():
%a.1 : str = prim::Constant[value="same string"]()
%b.1 : str = prim::Constant[value=" with a twist"]()
%7 : str = aten::add(%a.1, %b.1)
%11 : str = aten::add(%7, %suffix.1) # o.py:10:15
-> (%11)
block1():
%c.1 : str = prim::Constant[value="same string"]()
%d.1 : str = prim::Constant[value=" with a twist"]()
%12 : str = aten::add(%c.1, %d.1)
-> (%12)
return (%25)
)IR",
&*graph);
runCleanupPasses(graph);
testing::FileCheck()
.check_count(
"prim::Constant[value=\"same string with a twist\"]",
1,
/*exactly=*/true)
->run(*graph);
auto graph_after_pass_once = graph->toString();
runCleanupPasses(graph);
auto graph_after_pass_twice = graph->toString();
ASSERT_EQ(graph_after_pass_once, graph_after_pass_twice);
}
} // namespace jit
} // namespace torch