Skip to content
Snippets Groups Projects
EngineWriteReadTest.cpp 5.88 KiB
Newer Older
#include "EngineWriteReadTest.h"

#include <cstdint>

#include <array>
#include <iostream>
#include <stdexcept>

#include <adios2.h>

#include <gtest/gtest.h>

EngineWriteReadTestBase::EngineWriteReadTestBase(std::string engineName,
                                                 std::string fileName)
: m_EngineName(engineName), m_FileName(fileName), m_Method(nullptr)
{
}

void EngineWriteReadTestBase::SetUp()
{
    m_adios = std::unique_ptr<adios::ADIOS>(
        new adios::ADIOS(adios::Verbose::WARN, true));
}

void EngineWriteReadTestBase::TearDown() { m_adios.reset(); }

void EngineWriteReadTestBase::SetUpWrite()
{
    m_Method = &m_adios->DeclareMethod("TestMethod");
    m_Method->SetEngine(m_EngineName);
    m_Method->AddTransport("File");
    m_Engine = m_adios->Open(m_FileName, "w", *m_Method);
    ASSERT_NE(m_Engine, nullptr);
}

void EngineWriteReadTestBase::TearDownWrite()
{
    m_Method = nullptr;
    m_Engine->Close();
    m_Engine.reset();
}

void EngineWriteReadTestBase::WriteStep(size_t step)
{
    auto &var_i8 = m_adios->GetVariable<char>("i8");
    auto &var_i16 = m_adios->GetVariable<short>("i16");
    auto &var_i32 = m_adios->GetVariable<int>("i32");
    auto &var_i64 = m_adios->GetVariable<long>("i64");
    auto &var_u8 = m_adios->GetVariable<unsigned char>("u8");
    auto &var_u16 = m_adios->GetVariable<unsigned short>("u16");
    auto &var_u32 = m_adios->GetVariable<unsigned int>("u32");
    auto &var_u64 = m_adios->GetVariable<unsigned long>("u64");
    auto &var_r32 = m_adios->GetVariable<float>("r32");
    auto &var_r64 = m_adios->GetVariable<double>("r64");

    m_Engine->Write(var_i8, m_DataI8.cbegin() + step);
    m_Engine->Write(var_i16, m_DataI16.cbegin() + step);
    m_Engine->Write(var_i32, m_DataI32.cbegin() + step);
    m_Engine->Write(var_i64, m_DataI64.cbegin() + step);
    m_Engine->Write(var_u8, m_DataU8.cbegin() + step);
    m_Engine->Write(var_u16, m_DataU16.cbegin() + step);
    m_Engine->Write(var_u32, m_DataU32.cbegin() + step);
    m_Engine->Write(var_u64, m_DataU64.cbegin() + step);
    m_Engine->Write(var_r32, m_DataR32.cbegin() + step);
    m_Engine->Write(var_r64, m_DataR64.cbegin() + step);
}

void EngineWriteReadTestBase::Write3Steps()
{
    for (size_t t = 0; t < 3; ++t)
    {
        WriteStep(t);
        m_Engine->Advance();
    }
}

void EngineWriteReadTestBase::WriteRead()
{
    Declare();
    SetUpWrite();
    Write3Steps();
    TearDownWrite();
}

//******************************************************************************
// 1D test data
//******************************************************************************

void EngineWriteRead1DTest::Declare()
{
    auto &var_i8 = m_adios->DefineVariable<char>("i8", adios::Dims{8});
    auto &var_i16 = m_adios->DefineVariable<short>("i16", adios::Dims{8});
    auto &var_i32 = m_adios->DefineVariable<int>("i32", adios::Dims{8});
    auto &var_i64 = m_adios->DefineVariable<long>("i64", adios::Dims{8});
    auto &var_u8 = m_adios->DefineVariable<unsigned char>("u8", adios::Dims{8});
    auto &var_u16 =
        m_adios->DefineVariable<unsigned short>("u16", adios::Dims{8});
    auto &var_u32 =
        m_adios->DefineVariable<unsigned int>("u32", adios::Dims{8});
    auto &var_u64 =
        m_adios->DefineVariable<unsigned long>("u64", adios::Dims{8});
    auto &var_r32 = m_adios->DefineVariable<float>("r32", adios::Dims{8});
    auto &var_r64 = m_adios->DefineVariable<double>("r64", adios::Dims{8});
}

//******************************************************************************
// 2D 2x4 test data
//******************************************************************************

void EngineWriteRead2D2x4Test::Declare()
{
    auto &var_i8 = m_adios->DefineVariable<char>("i8", adios::Dims{2, 4});
    auto &var_i16 = m_adios->DefineVariable<short>("i16", adios::Dims{2, 4});
    auto &var_i32 = m_adios->DefineVariable<int>("i32", adios::Dims{2, 4});
    auto &var_i64 = m_adios->DefineVariable<long>("i64", adios::Dims{2, 4});
    auto &var_u8 =
        m_adios->DefineVariable<unsigned char>("u8", adios::Dims{2, 4});
    auto &var_u16 =
        m_adios->DefineVariable<unsigned short>("u16", adios::Dims{2, 4});
    auto &var_u32 =
        m_adios->DefineVariable<unsigned int>("u32", adios::Dims{2, 4});
    auto &var_u64 =
        m_adios->DefineVariable<unsigned long>("u64", adios::Dims{2, 4});
    auto &var_r32 = m_adios->DefineVariable<float>("r32", adios::Dims{2, 4});
    auto &var_r64 = m_adios->DefineVariable<double>("r64", adios::Dims{2, 4});
}

//******************************************************************************
// 2D 4x2 test data
//******************************************************************************

void EngineWriteRead2D4x2Test::Declare()
{
    auto &var_i8 = m_adios->DefineVariable<char>("i8", adios::Dims{4, 2});
    auto &var_i16 = m_adios->DefineVariable<short>("i16", adios::Dims{4, 2});
    auto &var_i32 = m_adios->DefineVariable<int>("i32", adios::Dims{4, 2});
    auto &var_i64 = m_adios->DefineVariable<long>("i64", adios::Dims{4, 2});
    auto &var_u8 =
        m_adios->DefineVariable<unsigned char>("u8", adios::Dims{4, 2});
    auto &var_u16 =
        m_adios->DefineVariable<unsigned short>("u16", adios::Dims{4, 2});
    auto &var_u32 =
        m_adios->DefineVariable<unsigned int>("u32", adios::Dims{4, 2});
    auto &var_u64 =
        m_adios->DefineVariable<unsigned long>("u64", adios::Dims{4, 2});
    auto &var_r32 = m_adios->DefineVariable<float>("r32", adios::Dims{4, 2});
    auto &var_r64 = m_adios->DefineVariable<double>("r64", adios::Dims{4, 2});
}

//******************************************************************************
// main
//******************************************************************************

int main(int argc, char **argv)
{
#ifdef ADIOS2_HAVE_MPI
    MPI_Init(nullptr, nullptr);
#endif

    ::testing::InitGoogleTest(&argc, argv);
    int result = RUN_ALL_TESTS();

#ifdef ADIOS2_HAVE_MPI
    MPI_Finalize();
#endif

    return result;
}