1 /* Copyright 2015 The TensorFlow Authors. All Rights Reserved.
2
3 Licensed under the Apache License, Version 2.0 (the "License");
4 you may not use this file except in compliance with the License.
5 You may obtain a copy of the License at
6
7 http://www.apache.org/licenses/LICENSE-2.0
8
9 Unless required by applicable law or agreed to in writing, software
10 distributed under the License is distributed on an "AS IS" BASIS,
11 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 See the License for the specific language governing permissions and
13 limitations under the License.
14 ==============================================================================*/
15
16 #define _XOPEN_SOURCE // for setenv, unsetenv
17 #include <cstdlib>
18
19 #include "tensorflow/core/util/reporter.h"
20
21 #include "tensorflow/core/lib/core/status_test_util.h"
22 #include "tensorflow/core/lib/strings/str_util.h"
23 #include "tensorflow/core/lib/strings/strcat.h"
24 #include "tensorflow/core/platform/protobuf.h"
25 #include "tensorflow/core/platform/test.h"
26
27 namespace tensorflow {
28 namespace {
29
30 // Tests of all the error paths in log_reader.cc follow:
ExpectHasSubstr(StringPiece s,StringPiece expected)31 static void ExpectHasSubstr(StringPiece s, StringPiece expected) {
32 EXPECT_TRUE(absl::StrContains(s, expected))
33 << s << " does not contain " << expected;
34 }
35
TEST(TestReporter,NoLogging)36 TEST(TestReporter, NoLogging) {
37 TestReporter test_reporter("b1");
38 TF_EXPECT_OK(test_reporter.Initialize());
39 TF_EXPECT_OK(test_reporter.Close());
40 }
41
TEST(TestReporter,UsesEnv)42 TEST(TestReporter, UsesEnv) {
43 const char* old_env = std::getenv(TestReporter::kTestReporterEnv);
44
45 // Set a file we can't possibly create, check for failure
46 setenv(TestReporter::kTestReporterEnv, "/cant/find/me:!", 1);
47 CHECK_EQ(string(std::getenv(TestReporter::kTestReporterEnv)),
48 string("/cant/find/me:!"));
49 TestReporter test_reporter("b1");
50 Status s = test_reporter.Initialize();
51 ExpectHasSubstr(s.ToString(), "/cant/find/me");
52
53 // Remove the env variable, no logging is performed
54 unsetenv(TestReporter::kTestReporterEnv);
55 CHECK_EQ(std::getenv(TestReporter::kTestReporterEnv), nullptr);
56 TestReporter test_reporter_empty("b1");
57 s = test_reporter_empty.Initialize();
58 TF_EXPECT_OK(s);
59 s = test_reporter_empty.Close();
60 TF_EXPECT_OK(s);
61
62 if (old_env == nullptr) {
63 unsetenv(TestReporter::kTestReporterEnv);
64 } else {
65 setenv(TestReporter::kTestReporterEnv, old_env, 1);
66 }
67 }
68
TEST(TestReporter,CreateTwiceFails)69 TEST(TestReporter, CreateTwiceFails) {
70 {
71 TestReporter test_reporter(
72 strings::StrCat(testing::TmpDir(), "/test_reporter_dupe"), "t1");
73 TF_EXPECT_OK(test_reporter.Initialize());
74 }
75 {
76 TestReporter test_reporter(
77 strings::StrCat(testing::TmpDir(), "/test_reporter_dupe"), "t1");
78 Status s = test_reporter.Initialize();
79 ExpectHasSubstr(s.ToString(), "file exists:");
80 }
81 }
82
TEST(TestReporter,CreateCloseCreateAgainSkipsSecond)83 TEST(TestReporter, CreateCloseCreateAgainSkipsSecond) {
84 TestReporter test_reporter(
85 strings::StrCat(testing::TmpDir(), "/test_reporter_create_close"), "t1");
86 TF_EXPECT_OK(test_reporter.Initialize());
87 TF_EXPECT_OK(test_reporter.Close());
88 TF_EXPECT_OK(test_reporter.Benchmark(1, 1.0, 2.0, 3.0)); // No-op, closed
89 TF_EXPECT_OK(test_reporter.Close()); // No-op, closed
90 Status s = test_reporter.Initialize(); // Try to reinitialize
91 ExpectHasSubstr(s.ToString(), "file exists:");
92 }
93
TEST(TestReporter,Benchmark)94 TEST(TestReporter, Benchmark) {
95 string fname =
96 strings::StrCat(testing::TmpDir(), "/test_reporter_benchmarks_");
97 TestReporter test_reporter(fname, "b1/2/3");
98 TF_EXPECT_OK(test_reporter.Initialize());
99 TF_EXPECT_OK(test_reporter.Benchmark(1, 1.0, 2.0, 3.0));
100 TF_EXPECT_OK(test_reporter.Close());
101
102 string expected_fname = strings::StrCat(fname, "b1__2__3");
103 string read;
104 TF_EXPECT_OK(ReadFileToString(Env::Default(), expected_fname, &read));
105
106 BenchmarkEntries benchmark_entries;
107 ASSERT_TRUE(benchmark_entries.ParseFromString(read));
108 ASSERT_EQ(1, benchmark_entries.entry_size());
109 const BenchmarkEntry& benchmark_entry = benchmark_entries.entry(0);
110
111 EXPECT_EQ(benchmark_entry.name(), "b1/2/3");
112 EXPECT_EQ(benchmark_entry.iters(), 1);
113 EXPECT_EQ(benchmark_entry.cpu_time(), 1.0);
114 EXPECT_EQ(benchmark_entry.wall_time(), 2.0);
115 EXPECT_EQ(benchmark_entry.throughput(), 3.0);
116 }
117
TEST(TestReporter,SetProperties)118 TEST(TestReporter, SetProperties) {
119 string fname =
120 strings::StrCat(testing::TmpDir(), "/test_reporter_benchmarks_");
121 TestReporter test_reporter(fname, "b2/3/4");
122 TF_EXPECT_OK(test_reporter.Initialize());
123 TF_EXPECT_OK(test_reporter.SetProperty("string_prop", "abc"));
124 TF_EXPECT_OK(test_reporter.SetProperty("double_prop", 4.0));
125
126 TF_EXPECT_OK(test_reporter.Close());
127 string expected_fname = strings::StrCat(fname, "b2__3__4");
128 string read;
129 TF_EXPECT_OK(ReadFileToString(Env::Default(), expected_fname, &read));
130
131 BenchmarkEntries benchmark_entries;
132 ASSERT_TRUE(benchmark_entries.ParseFromString(read));
133 ASSERT_EQ(1, benchmark_entries.entry_size());
134 const BenchmarkEntry& benchmark_entry = benchmark_entries.entry(0);
135 const auto& extras = benchmark_entry.extras();
136 ASSERT_EQ(2, extras.size());
137 EXPECT_EQ("abc", extras.at("string_prop").string_value());
138 EXPECT_EQ(4.0, extras.at("double_prop").double_value());
139 }
140
TEST(TestReporter,AddMetrics)141 TEST(TestReporter, AddMetrics) {
142 string fname =
143 strings::StrCat(testing::TmpDir(), "/test_reporter_benchmarks_");
144 TestReporter test_reporter(fname, "b3/4/5");
145 TF_EXPECT_OK(test_reporter.Initialize());
146 TF_EXPECT_OK(test_reporter.AddMetric("metric1", 2.0));
147 TF_EXPECT_OK(test_reporter.AddMetric("metric2", 3.0));
148
149 TF_EXPECT_OK(test_reporter.Close());
150 string expected_fname = strings::StrCat(fname, "b3__4__5");
151 string read;
152 TF_EXPECT_OK(ReadFileToString(Env::Default(), expected_fname, &read));
153
154 BenchmarkEntries benchmark_entries;
155 ASSERT_TRUE(benchmark_entries.ParseFromString(read));
156 ASSERT_EQ(1, benchmark_entries.entry_size());
157 const BenchmarkEntry& benchmark_entry = benchmark_entries.entry(0);
158 const auto& metrics = benchmark_entry.metrics();
159 ASSERT_EQ(2, metrics.size());
160 EXPECT_EQ("metric1", metrics.at(0).name());
161 EXPECT_EQ(2.0, metrics.at(0).value());
162 EXPECT_EQ("metric2", metrics.at(1).name());
163 EXPECT_EQ(3.0, metrics.at(1).value());
164 }
165
166 } // namespace
167 } // namespace tensorflow
168