summaryrefslogtreecommitdiffstats
path: root/lldb/unittests/ObjectFile/ELF/TestObjectFileELF.cpp
diff options
context:
space:
mode:
authorRaphael Isemann <teemperor@gmail.com>2019-12-23 10:38:12 +0100
committerRaphael Isemann <teemperor@gmail.com>2019-12-23 10:38:25 +0100
commit5dca0596a959217a1c18858a62ed35245a4c42b4 (patch)
tree768403f9a80da341579c1e1c682fc240f98033e3 /lldb/unittests/ObjectFile/ELF/TestObjectFileELF.cpp
parent70fa4c4f88609044dd0cd9671139d02d578d0df9 (diff)
downloadbcm5719-llvm-5dca0596a959217a1c18858a62ed35245a4c42b4.tar.gz
bcm5719-llvm-5dca0596a959217a1c18858a62ed35245a4c42b4.zip
[lldb] Add a SubsystemRAII that takes care of calling Initialize and Terminate in the unit tests
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
Diffstat (limited to 'lldb/unittests/ObjectFile/ELF/TestObjectFileELF.cpp')
-rw-r--r--lldb/unittests/ObjectFile/ELF/TestObjectFileELF.cpp19
1 files changed, 3 insertions, 16 deletions
diff --git a/lldb/unittests/ObjectFile/ELF/TestObjectFileELF.cpp b/lldb/unittests/ObjectFile/ELF/TestObjectFileELF.cpp
index 6bf641847cd..01ad2ab4d19 100644
--- a/lldb/unittests/ObjectFile/ELF/TestObjectFileELF.cpp
+++ b/lldb/unittests/ObjectFile/ELF/TestObjectFileELF.cpp
@@ -9,6 +9,7 @@
#include "Plugins/ObjectFile/ELF/ObjectFileELF.h"
#include "Plugins/SymbolFile/Symtab/SymbolFileSymtab.h"
+#include "TestingSupport/SubsystemRAII.h"
#include "TestingSupport/TestUtilities.h"
#include "lldb/Core/Module.h"
#include "lldb/Core/ModuleSpec.h"
@@ -29,22 +30,8 @@ using namespace lldb_private;
using namespace lldb;
class ObjectFileELFTest : public testing::Test {
-public:
- void SetUp() override {
- FileSystem::Initialize();
- HostInfo::Initialize();
- ObjectFileELF::Initialize();
- SymbolFileSymtab::Initialize();
- }
-
- void TearDown() override {
- SymbolFileSymtab::Terminate();
- ObjectFileELF::Terminate();
- HostInfo::Terminate();
- FileSystem::Terminate();
- }
-
-protected:
+ SubsystemRAII<FileSystem, HostInfo, ObjectFileELF, SymbolFileSymtab>
+ subsystems;
};
TEST_F(ObjectFileELFTest, SectionsResolveConsistently) {
OpenPOWER on IntegriCloud