Skip to content

Commit

Permalink
Add tests for the Header class.
Browse files Browse the repository at this point in the history
These are intended to exercise methods that are currently not covered by
other tests according to the coverage report.

Signed-off-by: Ben Grimes <[email protected]>
  • Loading branch information
MrGlobby committed Oct 16, 2023
1 parent de791a5 commit 4245a62
Show file tree
Hide file tree
Showing 4 changed files with 122 additions and 0 deletions.
3 changes: 3 additions & 0 deletions src/test/OpenEXRTest/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,8 @@ add_executable(OpenEXRTest
testExistingStreams.h
testFutureProofing.cpp
testFutureProofing.h
testHeader.cpp
testHeader.h
testHuf.cpp
testHuf.h
testIDManifest.cpp
Expand Down Expand Up @@ -169,6 +171,7 @@ define_openexr_tests(
testDwaLookups
testExistingStreams
testFutureProofing
testHeader
testHuf
testInputPart
testIsComplete
Expand Down
2 changes: 2 additions & 0 deletions src/test/OpenEXRTest/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@
#include "testDwaLookups.h"
#include "testExistingStreams.h"
#include "testFutureProofing.h"
#include "testHeader.h"
#include "testHuf.h"
#include "testIDManifest.h"
#include "testInputPart.h"
Expand Down Expand Up @@ -232,6 +233,7 @@ main (int argc, char* argv[])
TEST (testDwaLookups, "core");
TEST (testIDManifest, "core");
TEST (testCpuId, "core");
TEST (testHeader, "basic");

// NB: If you add a test here, make sure to enumerate it in the
// CMakeLists.txt so it runs as part of the test suite
Expand Down
109 changes: 109 additions & 0 deletions src/test/OpenEXRTest/testHeader.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,109 @@
//
// SPDX-License-Identifier: BSD-3-Clause
// Copyright (c) Contributors to the OpenEXR Project.
//

#ifdef NDEBUG
# undef NDEBUG
#endif

#include <ImfBoxAttribute.h>
#include <ImfHeader.h>

#include <exception>
#include <iostream>
#include <string>

#include <assert.h>

using namespace IEX_NAMESPACE;
using namespace IMATH_NAMESPACE;
using namespace OPENEXR_IMF_NAMESPACE;
using namespace std;

template<typename Header>
struct Test
{
void testFind(const string& name)
{
Header header;
auto iterator = header.find(name);
assert(iterator != header.end());
}

void testSubscript(const string& name)
{
Header header;
auto& comparand = header.find("displayWindow").attribute();
auto& attribute = header[name];
assert(&attribute == &comparand);
}

void testIterators(const string& name)
{
Header header;

auto& comparand = header.find("displayWindow").attribute();

for (auto iterator = header.begin(); iterator != header.end(); ++iterator)
{
if (iterator.name() == name)
{
assert(&iterator.attribute() == &comparand);
return;
}
}

assert (false);
}
};

void testEraseAttribute(const string& name)
{
Header header;
assert(header.find(name) != header.end());
header.erase(name);
assert(header.find(name) == header.end());
}

void testEraseAttributeThrowsWithEmptyString()
{
Header header;

try
{
header.erase("");
assert (false);
}
catch (const ArgExc&)
{
assert (true);
}
}

void testHeader (const string& tempDir)
{
try
{
{
Test<Header> headerTest;
headerTest.testFind("displayWindow");
headerTest.testSubscript("displayWindow");
headerTest.testIterators("displayWindow");
}
{
Test<const Header> headerTest;
headerTest.testFind("displayWindow");
headerTest.testSubscript("displayWindow");
headerTest.testIterators("displayWindow");
}
testEraseAttribute("displayWindow");
testEraseAttributeThrowsWithEmptyString();
cout << "ok\n" << endl;
}
catch (const exception& e)
{
cerr << "ERROR -- caught exception: " << e.what () << endl;
assert (false);
}
}
8 changes: 8 additions & 0 deletions src/test/OpenEXRTest/testHeader.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
//
// SPDX-License-Identifier: BSD-3-Clause
// Copyright (c) Contributors to the OpenEXR Project.
//

#include <string>

void testHeader (const std::string& tempDir);

0 comments on commit 4245a62

Please sign in to comment.