94 lines
2.8 KiB
C++
94 lines
2.8 KiB
C++
/* 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/lite/minimal_logging.h"
|
|
|
|
#include <string>
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
namespace tflite {
|
|
|
|
TEST(MinimalLogging, Basic) {
|
|
testing::internal::CaptureStderr();
|
|
TFLITE_LOG_PROD(TFLITE_LOG_INFO, "Foo");
|
|
EXPECT_EQ("INFO: Foo\n", testing::internal::GetCapturedStderr());
|
|
}
|
|
|
|
TEST(MinimalLogging, BasicFormatted) {
|
|
testing::internal::CaptureStderr();
|
|
TFLITE_LOG_PROD(TFLITE_LOG_INFO, "Foo %s %s", "Bar", "Baz");
|
|
EXPECT_EQ("INFO: Foo Bar Baz\n", testing::internal::GetCapturedStderr());
|
|
}
|
|
|
|
TEST(MinimalLogging, Warn) {
|
|
testing::internal::CaptureStderr();
|
|
TFLITE_LOG_PROD(TFLITE_LOG_WARNING, "One", "");
|
|
EXPECT_EQ("WARNING: One\n", testing::internal::GetCapturedStderr());
|
|
}
|
|
|
|
TEST(MinimalLogging, Error) {
|
|
testing::internal::CaptureStderr();
|
|
TFLITE_LOG_PROD(TFLITE_LOG_ERROR, "Two");
|
|
EXPECT_EQ("ERROR: Two\n", testing::internal::GetCapturedStderr());
|
|
}
|
|
|
|
TEST(MinimalLogging, UnknownSeverity) {
|
|
testing::internal::CaptureStderr();
|
|
TFLITE_LOG_PROD(static_cast<LogSeverity>(-1), "Three");
|
|
EXPECT_EQ("<Unknown severity>: Three\n",
|
|
testing::internal::GetCapturedStderr());
|
|
}
|
|
|
|
TEST(MinimalLogging, Once) {
|
|
testing::internal::CaptureStderr();
|
|
for (int i = 0; i < 10; ++i) {
|
|
TFLITE_LOG_PROD_ONCE(TFLITE_LOG_INFO, "Count: %d", i);
|
|
}
|
|
EXPECT_EQ("INFO: Count: 0\n", testing::internal::GetCapturedStderr());
|
|
}
|
|
|
|
TEST(MinimalLogging, Debug) {
|
|
testing::internal::CaptureStderr();
|
|
TFLITE_LOG(TFLITE_LOG_INFO, "Foo");
|
|
TFLITE_LOG(TFLITE_LOG_WARNING, "Bar");
|
|
TFLITE_LOG(TFLITE_LOG_ERROR, "Baz");
|
|
#ifndef NDEBUG
|
|
EXPECT_EQ("INFO: Foo\nWARNING: Bar\nERROR: Baz\n",
|
|
testing::internal::GetCapturedStderr());
|
|
#else
|
|
EXPECT_TRUE(testing::internal::GetCapturedStderr().empty());
|
|
#endif
|
|
}
|
|
|
|
TEST(MinimalLogging, DebugOnce) {
|
|
testing::internal::CaptureStderr();
|
|
for (int i = 0; i < 10; ++i) {
|
|
TFLITE_LOG_ONCE(TFLITE_LOG_INFO, "Count: %d", i);
|
|
}
|
|
#ifndef NDEBUG
|
|
EXPECT_EQ("INFO: Count: 0\n", testing::internal::GetCapturedStderr());
|
|
#else
|
|
EXPECT_TRUE(testing::internal::GetCapturedStderr().empty());
|
|
#endif
|
|
}
|
|
|
|
} // namespace tflite
|
|
|
|
int main(int argc, char** argv) {
|
|
::testing::InitGoogleTest(&argc, argv);
|
|
return RUN_ALL_TESTS();
|
|
}
|