Files
comaps/coding/coding_tests/dd_vector_test.cpp
Konstantin Pastbin e3e4a1985a Organic Maps sources as of 02.04.2025 (fad26bbf22ac3da75e01e62aa01e5c8e11861005)
To expand with full Organic Maps and Maps.ME commits history run:
  git remote add om-historic [om-historic.git repo url]
  git fetch --tags om-historic
  git replace squashed-history historic-commits
2025-05-08 21:10:51 +07:00

46 lines
998 B
C++

#include "testing/testing.hpp"
#include "coding/dd_vector.hpp"
#include "coding/reader.hpp"
#include <cstdint>
#include <vector>
UNIT_TEST(DDVector_Smoke)
{
std::vector<uint16_t> data;
// Push size. Big endian is used.
data.push_back(1);
data.push_back(2);
data.push_back(3);
typedef DDVector<uint16_t, MemReader> Vector;
MemReader reader(reinterpret_cast<char const *>(&data[0]), data.size() * sizeof(data[0]));
Vector v(reader);
TEST_EQUAL(3, v.size(), ());
TEST_EQUAL(1, v[0], ());
TEST_EQUAL(2, v[1], ());
TEST_EQUAL(3, v[2], ());
Vector::const_iterator it = v.begin();
for (auto const value : v)
TEST_EQUAL(value, *it++, ());
}
UNIT_TEST(DDVector_IncorrectSize)
{
typedef DDVector<uint16_t, MemReader> Vector;
char const data[] = "ab";
MemReader reader(data, ARRAY_SIZE(data));
bool exceptionCaught = false;
try
{
Vector v(reader);
}
catch (Vector::OpenException & e)
{
exceptionCaught = true;
}
TEST(exceptionCaught, ());
}