forked from OSchip/llvm-project
5dca0596a9
Summary: Many of our tests need to initialize certain subsystems/plugins of LLDB such as `FileSystem` or `HostInfo` by calling their static `Initialize` functions before the test starts and then calling `::Terminate` after the test is done (in reverse order). This adds a lot of error-prone boilerplate code to our testing code. This patch adds a RAII called SubsystemRAII that ensures that we always call ::Initialize and then call ::Terminate after the test is done (and that the Terminate calls are always in the reverse order of the ::Initialize calls). It also gets rid of all of the boilerplate that we had for these calls. Per-fixture initialization is still not very nice with this approach as it would require some kind of static unique_ptr that gets manually assigned/reseted from the gtest SetUpTestCase/TearDownTestCase functions. Because of that I changed all per-fixture setup to now do per-test setup which can be done by just having the SubsystemRAII as a member of the test fixture. This change doesn't influence our normal test runtime as LIT anyway runs each test case separately (and the Initialize/Terminate calls are anyway not very expensive). It will however make running all tests in a single executable slightly slower. Reviewers: labath, JDevlieghere, martong, espindola, shafik Reviewed By: labath Subscribers: mgorny, rnkovacs, emaste, MaskRay, abidh, lldb-commits Tags: #lldb Differential Revision: https://reviews.llvm.org/D71630 |
||
---|---|---|
.. | ||
Inputs | ||
AnsiTerminalTest.cpp | ||
ArchSpecTest.cpp | ||
ArgsTest.cpp | ||
BroadcasterTest.cpp | ||
CMakeLists.txt | ||
CompletionRequestTest.cpp | ||
ConstStringTest.cpp | ||
DataExtractorTest.cpp | ||
EnvironmentTest.cpp | ||
EventTest.cpp | ||
FileSpecTest.cpp | ||
FlagsTest.cpp | ||
ListenerTest.cpp | ||
LogTest.cpp | ||
NameMatchesTest.cpp | ||
OptionsWithRawTest.cpp | ||
PredicateTest.cpp | ||
ProcessInfoTest.cpp | ||
ProcessInstanceInfoTest.cpp | ||
RangeMapTest.cpp | ||
RangeTest.cpp | ||
RegisterValueTest.cpp | ||
RegularExpressionTest.cpp | ||
ReproducerInstrumentationTest.cpp | ||
ReproducerTest.cpp | ||
ScalarTest.cpp | ||
StateTest.cpp | ||
StatusTest.cpp | ||
StreamTeeTest.cpp | ||
StreamTest.cpp | ||
StringExtractorTest.cpp | ||
StringLexerTest.cpp | ||
StringListTest.cpp | ||
StructuredDataTest.cpp | ||
SubsystemRAIITest.cpp | ||
TildeExpressionResolverTest.cpp | ||
TimeoutTest.cpp | ||
TimerTest.cpp | ||
UUIDTest.cpp | ||
UriParserTest.cpp | ||
UserIDResolverTest.cpp | ||
VASprintfTest.cpp | ||
VMRangeTest.cpp |