When running some tests with --gtest_repeat=100 --gtest_shuffle, I
encountered some problems because the allocator wasn't torn down
completely, and the singleton pointer ended up pointing to a
use-after-scope'd object.
This patch has a couple of fixes and niceties:
1. Removing the once-init stuff from tests, now that it's implicitly
done in GuardedPoolAllocator::installAtFork() anyway.
2. Calling uninitTestOnly() in the late_init test.
3. Resetting the HasReportedBadPoolAccess when the signal handlers are
installed (allowing for --gtest_repeat w/ recoverable mode).
4. Adding a check and resetting the singleton pointer in
uninitTestOnly().
27 lines
794 B
C++
27 lines
794 B
C++
//===-- late_init.cpp -------------------------------------------*- C++ -*-===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "gwp_asan/guarded_pool_allocator.h"
|
|
#include "gwp_asan/options.h"
|
|
#include "gwp_asan/tests/harness.h"
|
|
|
|
TEST(LateInit, CheckLateInitIsOK) {
|
|
gwp_asan::GuardedPoolAllocator GPA;
|
|
|
|
for (size_t i = 0; i < 0x100; ++i)
|
|
EXPECT_FALSE(GPA.shouldSample());
|
|
|
|
gwp_asan::options::Options Opts;
|
|
Opts.Enabled = true;
|
|
Opts.SampleRate = 1;
|
|
|
|
GPA.init(Opts);
|
|
EXPECT_TRUE(GPA.shouldSample());
|
|
GPA.uninitTestOnly();
|
|
}
|