1948f6f967
-- bc74316103bbda92541896f588f71c9d45bea768 by Gennadiy Civil <misterg@google.com>: Manually fixing the BUILD.bazel files -- d41bf9ea916a0dc8c69e6ba77f58f9d55649880e by Shaindel Schwartz <shaindel@google.com>: Minor cleanup to miscellaneous BUILD files. PiperOrigin-RevId: 266420157 -- 08a8dc2cbd48d27e1115809f9ca8d178551cd66e by Gennadiy Civil <misterg@google.com>: Internal Change BEGIN_PUBLIC Internal Change END_PUBLIC -- 8617d58fde1ece40e4aa79eaa5e250b42d19835f by Shaindel Schwartz <shaindel@google.com>: Internal Change BEGIN_PUBLIC Internal Change END_PUBLIC -- 3a0fc7d48bdc70c4f7dffc219578693dea84eb2d by Derek Mauro <dmauro@google.com>: Implement absl::string_view::at() PiperOrigin-RevId: 266024644 -- ba53a9da8ede8fe7b8971eaab6b3a1fa34763ff6 by Andy Soffer <asoffer@google.com>: Remove forcing of optimization levels in MSVC. PiperOrigin-RevId: 265927588 -- df86f2046b54bba7da2e345040806d43470de5c0 by Shaindel Schwartz <shaindel@google.com>: Internal change PiperOrigin-RevId: 265811077 -- e2e3a6e8194363e7c6377672560c806d638a7c74 by Derek Mauro <dmauro@google.com>: Remove ABI unsafe mixed exceptions mode compilation. Testing will now be done on CI with the exceptions flag set globally. PiperOrigin-RevId: 265796079 GitOrigin-RevId: bc74316103bbda92541896f588f71c9d45bea768 Change-Id: Ibccd00f4829520454aa55c4f55c7cb2dc9c6b65a
79 lines
2.2 KiB
C++
79 lines
2.2 KiB
C++
// 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
|
|
//
|
|
// https://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 "absl/base/internal/exception_safety_testing.h"
|
|
|
|
#ifdef ABSL_HAVE_EXCEPTIONS
|
|
|
|
#include "gtest/gtest.h"
|
|
#include "absl/meta/type_traits.h"
|
|
|
|
namespace testing {
|
|
|
|
exceptions_internal::NoThrowTag nothrow_ctor;
|
|
|
|
exceptions_internal::StrongGuaranteeTagType strong_guarantee;
|
|
|
|
exceptions_internal::ExceptionSafetyTestBuilder<> MakeExceptionSafetyTester() {
|
|
return {};
|
|
}
|
|
|
|
namespace exceptions_internal {
|
|
|
|
int countdown = -1;
|
|
|
|
ConstructorTracker* ConstructorTracker::current_tracker_instance_ = nullptr;
|
|
|
|
void MaybeThrow(absl::string_view msg, bool throw_bad_alloc) {
|
|
if (countdown-- == 0) {
|
|
if (throw_bad_alloc) throw TestBadAllocException(msg);
|
|
throw TestException(msg);
|
|
}
|
|
}
|
|
|
|
testing::AssertionResult FailureMessage(const TestException& e,
|
|
int countdown) noexcept {
|
|
return testing::AssertionFailure() << "Exception thrown from " << e.what();
|
|
}
|
|
|
|
std::string GetSpecString(TypeSpec spec) {
|
|
std::string out;
|
|
absl::string_view sep;
|
|
const auto append = [&](absl::string_view s) {
|
|
absl::StrAppend(&out, sep, s);
|
|
sep = " | ";
|
|
};
|
|
if (static_cast<bool>(TypeSpec::kNoThrowCopy & spec)) {
|
|
append("kNoThrowCopy");
|
|
}
|
|
if (static_cast<bool>(TypeSpec::kNoThrowMove & spec)) {
|
|
append("kNoThrowMove");
|
|
}
|
|
if (static_cast<bool>(TypeSpec::kNoThrowNew & spec)) {
|
|
append("kNoThrowNew");
|
|
}
|
|
return out;
|
|
}
|
|
|
|
std::string GetSpecString(AllocSpec spec) {
|
|
return static_cast<bool>(AllocSpec::kNoThrowAllocate & spec)
|
|
? "kNoThrowAllocate"
|
|
: "";
|
|
}
|
|
|
|
} // namespace exceptions_internal
|
|
|
|
} // namespace testing
|
|
|
|
#endif // ABSL_HAVE_EXCEPTIONS
|