mirror of
https://github.com/chromium/crashpad.git
synced 2024-12-28 07:48:14 +08:00
50ed179e9a
Use BUILDFLAG(IS_*) instead of defined(OS_*). This was generated mostly mechnically by performing the following steps: - sed -i '' -E -e 's/defined\(OS_/BUILDFLAG(IS_/g' \ -e 's%([ !])OS_([A-Z]+)%\1BUILDFLAG(IS_\2)%g' \ $(git grep -l 'OS_' '**/*.c' '**/*.cc' '**/*.h' '**/*.m' '**/*.mm') - sed -i '' -e 's/#ifdef BUILDFLAG(/#if BUILDFLAG(/' \ $(git grep -l '#ifdef BUILDFLAG(' '**/*.c' '**/*.cc' '**/*.h' '**/*.m' '**/*.mm') - gsed -i -z -E -e \ 's%(.*)#include "%\1#include "build/buildflag.h"\n#include "%' \ $(git grep -l 'BUILDFLAG(IS_' '**/*.c' '**/*.cc' '**/*.h' '**/*.m' '**/*.mm') - Spot checks to move #include "build/buildflag.h" to the correct parts of files. - sed -i '' -E -e \ 's%^(#include "build/buildflag.h")$%#include "build/build_config.h"\n\1%' \ $(grep -L '^#include "build/build_config.h"$' $(git grep -l 'BUILDFLAG(IS_' '**/*.c' '**/*.cc' '**/*.h' '**/*.m' '**/*.mm')) - Add “clang-format off” around tool usage messages. - git cl format - Update mini_chromium to 85ba51f98278 (intermediate step). TESTING ONLY). - for f in $(git grep -l '^#include "build/buildflag.h"$' '**/*.c' '**/*.cc' '**/*.h' '**/*.m' '**/*.mm'); do \ grep -v '^#include "build/buildflag.h"$' "${f}" > /tmp/z; \ cp /tmp/z "${f}"; done - git cl format - Update mini_chromium to 735143774c5f (intermediate step). - Update mini_chromium to f41420eb45fa (as checked in). - Update mini_chromium to 6e2f204b4ae1 (as checked in). For ease of review and inspection, each of these steps is uploaded as a new patch set in a review series. This includes an update of mini_chromium to 6e2f204b4ae1: f41420eb45fa Use BUILDFLAG for OS checking 6e2f204b4ae1 Include what you use: string_util.h uses build_config.h Bug: chromium:1234043 Change-Id: Ieef86186f094c64e59b853729737e36982f8cf69 Reviewed-on: https://chromium-review.googlesource.com/c/crashpad/crashpad/+/3400258 Reviewed-by: Joshua Peraza <jperaza@chromium.org> Commit-Queue: Mark Mentovai <mark@chromium.org>
134 lines
5.8 KiB
C
134 lines
5.8 KiB
C
// Copyright 2015 The Crashpad 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.
|
||
|
||
#ifndef CRASHPAD_TEST_GTEST_DEATH_H_
|
||
#define CRASHPAD_TEST_GTEST_DEATH_H_
|
||
|
||
#include "base/logging.h"
|
||
#include "build/build_config.h"
|
||
#include "gtest/gtest.h"
|
||
|
||
#if BUILDFLAG(IS_APPLE)
|
||
#include "test/mac/exception_swallower.h"
|
||
#endif
|
||
|
||
//! \file
|
||
|
||
#if BUILDFLAG(IS_MAC) || DOXYGEN
|
||
|
||
//! \brief Wraps the Google Test `ASSERT_DEATH_IF_SUPPORTED()` macro to make
|
||
//! assertions about death caused by crashes.
|
||
//!
|
||
//! On macOS, this macro prevents the system’s crash reporter from handling
|
||
//! crashes that occur in \a statement. Crashes are normally visible to the
|
||
//! system’s crash reporter, but it is undesirable for intentional
|
||
//! ASSERT_DEATH_CRASH() crashes to be handled by any crash reporter.
|
||
//!
|
||
//! `ASSERT_DEATH_IF_SUPPORTED()` is used instead of `ASSERT_DEATH()` to support
|
||
//! platforms where death tests are not implemented by Google Test (e.g.
|
||
//! Fuchsia). On platforms where death tests are not implemented, a warning will
|
||
//! be logged and the remainder of the test body skipped.
|
||
//!
|
||
//! \sa ASSERT_DEATH_CHECK()
|
||
//! \sa EXPECT_DEATH_CRASH()
|
||
#define ASSERT_DEATH_CRASH(statement, regex) \
|
||
do { \
|
||
crashpad::test::ExceptionSwallower exception_swallower; \
|
||
ASSERT_DEATH_IF_SUPPORTED( \
|
||
crashpad::test::ExceptionSwallower::SwallowExceptions(); \
|
||
{ statement; }, regex); \
|
||
} while (false)
|
||
|
||
//! \brief Wraps the Google Test `EXPECT_DEATH_IF_SUPPORTED()` macro to make
|
||
//! assertions about death caused by crashes.
|
||
//!
|
||
//! On macOS, this macro prevents the system’s crash reporter from handling
|
||
//! crashes that occur in \a statement. Crashes are normally visible to the
|
||
//! system’s crash reporter, but it is undesirable for intentional
|
||
//! EXPECT_DEATH_CRASH() crashes to be handled by any crash reporter.
|
||
//!
|
||
//! `EXPECT_DEATH_IF_SUPPORTED()` is used instead of `EXPECT_DEATH()` to support
|
||
//! platforms where death tests are not implemented by Google Test (e.g.
|
||
//! Fuchsia). On platforms where death tests are not implemented, a warning will
|
||
//! be logged and the remainder of the test body skipped.
|
||
//!
|
||
//! \sa EXPECT_DEATH_CHECK()
|
||
//! \sa ASSERT_DEATH_CRASH()
|
||
#define EXPECT_DEATH_CRASH(statement, regex) \
|
||
do { \
|
||
crashpad::test::ExceptionSwallower exception_swallower; \
|
||
EXPECT_DEATH(crashpad::test::ExceptionSwallower::SwallowExceptions(); \
|
||
{ statement; }, \
|
||
regex); \
|
||
} while (false)
|
||
|
||
#else // BUILDFLAG(IS_MAC)
|
||
|
||
#define ASSERT_DEATH_CRASH(statement, regex) \
|
||
ASSERT_DEATH_IF_SUPPORTED(statement, regex)
|
||
#define EXPECT_DEATH_CRASH(statement, regex) \
|
||
EXPECT_DEATH_IF_SUPPORTED(statement, regex)
|
||
|
||
#endif // BUILDFLAG(IS_MAC)
|
||
|
||
#if !(!defined(MINI_CHROMIUM_BASE_LOGGING_H_) && \
|
||
defined(OFFICIAL_BUILD) && \
|
||
defined(NDEBUG)) || \
|
||
DOXYGEN
|
||
|
||
//! \brief Wraps the ASSERT_DEATH_CRASH() macro to make assertions about death
|
||
//! caused by `CHECK()` failures.
|
||
//!
|
||
//! In an in-Chromium build in the official configuration, `CHECK()` does not
|
||
//! print its condition or streamed messages. In that case, this macro uses an
|
||
//! empty \a regex pattern when calling ASSERT_DEATH_CRASH() to avoid looking
|
||
//! for any particular output on the standard error stream. In other build
|
||
//! configurations, the \a regex pattern is left intact.
|
||
//!
|
||
//! On macOS, `CHECK()` failures normally show up as crashes to the system’s
|
||
//! crash reporter, but it is undesirable for intentional ASSERT_DEATH_CHECK()
|
||
//! crashes to be handled by any crash reporter, so this is implemented in
|
||
//! terms of ASSERT_DEATH_CRASH() instead of `ASSERT_DEATH()`.
|
||
//!
|
||
//! \sa EXPECT_DEATH_CHECK()
|
||
#define ASSERT_DEATH_CHECK(statement, regex) \
|
||
ASSERT_DEATH_CRASH(statement, regex)
|
||
|
||
//! \brief Wraps the EXPECT_DEATH_CRASH() macro to make assertions about death
|
||
//! caused by `CHECK()` failures.
|
||
//!
|
||
//! In an in-Chromium build in the official configuration, `CHECK()` does not
|
||
//! print its condition or streamed messages. In that case, this macro uses an
|
||
//! empty \a regex pattern when calling EXPECT_DEATH_CRASH() to avoid looking
|
||
//! for any particular output on the standard error stream. In other build
|
||
//! configurations, the \a regex pattern is left intact.
|
||
//!
|
||
//! On macOS, `CHECK()` failures normally show up as crashes to the system’s
|
||
//! crash reporter, but it is undesirable for intentional EXPECT_DEATH_CHECK()
|
||
//! crashes to be handled by any crash reporter, so this is implemented in
|
||
//! terms of EXPECT_DEATH_CRASH() instead of `EXPECT_DEATH()`.
|
||
//!
|
||
//! \sa ASSERT_DEATH_CHECK()
|
||
#define EXPECT_DEATH_CHECK(statement, regex) \
|
||
EXPECT_DEATH_CRASH(statement, regex)
|
||
|
||
#else // !(!MINI_CHROMIUM_BASE_LOGGING_H_ && OFFICIAL_BUILD && NDEBUG)
|
||
|
||
#define ASSERT_DEATH_CHECK(statement, regex) ASSERT_DEATH_CRASH(statement, "")
|
||
#define EXPECT_DEATH_CHECK(statement, regex) EXPECT_DEATH_CRASH(statement, "")
|
||
|
||
#endif // !(!MINI_CHROMIUM_BASE_LOGGING_H_ && OFFICIAL_BUILD && NDEBUG)
|
||
|
||
#endif // CRASHPAD_TEST_GTEST_DEATH_H_
|