// Copyright 2022 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include <vector> #include "base/check.h" #include "build/build_config.h" #include "testing/gmock/include/gmock/gmock.h" #include "testing/gtest/include/gtest/gtest.h" namespace { // TODO(thakis): Remove _LIBCPP_ENABLE_ASSERTIONS here once // pnacl-saigo's libc++ is new enough. #if defined(__GLIBCXX__) #if !defined(_GLIBCXX_ASSERTIONS) #error "libstdc++ assertions should be enabled" #endif #elif !_LIBCPP_ENABLE_ASSERTIONS && \ _LIBCPP_HARDENING_MODE != _LIBCPP_HARDENING_MODE_EXTENSIVE #error "_LIBCPP_HARDENING_MODE not defined" #endif ContainsRegex; Not; // This test checks for two things: // // 0. Assertions are enabled for libc++ and cause the process to crash when // invoked (in this test's case, when an out of bounds access is made in // std::vector. // 1. The correct assertion handler is linked in depending on whether or not // this test is built in debug mode. libc++ passes the string // {file}:{line} assertion {expression} failed: {message}. The default // libc++ handler, which we use in debug mode, prints this string to stderr, // while the nondebug assertion handler just crashes immediately. Therefore, // to check that we linked in the correct assertion handler, we check for the // presence or absence of the above string. TEST(LibcppHardeningTest, Assertions) { … } } // namespace