/*********************************************************************
* Software License Agreement (AGPL-3 License)
*
* OpenViBE SDK Test Software
* Based on OpenViBE V1.1.0, Copyright (C) Inria, 2006-2015
* Copyright (C) Inria, 2015-2017,V1.0
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License version 3,
* as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program.
* If not, see .
*/
#include
#include
#include
#include "ebml/defines.h"
#include "ebml/IWriter.h"
#include "ebml/CWriterHelper.h"
#include "ovtAssert.h"
#include
#define OVP_NodeId_OpenViBEStream_Header EBML::CIdentifier(0xF59505AB, 0x3684C8D8)
#define OVP_NodeId_OpenViBEStream_Header_Compression EBML::CIdentifier(0x40358769, 0x166380D1)
#define OVP_NodeId_OpenViBEStream_Header_StreamType EBML::CIdentifier(0x732EC1D1, 0xFE904087)
#define OVP_NodeId_OpenViBEStream_Buffer EBML::CIdentifier(0x2E60AD18, 0x87A29BDF)
#define OVP_NodeId_OpenViBEStream_Buffer_StreamIndex EBML::CIdentifier(0x30A56D8A, 0xB9C12238)
#define OVP_NodeId_OpenViBEStream_Buffer_StartTime EBML::CIdentifier(0x093E6A0A, 0xC5A9467B)
#define OVP_NodeId_OpenViBEStream_Buffer_EndTime EBML::CIdentifier(0x8B5CCCD9, 0xC5024F29)
#define OVP_NodeId_OpenViBEStream_Buffer_Content EBML::CIdentifier(0x8D4B0BE8, 0x7051265C)
#ifndef M_PI
#define M_PI 3.1415926535897932384626433832795
#endif
class CWriterCallBack : public EBML::IWriterCallBack
{
public:
CWriterCallBack(const char* filename) { m_file = std::fopen(filename, "wb"); }
~CWriterCallBack() override { if (m_file) { std::fclose(m_file); } } // in case release is not called
void write(const void* buffer, const size_t size) override { if (m_file) { std::fwrite(buffer, size_t(size), 1, m_file); } }
// necessary thjor the test to close the stream and re-open it for inspection
void release()
{
std::fclose(m_file);
m_file = nullptr;
}
private:
std::FILE* m_file{ nullptr };
};
int uoEBMLWriterTest(int argc, char* argv[])
{
OVT_ASSERT(argc == 3, "Failure to retrieve tests arguments. Expecting: data_dir output_dir");
const std::string expectedFile = std::string(argv[1]) + "ref_data.ebml";
const std::string outputFile = std::string(argv[2]) + "uoEBMLWriterTest.ebml";
// The test serializes a known ebml sequence and compares the output
// to a reference.
// serializing
CWriterCallBack callback(outputFile.c_str());
EBML::IWriter* writer = createWriter(callback);
EBML::CWriterHelper helper;
helper.connect(writer);
helper.openChild(EBML_Identifier_Header);
helper.openChild(EBML_Identifier_DocType);
helper.setStr("matroska");
helper.closeChild();
helper.openChild(EBML_Identifier_DocTypeVersion);
helper.setUInt(1);
helper.closeChild();
helper.openChild(EBML_Identifier_DocTypeReadVersion);
helper.setInt(655356);
helper.closeChild();
helper.closeChild();
helper.openChild(0x1234);
helper.setUInt(0);
helper.closeChild();
helper.openChild(0xffffffffffffffffLL);
helper.setUInt(0xff000000ff000000LL);
helper.closeChild();
helper.openChild(0x4321);
helper.setDouble(M_PI);
helper.closeChild();
helper.openChild(0x8765);
helper.setFloat(float(M_PI));
helper.closeChild();
writer->release();
callback.release();
// comparison part
std::ifstream generatedStream(outputFile, std::ios::binary);
std::ifstream expectedStream(expectedFile, std::ios::binary);
OVT_ASSERT(generatedStream.is_open(), "Failure to open generated ebml stream for reading");
OVT_ASSERT(expectedStream.is_open(), "Failure to open reference stream for reading");
char generatedChar;
char expectedChar;
while (expectedStream.get(expectedChar))
{
OVT_ASSERT(generatedStream.get(generatedChar), "Failure to retrieve a char to match");
OVT_ASSERT(generatedChar == expectedChar, "Failure to match expected char to generated char");
}
// last check to verify the expected file has no additional line
OVT_ASSERT(!generatedStream.get(generatedChar), "Failure to match expected file size and generated file size");
return EXIT_SUCCESS;
}