forked from pytorch/pytorch
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_cleanup_passes.cpp
50 lines (46 loc) · 1.49 KB
/
test_cleanup_passes.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#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 {
// NOLINTNEXTLINE(cppcoreguidelines-avoid-non-const-global-variables)
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