// Copyright 2017 The Abseil Authors. // // 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. #ifndef ABSL_TIME_INTERNAL_TEST_UTIL_H_ #define ABSL_TIME_INTERNAL_TEST_UTIL_H_ #include #include "gmock/gmock.h" #include "gtest/gtest.h" #include "absl/time/time.h" // This helper is a macro so that failed expectations show up with the // correct line numbers. // // This is for internal testing of the Base Time library itself. This is not // part of a public API. #define ABSL_INTERNAL_EXPECT_TIME(bd, y, m, d, h, min, s, off, isdst) \ do { \ EXPECT_EQ(y, bd.year); \ EXPECT_EQ(m, bd.month); \ EXPECT_EQ(d, bd.day); \ EXPECT_EQ(h, bd.hour); \ EXPECT_EQ(min, bd.minute); \ EXPECT_EQ(s, bd.second); \ EXPECT_EQ(off, bd.offset); \ EXPECT_EQ(isdst, bd.is_dst); \ EXPECT_THAT(bd.zone_abbr, \ testing::MatchesRegex(absl::time_internal::kZoneAbbrRE)); \ } while (0) namespace absl { inline namespace lts_2018_06_20 { namespace time_internal { // A regular expression that matches all zone abbreviations (%Z). extern const char kZoneAbbrRE[]; // Loads the named timezone, but dies on any failure. absl::TimeZone LoadTimeZone(const std::string& name); } // namespace time_internal } // inline namespace lts_2018_06_20 } // namespace absl #endif // ABSL_TIME_INTERNAL_TEST_UTIL_H_