2270 lines
71 KiB
C++

/******************************************************************************
The MIT License(MIT)
Embedded Template Library.
https://github.com/ETLCPP/etl
https://www.etlcpp.com
Copyright(c) 2014 John Wellbelove
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files(the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and / or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions :
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
******************************************************************************/
#include "unit_test_framework.h"
#include "etl/deque.h"
#include "etl/vector.h"
#include "data.h"
#include <vector>
#include <deque>
#include <array>
#include <algorithm>
#include <iostream>
#include <numeric>
#include <cstring>
#include <memory>
#include "etl/private/diagnostic_useless_cast_push.h"
namespace
{
SUITE(test_deque)
{
const size_t SIZE = 14UL;
typedef TestDataDC<std::string> DC;
typedef TestDataNDC<std::string> NDC;
typedef etl::deque<int, SIZE> DataInt;
typedef etl::ideque<int> IDataInt;
typedef etl::deque<DC, SIZE> DataDC;
typedef etl::deque<NDC, SIZE> DataNDC;
typedef etl::ideque<NDC> IDataNDC;
typedef std::deque<NDC> Compare_Data;
typedef std::deque<DC> Compare_DataDC;
NDC N0 = NDC("0");
NDC N1 = NDC("1");
NDC N2 = NDC("2");
NDC N3 = NDC("3");
NDC N4 = NDC("4");
NDC N5 = NDC("5");
NDC N6 = NDC("6");
NDC N7 = NDC("7");
NDC N8 = NDC("8");
NDC N9 = NDC("9");
NDC N10 = NDC("10");
NDC N11 = NDC("11");
NDC N12 = NDC("12");
NDC N13 = NDC("13");
NDC N14 = NDC("14");
NDC N15 = NDC("15");
NDC N16 = NDC("16");
NDC N17 = NDC("17");
NDC N999 = NDC("999");
std::vector<NDC> blank_data = { N999, N999, N999, N999, N999, N999, N999, N999, N999, N999, N999, N999, N999, N999 };
std::vector<NDC> initial_data = { N0, N1, N2, N3, N4, N5, N6, N7, N8, N9, N10, N11, N12, N13 };
std::vector<NDC> initial_data_excess = { N0, N1, N2, N3, N4, N5, N6, N7, N8, N9, N10, N11, N12, N13, N14 };
std::vector<NDC> initial_data_under = { N0, N1, N2, N3, N4, N5, N6, N7, N8, N9, N10, N11 };
std::vector<NDC> initial_data_small = { N0, N1, N2, N3, N4, N5, N6, N7, N8, N9 };
std::vector<NDC> insert_data = { N10, N11, N12, N13, N14 };
std::vector<DC> initial_data_dc = { DC("0"), DC("1"), DC("2"), DC("3"), DC("4"), DC("5"), DC("6"), DC("7"), DC("8"), DC("9"), DC("10"), DC("11"), DC("12"), DC("13") };
std::vector<int> int_data1 = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13 };
std::vector<int> int_data2 = { 15, 16, 17, 18 };
//*************************************************************************
TEST(test_constructor)
{
DataDC data;
CHECK(data.empty());
CHECK(!data.full());
CHECK(data.begin() == data.end());
CHECK_EQUAL(0U, data.size());
CHECK_EQUAL(SIZE, data.max_size());
}
//*************************************************************************
TEST(test_constructor_fill)
{
Compare_Data compare_data(SIZE, N999);
DataNDC data(SIZE, N999);
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_destruct_via_ideque)
{
int current_count = NDC::get_instance_count();
DataNDC* pdata = new DataNDC(SIZE, N999);
CHECK_EQUAL(int(current_count + SIZE), NDC::get_instance_count());
IDataNDC* pidata = pdata;
delete pidata;
CHECK_EQUAL(current_count, NDC::get_instance_count());
}
//*************************************************************************
TEST(test_constructor_fill_excess)
{
CHECK_THROW(DataNDC(SIZE + 1, N999), etl::deque_full);
}
//*************************************************************************
TEST(test_constructor_range)
{
Compare_Data compare_data(initial_data.begin(), initial_data.end());
DataNDC data(initial_data.begin(), initial_data.end());
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
#if ETL_HAS_INITIALIZER_LIST
//*************************************************************************
TEST(test_constructor_initializer_list)
{
Compare_Data compare_data = { N0, N1, N2, N3 };
DataNDC data = { N0, N1, N2, N3 };
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
#endif
//*************************************************************************
TEST(test_copy_constructor)
{
DataNDC deque1(initial_data.begin(), initial_data.end());
DataNDC deque2(deque1);
CHECK_EQUAL(deque1.size(), deque2.size());
CHECK(std::equal(deque1.begin(), deque1.end(), deque2.begin()));
}
//*************************************************************************
TEST(test_move_constructor)
{
typedef etl::deque<std::unique_ptr<uint32_t>, SIZE> Data;
std::unique_ptr<uint32_t> p1(new uint32_t(1U));
std::unique_ptr<uint32_t> p2(new uint32_t(2U));
std::unique_ptr<uint32_t> p3(new uint32_t(3U));
std::unique_ptr<uint32_t> p4(new uint32_t(4U));
Data deque1;
deque1.push_back(std::move(p1));
deque1.push_back(std::move(p2));
deque1.push_back(std::move(p3));
deque1.push_back(std::move(p4));
Data deque2(std::move(deque1));
CHECK_EQUAL(4U, deque2.size());
std::unique_ptr<uint32_t> pr = std::move(*deque2.begin());
CHECK_EQUAL(1U, *pr);
CHECK_EQUAL(2U, *deque2[1]);
CHECK_EQUAL(3U, *deque2[2]);
CHECK_EQUAL(4U, *deque2[3]);
}
//*************************************************************************
TEST(test_move_insert_erase)
{
typedef etl::deque<std::unique_ptr<uint32_t>, SIZE> Data;
std::unique_ptr<uint32_t> p1(new uint32_t(1U));
std::unique_ptr<uint32_t> p2(new uint32_t(2U));
std::unique_ptr<uint32_t> p3(new uint32_t(3U));
std::unique_ptr<uint32_t> p4(new uint32_t(4U));
Data deque1;
deque1.push_back(std::move(p1));
deque1.push_back(std::move(p2));
deque1.push_back(std::move(p4));
deque1.insert(deque1.begin() + 2U, std::move(p3));
CHECK_EQUAL(4U, deque1.size());
CHECK(bool(deque1[0]));
CHECK(bool(deque1[1]));
CHECK(bool(deque1[2]));
CHECK(bool(deque1[3]));
CHECK_EQUAL(1U, *deque1[0]);
CHECK_EQUAL(2U, *deque1[1]);
CHECK_EQUAL(3U, *deque1[2]);
CHECK_EQUAL(4U, *deque1[3]);
deque1.erase(deque1.begin() + 1);
CHECK(bool(deque1[0]));
CHECK(bool(deque1[1]));
CHECK(bool(deque1[2]));
CHECK_EQUAL(1U, *deque1[0]);
CHECK_EQUAL(3U, *deque1[1]);
CHECK_EQUAL(4U, *deque1[2]);
}
//*************************************************************************
TEST(test_assignment)
{
DataNDC deque1(initial_data.begin(), initial_data.end());
DataNDC deque2;
deque2 = deque1;
CHECK_EQUAL(deque1.size(), deque2.size());
CHECK(std::equal(deque1.begin(), deque1.end(), deque2.begin()));
}
//*************************************************************************
TEST(test_move_assignment)
{
typedef etl::deque<std::unique_ptr<uint32_t>, SIZE> Data;
std::unique_ptr<uint32_t> p1(new uint32_t(1U));
std::unique_ptr<uint32_t> p2(new uint32_t(2U));
std::unique_ptr<uint32_t> p3(new uint32_t(3U));
std::unique_ptr<uint32_t> p4(new uint32_t(4U));
std::unique_ptr<uint32_t> p5(new uint32_t(5U));
Data deque1;
deque1.push_back(std::move(p1));
deque1.push_back(std::move(p2));
deque1.push_back(std::move(p3));
deque1.push_back(std::move(p4));
Data deque2;
deque2.push_back(std::move(p5));
deque2 = std::move(deque1);
CHECK_EQUAL(4U, deque2.size());
CHECK_EQUAL(1U, *deque2[0]);
CHECK_EQUAL(2U, *deque2[1]);
CHECK_EQUAL(3U, *deque2[2]);
CHECK_EQUAL(4U, *deque2[3]);
}
//*************************************************************************
TEST(test_assignment_interface)
{
DataNDC deque1(initial_data.begin(), initial_data.end());
DataNDC deque2;
IDataNDC& ideque1 = deque1;
IDataNDC& ideque2 = deque2;
ideque2 = ideque1;
CHECK_EQUAL(deque1.size(), deque2.size());
CHECK(std::equal(deque1.begin(), deque1.end(), deque2.begin()));
}
//*************************************************************************
TEST(test_move_assignment_interface)
{
typedef etl::deque<std::unique_ptr<uint32_t>, SIZE> Data;
typedef etl::ideque<std::unique_ptr<uint32_t>> IData;
std::unique_ptr<uint32_t> p1(new uint32_t(1U));
std::unique_ptr<uint32_t> p2(new uint32_t(2U));
std::unique_ptr<uint32_t> p3(new uint32_t(3U));
std::unique_ptr<uint32_t> p4(new uint32_t(4U));
std::unique_ptr<uint32_t> p5(new uint32_t(5U));
Data deque1;
deque1.push_back(std::move(p1));
deque1.push_back(std::move(p2));
deque1.push_back(std::move(p3));
deque1.push_back(std::move(p4));
Data deque2;
deque2.push_back(std::move(p5));
IData& ideque1 = deque1;
IData& ideque2 = deque2;
ideque2 = std::move(ideque1);
CHECK_EQUAL(0U, deque1.size());
CHECK_EQUAL(4U, deque2.size());
CHECK_EQUAL(1U, *deque2[0]);
CHECK_EQUAL(2U, *deque2[1]);
CHECK_EQUAL(3U, *deque2[2]);
CHECK_EQUAL(4U, *deque2[3]);
}
//*************************************************************************
TEST(test_self_assignment)
{
DataNDC deque1(initial_data.begin(), initial_data.end());
DataNDC deque2(deque1);
#include "etl/private/diagnostic_self_assign_overloaded_push.h"
deque2 = deque2;
#include "etl/private/diagnostic_pop.h"
CHECK_EQUAL(deque1.size(), deque2.size());
CHECK(std::equal(deque1.begin(), deque1.end(), deque2.begin()));
}
//*************************************************************************
TEST(test_assign_range)
{
DataNDC data;
CHECK_NO_THROW(data.assign(initial_data.begin(), initial_data.end()));
CHECK_EQUAL(initial_data.size(), data.size());
CHECK(std::equal(initial_data.begin(), initial_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_assign_range_excess)
{
DataNDC data;
CHECK_THROW(data.assign(initial_data_excess.begin(), initial_data_excess.end()), etl::deque_full);
}
//*************************************************************************
TEST(test_assign_fill)
{
Compare_Data compare_data;
DataNDC data;
compare_data.assign(SIZE, N999);
CHECK_NO_THROW(data.assign(SIZE, N999));
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_assign_fill_excess)
{
DataNDC data;
CHECK_THROW(data.assign(SIZE + 1, N999), etl::deque_full);
}
//*************************************************************************
TEST(test_at)
{
Compare_Data compare_data(initial_data.begin(), initial_data.end());
DataNDC data(initial_data.begin(), initial_data.end());
CHECK_EQUAL(compare_data.at(0), data.at(0));
CHECK_EQUAL(compare_data.at(1), data.at(1));
CHECK_EQUAL(compare_data.at(2), data.at(2));
CHECK_EQUAL(compare_data.at(3), data.at(3));
CHECK_EQUAL(compare_data.at(4), data.at(4));
CHECK_EQUAL(compare_data.at(5), data.at(5));
}
//*************************************************************************
TEST(test_at_const)
{
const Compare_Data compare_data(initial_data.begin(), initial_data.end());
const DataNDC data(initial_data.begin(), initial_data.end());
CHECK_EQUAL(compare_data.at(0), data.at(0));
CHECK_EQUAL(compare_data.at(1), data.at(1));
CHECK_EQUAL(compare_data.at(2), data.at(2));
CHECK_EQUAL(compare_data.at(3), data.at(3));
CHECK_EQUAL(compare_data.at(4), data.at(4));
CHECK_EQUAL(compare_data.at(5), data.at(5));
}
//*************************************************************************
TEST(test_index_operator)
{
Compare_Data compare_data(initial_data.begin(), initial_data.end());
DataNDC data(initial_data.begin(), initial_data.end());
CHECK_EQUAL(compare_data[0], data[0]);
CHECK_EQUAL(compare_data[1], data[1]);
CHECK_EQUAL(compare_data[2], data[2]);
CHECK_EQUAL(compare_data[3], data[3]);
CHECK_EQUAL(compare_data[4], data[4]);
CHECK_EQUAL(compare_data[5], data[5]);
}
//*************************************************************************
TEST(test_index_operator_const)
{
const Compare_Data compare_data(initial_data.begin(), initial_data.end());
const DataNDC data(initial_data.begin(), initial_data.end());
CHECK_EQUAL(compare_data[0], data[0]);
CHECK_EQUAL(compare_data[1], data[1]);
CHECK_EQUAL(compare_data[2], data[2]);
CHECK_EQUAL(compare_data[3], data[3]);
CHECK_EQUAL(compare_data[4], data[4]);
CHECK_EQUAL(compare_data[5], data[5]);
}
//*************************************************************************
TEST(test_front)
{
DataNDC data;
data.push_front(N1);
CHECK_EQUAL(N1, data.front());
data.push_front(N2);
CHECK_EQUAL(N2, data.front());
data.push_front(N3);
CHECK_EQUAL(N3, data.front());
data.push_front(N4);
CHECK_EQUAL(N4, data.front());
data.push_front(N5);
CHECK_EQUAL(N5, data.front());
data.push_front(N6);
CHECK_EQUAL(N6, data.front());
}
//*************************************************************************
TEST(test_front_const)
{
DataNDC data;
const DataNDC& ctestDeque = data;
data.push_front(N1);
CHECK_EQUAL(N1, ctestDeque.front());
data.push_front(N2);
CHECK_EQUAL(N2, ctestDeque.front());
data.push_front(N3);
CHECK_EQUAL(N3, ctestDeque.front());
data.push_front(N4);
CHECK_EQUAL(N4, ctestDeque.front());
data.push_front(N5);
CHECK_EQUAL(N5, ctestDeque.front());
data.push_front(N6);
CHECK_EQUAL(N6, ctestDeque.front());
}
//*************************************************************************
TEST(test_back)
{
DataNDC data;
data.push_back(N1);
CHECK_EQUAL(N1, data.back());
data.push_back(N2);
CHECK_EQUAL(N2, data.back());
data.push_back(N3);
CHECK_EQUAL(N3, data.back());
data.push_back(N4);
CHECK_EQUAL(N4, data.back());
data.push_back(N5);
CHECK_EQUAL(N5, data.back());
data.push_back(N6);
CHECK_EQUAL(N6, data.back());
}
//*************************************************************************
TEST(test_back_const)
{
DataNDC data;
const DataNDC& ctestDeque = data;
data.push_back(N1);
CHECK_EQUAL(N1, ctestDeque.back());
data.push_back(N2);
CHECK_EQUAL(N2, ctestDeque.back());
data.push_back(N3);
CHECK_EQUAL(N3, ctestDeque.back());
data.push_back(N4);
CHECK_EQUAL(N4, ctestDeque.back());
data.push_back(N5);
CHECK_EQUAL(N5, ctestDeque.back());
data.push_back(N6);
CHECK_EQUAL(N6, ctestDeque.back());
}
//*************************************************************************
TEST(test_iterator_comparison)
{
DataNDC data(SIZE, N0);
DataNDC::iterator first = data.begin() + 1;
DataNDC::iterator second = data.begin() + 1;
DataNDC::iterator third = data.begin() + 4;
CHECK(first == second);
CHECK(second == first);
CHECK(!(first == third));
CHECK(!(third == first));
CHECK(!(first != second));
CHECK(!(second != first));
CHECK(first != third);
CHECK(third != first);
CHECK(!(first < second));
CHECK(!(second < first));
CHECK(first < third);
CHECK(!(third < first));
CHECK(first <= second);
CHECK(second <= first);
CHECK(first <= third);
CHECK(!(third <= first));
CHECK(!(first > second));
CHECK(!(second > first));
CHECK(!(first > third));
CHECK(third > first);
CHECK(first >= second);
CHECK(second >= first);
CHECK(!(first >= third));
CHECK(third >= first);
}
//*************************************************************************
TEST(test_const_iterator_comparison)
{
DataNDC data(SIZE, N0);
DataNDC::const_iterator first = data.begin() + 1;
DataNDC::const_iterator second = data.begin() + 1;
DataNDC::const_iterator third = data.begin() + 4;
CHECK(first == second);
CHECK(second == first);
CHECK(!(first == third));
CHECK(!(third == first));
CHECK(!(first != second));
CHECK(!(second != first));
CHECK(first != third);
CHECK(third != first);
CHECK(!(first < second));
CHECK(!(second < first));
CHECK(first < third);
CHECK(!(third < first));
CHECK(first <= second);
CHECK(second <= first);
CHECK(first <= third);
CHECK(!(third <= first));
CHECK(!(first > second));
CHECK(!(second > first));
CHECK(!(first > third));
CHECK(third > first);
CHECK(first >= second);
CHECK(second >= first);
CHECK(!(first >= third));
CHECK(third >= first);
}
//*************************************************************************
TEST(test_iterator_comparison_rollover_left)
{
DataNDC data(SIZE, N0);
data.pop_back();
data.pop_back();
data.pop_back();
data.pop_back();
data.push_front(N1);
data.push_front(N1);
data.push_front(N1);
data.push_front(N1);
DataNDC::const_iterator first = data.cbegin() + 1;
DataNDC::const_iterator second = data.cbegin() + 4;
CHECK(first < second);
CHECK(!(second < first));
}
//*************************************************************************
TEST(test_const_iterator_comparison_rollover_left)
{
DataNDC data(SIZE, N0);
data.pop_back();
data.pop_back();
data.pop_back();
data.pop_back();
data.push_front(N1);
data.push_front(N1);
data.push_front(N1);
data.push_front(N1);
DataNDC::const_iterator first = data.cbegin() + 1;
DataNDC::const_iterator second = data.cbegin() + 4;
CHECK(first < second);
CHECK(!(second < first));
}
//*************************************************************************
TEST(test_iterator_comparison_rollover_right)
{
DataNDC data(SIZE, N0);
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(N1);
data.push_back(N1);
data.push_back(N1);
data.push_back(N1);
DataNDC::iterator first = data.begin() + 1;
DataNDC::iterator second = data.begin() + 4;
CHECK(first < second);
CHECK(!(second < first));
}
//*************************************************************************
TEST(test_const_iterator_comparison_rollover_right)
{
DataNDC data(SIZE, N0);
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(N1);
data.push_back(N1);
data.push_back(N1);
data.push_back(N1);
DataNDC::const_iterator first = data.cbegin() + 1;
DataNDC::const_iterator second = data.cbegin() + 4;
CHECK(first < second);
CHECK(!(second < first));
}
//*************************************************************************
TEST(test_reverse_iterator_difference)
{
DataNDC data(SIZE, N0);
DataNDC::reverse_iterator first = data.rbegin() + 1;
DataNDC::reverse_iterator second = data.rbegin() + 4;
CHECK_EQUAL(-3, first - second);
CHECK_EQUAL( 3, second - first);
}
//*************************************************************************
TEST(test_const_reverse_iterator_difference)
{
DataNDC data(SIZE, N0);
DataNDC::const_reverse_iterator first = data.crbegin() + 1;
DataNDC::const_reverse_iterator second = data.crbegin() + 4;
CHECK_EQUAL(-3, first - second);
CHECK_EQUAL( 3, second - first);
}
//*************************************************************************
TEST(test_reverse_iterator_difference_rollover)
{
DataNDC data(SIZE, N0);
data.pop_back();
data.pop_back();
data.pop_back();
data.pop_back();
data.push_front(N1);
data.push_front(N1);
data.push_front(N1);
data.push_front(N1);
DataNDC::reverse_iterator first = data.rbegin() + 1;
DataNDC::reverse_iterator second = data.rbegin() + 4;
CHECK_EQUAL(-3, first - second);
CHECK_EQUAL( 3, second - first);
}
//*************************************************************************
TEST(test_const_reverse_iterator_difference_rollover)
{
DataNDC data(SIZE, N0);
data.pop_back();
data.pop_back();
data.pop_back();
data.pop_back();
data.push_front(N1);
data.push_front(N1);
data.push_front(N1);
data.push_front(N1);
DataNDC::const_reverse_iterator first = data.crbegin() + 1;
DataNDC::const_reverse_iterator second = data.crbegin() + 4;
CHECK_EQUAL(-3, first - second);
CHECK_EQUAL( 3, second - first);
}
//*************************************************************************
TEST(test_reverse_iterator_comparison)
{
DataNDC data(SIZE, N0);
DataNDC::reverse_iterator first = data.rbegin() + 1;
DataNDC::reverse_iterator second = data.rbegin() + 4;
CHECK(first < second);
CHECK(!(second < first));
}
//*************************************************************************
TEST(test_const_reverse_iterator_comparison)
{
DataNDC data(SIZE, N0);
DataNDC::const_reverse_iterator first = data.crbegin() + 1;
DataNDC::const_reverse_iterator second = data.crbegin() + 4;
CHECK(first < second);
CHECK(!(second < first));
}
//*************************************************************************
TEST(test_reverse_iterator_comparison_rollover_left)
{
DataNDC data(SIZE, N0);
data.pop_back();
data.pop_back();
data.pop_back();
data.pop_back();
data.push_front(N1);
data.push_front(N1);
data.push_front(N1);
data.push_front(N1);
DataNDC::reverse_iterator first = data.rbegin() + 1;
DataNDC::reverse_iterator second = data.rbegin() + 4;
CHECK(first < second);
CHECK(!(second < first));
}
//*************************************************************************
TEST(test_const_reverse_iterator_comparison_rollover_left)
{
DataNDC data(SIZE, N0);
data.pop_back();
data.pop_back();
data.pop_back();
data.pop_back();
data.push_front(N1);
data.push_front(N1);
data.push_front(N1);
data.push_front(N1);
DataNDC::const_reverse_iterator first = data.crbegin() + 1;
DataNDC::const_reverse_iterator second = data.crbegin() + 4;
CHECK(first < second);
CHECK(!(second < first));
}
//*************************************************************************
TEST(test_reverse_iterator_comparison_rollover_right)
{
DataNDC data(SIZE, N0);
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(N1);
data.push_back(N1);
data.push_back(N1);
data.push_back(N1);
DataNDC::reverse_iterator first = data.rbegin() + 1;
DataNDC::reverse_iterator second = data.rbegin() + 4;
CHECK(first < second);
CHECK(!(second < first));
}
//*************************************************************************
TEST(test_const_reverse_iterator_comparison_rollover_right)
{
DataNDC data(SIZE, N0);
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(N1);
data.push_back(N1);
data.push_back(N1);
data.push_back(N1);
DataNDC::const_reverse_iterator first = data.crbegin() + 1;
DataNDC::const_reverse_iterator second = data.crbegin() + 4;
CHECK(first < second);
CHECK(!(second < first));
}
//*************************************************************************
TEST(test_empty)
{
DataNDC data;
CHECK(data.empty());
}
//*************************************************************************
TEST(test_full)
{
DataDC data;
data.resize(SIZE);
CHECK(data.full());
}
//*************************************************************************
TEST(test_clear)
{
DataDC data;
data.resize(SIZE);
data.clear();
CHECK(data.empty());
// Do it again to check that clear() didn't screw up the internals.
data.resize(SIZE);
CHECK_EQUAL(SIZE, data.size());
data.clear();
CHECK(data.empty());
}
//*************************************************************************
TEST(test_clear_pod)
{
DataInt data;
data.resize(SIZE);
data.clear();
CHECK(data.empty());
// Do it again to check that clear() didn't screw up the internals.
data.resize(SIZE);
data.clear();
CHECK(data.empty());
}
//*************************************************************************
TEST(test_insert_to_empty)
{
const int value(5);
const size_t insertCount = 2UL;
etl::deque<int, 2> valuesToInsert(insertCount, value);
etl::deque<int, 10> data;
data.insert(data.cbegin(), valuesToInsert.begin(), valuesToInsert.end());
CHECK_EQUAL(insertCount, std::distance(data.begin(), data.end()));
CHECK(data.size() == insertCount);
CHECK(data[0] == value);
CHECK(data[1] == value);
CHECK(std::equal(data.begin(), data.end(), valuesToInsert.begin()));
}
//*************************************************************************
TEST(test_insert_value_begin)
{
Compare_Data compare_data(initial_data_under.begin(), initial_data_under.end());
DataNDC data(compare_data.begin(), compare_data.end());
Compare_Data::iterator cposition = compare_data.insert(compare_data.cbegin(), N14);
DataNDC::iterator position = data.insert(data.cbegin(), N14);
CHECK_EQUAL(compare_data.size(), std::distance(data.begin(), data.end()));
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), cposition), std::distance(data.begin(), position));
}
//*************************************************************************
TEST(test_emplace_value_begin)
{
Compare_Data compare_data(initial_data_under.begin(), initial_data_under.end());
DataNDC data(compare_data.begin(), compare_data.end());
Compare_Data::iterator cposition = compare_data.emplace(compare_data.begin(), N14.value);
DataNDC::iterator position = data.emplace(data.begin(), N14.value);
CHECK_EQUAL(compare_data.size(), std::distance(data.begin(), data.end()));
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), cposition), std::distance(data.begin(), position));
}
//*************************************************************************
TEST(test_insert_value_end)
{
Compare_Data compare_data(initial_data_under.begin(), initial_data_under.end());
DataNDC data(compare_data.begin(), compare_data.end());
Compare_Data::iterator cposition = compare_data.insert(compare_data.cend(), N14);
DataNDC::iterator position = data.insert(data.cend(), N14);
CHECK_EQUAL(compare_data.size(), std::distance(data.begin(), data.end()));
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), cposition), std::distance(data.begin(), position));
}
//*************************************************************************
TEST(test_emplace_value_end)
{
Compare_Data compare_data(initial_data_under.begin(), initial_data_under.end());
DataNDC data(compare_data.begin(), compare_data.end());
Compare_Data::iterator cposition = compare_data.emplace(compare_data.end(), N14.value);
DataNDC::iterator position = data.emplace(data.end(), N14.value);
CHECK_EQUAL(compare_data.size(), std::distance(data.begin(), data.end()));
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), cposition), std::distance(data.begin(), position));
}
//*************************************************************************
TEST(test_insert_value)
{
Compare_Data compare_data(initial_data_under.begin(), initial_data_under.end());
DataNDC data(compare_data.begin(), compare_data.end());
Compare_Data::iterator cposition = compare_data.insert(compare_data.cbegin() + 3, N14);
DataNDC::iterator position = data.insert(data.cbegin() + 3, N14);
CHECK_EQUAL(compare_data.size(), std::distance(data.begin(), data.end()));
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), cposition), std::distance(data.begin(), position));
compare_data.assign(initial_data_under.begin(), initial_data_under.end());
data.assign(compare_data.begin(), compare_data.end());
cposition = compare_data.insert(compare_data.cbegin() + 4, N14);
position = data.insert(data.cbegin() + 4, N14);
CHECK_EQUAL(compare_data.size(), std::distance(data.begin(), data.end()));
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), cposition), std::distance(data.begin(), position));
}
//*************************************************************************
TEST(test_emplace_value)
{
Compare_Data compare_data(initial_data_under.begin(), initial_data_under.end());
DataNDC data(compare_data.begin(), compare_data.end());
Compare_Data::iterator cposition = compare_data.emplace(compare_data.begin() + 3, N14.value);
DataNDC::iterator position = data.emplace(data.begin() + 3, N14.value);
CHECK_EQUAL(compare_data.size(), std::distance(data.begin(), data.end()));
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), cposition), std::distance(data.begin(), position));
compare_data.assign(initial_data_under.begin(), initial_data_under.end());
data.assign(compare_data.begin(), compare_data.end());
cposition = compare_data.emplace(compare_data.begin() + 4, N14.value);
position = data.emplace(data.begin() + 4, N14.value);
CHECK_EQUAL(compare_data.size(), std::distance(data.begin(), data.end()));
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), cposition), std::distance(data.begin(), position));
}
//*************************************************************************
TEST(test_emplace_default)
{
const int Initial = 1;
const int Default = 2;
struct S
{
S()
: value(Default)
{
}
S(int v)
: value(v)
{
}
bool operator ==(const S& rhs) const
{
return value == rhs.value;
}
int value;
};
// First fill with Initial values.
etl::deque<S, SIZE> data;
data.resize(SIZE, S(Initial));
data.clear();
// Then emplace Default values.
for (size_t i = 0; i < SIZE; ++i)
{
data.emplace(data.end());
}
// Compare with an array of default values.
std::array<S, SIZE> compare_data;
compare_data.fill(S());
CHECK_TRUE(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_emplace_front_default)
{
const int Initial = 1;
const int Default = 2;
struct S
{
S()
: value(Default)
{
}
S(int v)
: value(v)
{
}
bool operator ==(const S& rhs) const
{
return value == rhs.value;
}
int value;
};
// First fill with Initial values.
etl::deque<S, SIZE> data;
data.resize(SIZE, S(Initial));
data.clear();
// Then emplace Default values.
for (size_t i = 0; i < SIZE; ++i)
{
data.emplace_front();
}
// Compare with an array of default values.
std::array<S, SIZE> compare_data;
compare_data.fill(S());
CHECK_TRUE(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_emplace_back_default)
{
const int Initial = 1;
const int Default = 2;
struct S
{
S()
: value(Default)
{
}
S(int v)
: value(v)
{
}
bool operator ==(const S& rhs) const
{
return value == rhs.value;
}
int value;
};
// First fill with Initial values.
etl::deque<S, SIZE> data;
data.resize(SIZE, S(Initial));
data.clear();
// Then emplace Default values.
for (size_t i = 0; i < SIZE; ++i)
{
data.emplace_back();
}
// Compare with an array of default values.
std::array<S, SIZE> compare_data;
compare_data.fill(S());
CHECK_TRUE(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_insert_n_value_position)
{
size_t max_insert = SIZE - initial_data_small.size();
for (size_t insert_size = 1UL; insert_size <= max_insert; ++insert_size)
{
for (size_t offset = 0UL; offset <= initial_data_small.size(); ++offset)
{
Compare_Data compare_data(initial_data_small.begin(), initial_data_small.end());
DataNDC data(compare_data.begin(), compare_data.end());
compare_data.insert(compare_data.cbegin() + offset, insert_size, N14);
data.insert(data.cbegin() + offset, insert_size, N14);
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
}
}
//*************************************************************************
TEST(test_insert_n_value_excess)
{
DataNDC data(initial_data_under.begin(), initial_data_under.end());
size_t insert_size = SIZE - initial_data_under.size() + 1;
CHECK_THROW(data.insert(data.cbegin(), insert_size, N14), etl::deque_full);
CHECK_THROW(data.insert(data.cend(), insert_size, N14), etl::deque_full);
CHECK_THROW(data.insert(data.cbegin() + 6, insert_size, N14), etl::deque_full);
}
//*************************************************************************
TEST(test_insert_range)
{
size_t max_insert = SIZE - initial_data_small.size();
for (size_t insert_size = 1UL; insert_size <= max_insert; ++insert_size)
{
Compare_Data range(insert_data.begin(), insert_data.begin() + insert_size);
for (size_t offset = 0UL; offset <= initial_data_small.size(); ++offset)
{
Compare_Data compare_data(initial_data_small.begin(), initial_data_small.end());
DataNDC data(blank_data.begin(), blank_data.end());
data.assign(compare_data.begin(), compare_data.end());
compare_data.insert(compare_data.cbegin() + offset, range.begin(), range.end());
data.insert(data.cbegin() + offset, range.begin(), range.end());
CHECK_EQUAL(compare_data.size(), std::distance(data.begin(), data.end()));
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
}
}
//*************************************************************************
TEST(test_insert_range_excess)
{
Compare_Data range = { N12, N13, N14, N15 };
DataNDC data(initial_data_under.begin(), initial_data_under.end());
CHECK_THROW(data.insert(data.cbegin(), range.begin(), range.end()), etl::deque_full);
CHECK_THROW(data.insert(data.cend(), range.begin(), range.end()), etl::deque_full);
CHECK_THROW(data.insert(data.cbegin() + 6, range.begin(), range.end()), etl::deque_full);
}
//*************************************************************************
TEST(test_erase_begin)
{
Compare_Data compare_data = { N0, N0, N0, N0, N0, N0, N0, N0, N0, N1, N2, N3 };
DataNDC data(compare_data.begin(), compare_data.end());
// Cause rollover.
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(N4);
data.push_back(N5);
data.push_back(N6);
data.push_back(N7);
data.push_back(N8);
data.push_back(N9);
data.push_back(N10);
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.push_back(N4);
compare_data.push_back(N5);
compare_data.push_back(N6);
compare_data.push_back(N7);
compare_data.push_back(N8);
compare_data.push_back(N9);
compare_data.push_back(N10);
DataNDC::const_iterator i_next = data.erase(data.cbegin());
Compare_Data::const_iterator i_cnext = compare_data.erase(compare_data.cbegin());
CHECK_EQUAL(DataNDC::difference_type(data.size()), std::distance(data.begin(), data.end()));
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.cbegin(), i_cnext), std::distance(data.cbegin(), i_next));
}
//*************************************************************************
TEST(test_erase_end)
{
Compare_Data compare_data = { N0, N0, N0, N0, N0, N0, N0, N0, N0, N1, N2, N3 };
DataNDC data(compare_data.begin(), compare_data.end());
// Cause rollover.
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(N4);
data.push_back(N5);
data.push_back(N6);
data.push_back(N7);
data.push_back(N8);
data.push_back(N9);
data.push_back(N10);
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.push_back(N4);
compare_data.push_back(N5);
compare_data.push_back(N6);
compare_data.push_back(N7);
compare_data.push_back(N8);
compare_data.push_back(N9);
compare_data.push_back(N10);
DataNDC::iterator i_erase = data.end() - 1;
DataNDC::iterator i_next = data.erase(i_erase);
Compare_Data::const_iterator i_cerase = compare_data.cend() - 1U;
Compare_Data::iterator i_cnext = compare_data.erase(i_cerase);
CHECK_EQUAL(DataNDC::difference_type(compare_data.size()), std::distance(data.begin(), data.end()));
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), i_cnext), std::distance(data.begin(), i_next));
}
//*************************************************************************
TEST(test_erase_middle)
{
std::vector<NDC> initial = { N0, N0, N0, N0, N0, N0, N0, N0, N0, N1, N2, N3 };
Compare_Data compare_data(initial.begin(), initial.end());
DataNDC data(initial.begin(), initial.end());
// Cause rollover.
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(N4);
data.push_back(N5);
data.push_back(N6);
data.push_back(N7);
data.push_back(N8);
data.push_back(N9);
data.push_back(N10);
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.push_back(N4);
compare_data.push_back(N5);
compare_data.push_back(N6);
compare_data.push_back(N7);
compare_data.push_back(N8);
compare_data.push_back(N9);
compare_data.push_back(N10);
// Erase near beginning.
DataNDC::const_iterator i_erase = data.begin() + 2;
DataNDC::iterator i_next = data.erase(i_erase);
Compare_Data::const_iterator i_cerase = compare_data.begin() + 2;
Compare_Data::iterator i_cnext = compare_data.erase(i_cerase);
CHECK_EQUAL(DataNDC::difference_type(compare_data.size()), std::distance(data.begin(), data.end()));
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), i_cnext), std::distance(data.begin(), i_next));
compare_data.assign(initial.begin(), initial.end());
data.assign(initial.begin(), initial.end());
// Cause rollover.
// Cause rollover.
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(N4);
data.push_back(N5);
data.push_back(N6);
data.push_back(N7);
data.push_back(N8);
data.push_back(N9);
data.push_back(N10);
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.push_back(N4);
compare_data.push_back(N5);
compare_data.push_back(N6);
compare_data.push_back(N7);
compare_data.push_back(N8);
compare_data.push_back(N9);
compare_data.push_back(N10);
// Erase near end.
i_erase = data.begin() + 3;
i_next = data.erase(i_erase);
i_cerase = compare_data.begin() + 3;
i_cnext = compare_data.erase(i_cerase);
CHECK_EQUAL(DataNDC::difference_type(compare_data.size()), std::distance(data.begin(), data.end()));
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), i_cnext), std::distance(data.begin(), i_next));
}
//*************************************************************************
TEST(test_erase_range_begin)
{
std::vector<NDC> initial = { N0, N0, N0, N0, N0, N0, N0, N0, N0, N1, N2, N3 };
Compare_Data compare_data(initial.begin(), initial.end());
DataNDC data(initial.begin(), initial.end());
// Cause rollover.
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(N4);
data.push_back(N5);
data.push_back(N6);
data.push_back(N7);
data.push_back(N8);
data.push_back(N9);
data.push_back(N10);
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.push_back(N4);
compare_data.push_back(N5);
compare_data.push_back(N6);
compare_data.push_back(N7);
compare_data.push_back(N8);
compare_data.push_back(N9);
compare_data.push_back(N10);
DataNDC::iterator i_next = data.erase(data.cbegin(), data.cbegin() + 3);
Compare_Data::iterator i_cnext = compare_data.erase(compare_data.cbegin(), compare_data.cbegin() + 3);
CHECK_EQUAL(DataNDC::difference_type(compare_data.size()), std::distance(data.begin(), data.end()));
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), i_cnext), std::distance(data.begin(), i_next));
}
//*************************************************************************
TEST(test_erase_range_end)
{
std::vector<NDC> initial = { N0, N0, N0, N0, N0, N0, N0, N0, N0, N1, N2, N3 };
Compare_Data compare_data(initial.begin(), initial.end());
DataNDC data(initial.begin(), initial.end());
// Cause rollover.
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(N4);
data.push_back(N5);
data.push_back(N6);
data.push_back(N7);
data.push_back(N8);
data.push_back(N9);
data.push_back(N10);
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.push_back(N4);
compare_data.push_back(N5);
compare_data.push_back(N6);
compare_data.push_back(N7);
compare_data.push_back(N8);
compare_data.push_back(N9);
compare_data.push_back(N10);
DataNDC::iterator i_next = data.erase(data.cend() - 3, data.cend());
Compare_Data::iterator i_cnext = compare_data.erase(compare_data.cend() - 3, compare_data.cend());
CHECK_EQUAL(DataNDC::difference_type(compare_data.size()), std::distance(data.begin(), data.end()));
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), i_cnext), std::distance(data.begin(), i_next));
}
//*************************************************************************
TEST(test_erase_range_middle)
{
std::vector<NDC> initial = { N0, N0, N0, N0, N0, N0, N0, N0, N0, N1, N2, N3 };
Compare_Data compare_data(initial.begin(), initial.end());
DataNDC data(initial.begin(), initial.end());
// Cause rollover.
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(N4);
data.push_back(N5);
data.push_back(N6);
data.push_back(N7);
data.push_back(N8);
data.push_back(N9);
data.push_back(N10);
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.push_back(N4);
compare_data.push_back(N5);
compare_data.push_back(N6);
compare_data.push_back(N7);
compare_data.push_back(N8);
compare_data.push_back(N9);
compare_data.push_back(N10);
DataNDC::iterator i_next = data.erase(data.cbegin() + 1, data.cbegin() + 3);
Compare_Data::iterator i_cnext = compare_data.erase(compare_data.cbegin() + 1, compare_data.cbegin() + 3);
CHECK_EQUAL(DataNDC::difference_type(compare_data.size()), std::distance(data.begin(), data.end()));
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), i_cnext), std::distance(data.begin(), i_next));
compare_data.assign(initial.begin(), initial.end());
data.assign(initial.begin(), initial.end());
// Cause rollover.
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(N4);
data.push_back(N5);
data.push_back(N6);
data.push_back(N7);
data.push_back(N8);
data.push_back(N9);
data.push_back(N10);
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.push_back(N4);
compare_data.push_back(N5);
compare_data.push_back(N6);
compare_data.push_back(N7);
compare_data.push_back(N8);
compare_data.push_back(N9);
compare_data.push_back(N10);
i_next = data.erase(data.cbegin() + 3, data.cbegin() + 5);
i_cnext = compare_data.erase(compare_data.cbegin() + 3, compare_data.cbegin() + 5);
CHECK_EQUAL(DataNDC::difference_type(compare_data.size()), std::distance(data.begin(), data.end()));
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
CHECK_EQUAL(std::distance(compare_data.begin(), i_cnext), std::distance(data.begin(), i_next));
}
//*************************************************************************
TEST(test_push_back)
{
Compare_Data compare_data = { N1, N2, N3, N4, N5 };
DataNDC data;
CHECK_NO_THROW(data.push_back(N1));
CHECK_EQUAL(size_t(1), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end() - 4, data.begin()));
CHECK_NO_THROW(data.push_back(N2));
CHECK_EQUAL(size_t(2), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end() - 3, data.begin()));
CHECK_NO_THROW(data.push_back(N3));
CHECK_EQUAL(size_t(3), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end() - 2, data.begin()));
CHECK_NO_THROW(data.push_back(N4));
CHECK_EQUAL(size_t(4), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end() - 1, data.begin()));
CHECK_NO_THROW(data.push_back(N5));
CHECK_EQUAL(size_t(5), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_emplace_back)
{
Compare_Data compare_data = { N1, N2, N3, N4, N5 };
DataNDC data;
CHECK_NO_THROW(data.emplace_back("1"));
CHECK_EQUAL(size_t(1), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end() - 4, data.begin()));
CHECK_NO_THROW(data.emplace_back("2"));
CHECK_EQUAL(size_t(2), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end() - 3, data.begin()));
CHECK_NO_THROW(data.emplace_back("3"));
CHECK_EQUAL(size_t(3), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end() - 2, data.begin()));
CHECK_NO_THROW(data.emplace_back("4"));
CHECK_EQUAL(size_t(4), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end() - 1, data.begin()));
CHECK_NO_THROW(data.emplace_back("5"));
CHECK_EQUAL(size_t(5), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_emplace_back_return)
{
DataNDC data;
data.emplace_back("24");
auto& back = data.emplace_back("42");
CHECK_EQUAL(back, data.back());
}
//*************************************************************************
TEST(test_push_back_excess)
{
DataNDC data;
for (size_t i = 0UL; i < SIZE; ++i)
{
CHECK_NO_THROW(data.push_back(N0));
}
CHECK_THROW(data.push_back(N999), etl::deque_full);
}
//*************************************************************************
TEST(test_pop_back)
{
Compare_Data compare_data = { N1, N2, N3, N4, N5 };
DataNDC data;
data.assign(compare_data.begin(), compare_data.end());
data.pop_back();
CHECK_EQUAL(size_t(4), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end() - 1, data.begin()));
data.pop_back();
CHECK_EQUAL(size_t(3), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end() - 2, data.begin()));
data.pop_back();
CHECK_EQUAL(size_t(2), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end() - 3, data.begin()));
data.pop_back();
CHECK_EQUAL(size_t(1), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end() - 4, data.begin()));
data.pop_back();
CHECK_EQUAL(size_t(0), data.size());
}
//*************************************************************************
TEST(test_pop_back_exception)
{
Compare_Data compare_data = { N1, N2, N3, N4, N5 };
DataNDC data;
data.assign(compare_data.begin(), compare_data.end());
data.pop_back();
data.pop_back();
data.pop_back();
data.pop_back();
data.pop_back();
CHECK_THROW(data.pop_back(), etl::deque_empty);
}
//*************************************************************************
TEST(test_push_front)
{
Compare_Data compare_data = { N5, N4, N3, N2, N1 };
DataNDC data;
CHECK_NO_THROW(data.push_front(N1));
CHECK_EQUAL(size_t(1), data.size());
CHECK(std::equal(compare_data.begin() + 4, compare_data.end(), data.begin()));
CHECK_NO_THROW(data.push_front(N2));
CHECK_EQUAL(size_t(2), data.size());
CHECK(std::equal(compare_data.begin() + 3, compare_data.end(), data.begin()));
CHECK_NO_THROW(data.push_front(N3));
CHECK_EQUAL(size_t(3), data.size());
CHECK(std::equal(compare_data.begin() + 2, compare_data.end(), data.begin()));
CHECK_NO_THROW(data.push_front(N4));
CHECK_EQUAL(size_t(4), data.size());
CHECK(std::equal(compare_data.begin() + 1, compare_data.end(), data.begin()));
CHECK_NO_THROW(data.push_front(N5));
CHECK_EQUAL(size_t(5), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_emplace_front)
{
Compare_Data compare_data = { N5, N4, N3, N2, N1 };
DataNDC data;
CHECK_NO_THROW(data.emplace_front("1"));
CHECK_EQUAL(size_t(1), data.size());
CHECK(std::equal(compare_data.begin() + 4, compare_data.end(), data.begin()));
CHECK_NO_THROW(data.emplace_front("2"));
CHECK_EQUAL(size_t(2), data.size());
CHECK(std::equal(compare_data.begin() + 3, compare_data.end(), data.begin()));
CHECK_NO_THROW(data.emplace_front("3"));
CHECK_EQUAL(size_t(3), data.size());
CHECK(std::equal(compare_data.begin() + 2, compare_data.end(), data.begin()));
CHECK_NO_THROW(data.emplace_front("4"));
CHECK_EQUAL(size_t(4), data.size());
CHECK(std::equal(compare_data.begin() + 1, compare_data.end(), data.begin()));
CHECK_NO_THROW(data.emplace_front("5"));
CHECK_EQUAL(size_t(5), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_emplace_front_return)
{
DataNDC data;
data.emplace_front("24");
auto& front = data.emplace_front("42");
CHECK_EQUAL(front, data.front());
}
//*************************************************************************
TEST(test_push_front_excess)
{
DataNDC data;
for (size_t i = 0UL; i < SIZE; ++i)
{
CHECK_NO_THROW(data.push_front(N1));
}
CHECK_THROW(data.push_front(N999), etl::deque_full);
}
//*************************************************************************
TEST(test_pop_front_exception)
{
Compare_Data compare_data = { N1, N2, N3, N4, N5 };
DataNDC data;
data.assign(compare_data.begin(), compare_data.end());
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
CHECK_THROW(data.pop_front(), etl::deque_empty);
}
//*************************************************************************
TEST(test_push_front_push_back)
{
Compare_Data compare_data = { N1, N2, N3, N4, N5};
DataNDC data;
CHECK_NO_THROW(data.push_back(N3));
CHECK_NO_THROW(data.push_front(N2));
CHECK_NO_THROW(data.push_back(N4));
CHECK_NO_THROW(data.push_front(N1));
CHECK_NO_THROW(data.push_back(N5));
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_push_back_pop_front_push_back)
{
Compare_Data compare_data = { N6, N7, N8 };
DataNDC data;
data.push_back(N1);
data.push_back(N2);
data.push_back(N3);
data.push_back(N4);
data.push_back(N5);
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(N6);
data.push_back(N7);
data.push_back(N8);
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_pop_front)
{
Compare_Data compare_data = { N1, N2, N3, N4, N5 };
DataNDC data;
data.assign(compare_data.begin(), compare_data.end());
data.pop_front();
CHECK_EQUAL(size_t(4), data.size());
CHECK(std::equal(compare_data.begin() + 1, compare_data.end(), data.begin()));
data.pop_front();
CHECK_EQUAL(size_t(3), data.size());
CHECK(std::equal(compare_data.begin() + 2, compare_data.end(), data.begin()));
data.pop_front();
CHECK_EQUAL(size_t(2), data.size());
CHECK(std::equal(compare_data.begin() + 3, compare_data.end(), data.begin()));
data.pop_front();
CHECK_EQUAL(size_t(1), data.size());
CHECK(std::equal(compare_data.begin() + 4, compare_data.end(), data.begin()));
data.pop_front();
CHECK_EQUAL(size_t(0), data.size());
}
//*************************************************************************
TEST(test_resize_up)
{
Compare_DataDC compare_data(initial_data_dc.begin(), initial_data_dc.end());
DataDC data(initial_data_dc.begin(), initial_data_dc.end());
// Cause rollover.
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(DC("14"));
data.push_back(DC("15"));
data.push_back(DC("16"));
data.push_back(DC("17"));
data.resize(SIZE);
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.push_back(DC("14"));
compare_data.push_back(DC("15"));
compare_data.push_back(DC("16"));
compare_data.push_back(DC("17"));
compare_data.resize(SIZE);
CHECK_EQUAL(size_t(SIZE), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_resize_down)
{
Compare_DataDC compare_data(initial_data_dc.begin(), initial_data_dc.end());
DataDC data(initial_data_dc.begin(), initial_data_dc.end());
// Cause rollover.
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.push_back(DC("14"));
data.push_back(DC("15"));
data.push_back(DC("16"));
data.push_back(DC("17"));
data.resize(SIZE / 2);
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.pop_front();
compare_data.push_back(DC("14"));
compare_data.push_back(DC("15"));
compare_data.push_back(DC("16"));
compare_data.push_back(DC("17"));
compare_data.resize(SIZE / 2);
CHECK_EQUAL(compare_data.size(), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_resize_value)
{
Compare_Data compare_data = { N1, N2, N3, N3, N3 };
DataNDC data;
data.push_front(N1);
data.push_back(N2);
data.resize(SIZE, N3);
CHECK_EQUAL(size_t(SIZE), data.size());
CHECK(std::equal(compare_data.begin(), compare_data.end(), data.begin()));
}
//*************************************************************************
TEST(test_resize_excess)
{
DataDC data;
CHECK_THROW(data.resize(SIZE + 1), etl::deque_full);
}
//*************************************************************************
TEST(test_equality_operator)
{
Compare_Data same = { N1, N2, N3, N4, N5, N6 };
Compare_Data different = { N6, N5, N4, N3, N2, N1 };
DataNDC deque1(same.begin(), same.end());
DataNDC deque2(deque1);
CHECK(deque1 == deque2);
// Change deque2's data.
std::copy(different.begin(), different.end(), deque2.begin());
CHECK(!(deque1 == deque2));
}
//*************************************************************************
TEST(test_inequality_operator)
{
Compare_Data same = { N1, N2, N3, N4, N5, N6 };
Compare_Data different = { N6, N5, N4, N3, N2, N1 };
DataNDC deque1(same.begin(), same.end());
DataNDC deque2(deque1);
CHECK(!(deque1 != deque2));
// Change deque2's data.
std::copy(different.begin(), different.end(), deque2.begin());
CHECK(deque1 != deque2);
}
//*************************************************************************
TEST(test_iterator_comparison_empty)
{
DataNDC data;
CHECK(data.begin() == data.end());
CHECK(data.cbegin() == data.cend());
CHECK(data.rbegin() == data.rend());
CHECK(data.crbegin() == data.crend());
}
//*************************************************************************
TEST(test_memcpy_repair)
{
DataInt data(int_data1.begin(), int_data1.end());
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.insert(data.end(), int_data2.begin(), int_data2.end());
char buffer[sizeof(DataInt)];
memcpy(&buffer, (const void*)&data, sizeof(data));
DataInt& rdata(*reinterpret_cast<DataInt*>(buffer));
rdata.repair();
// Check that the memcpy'd vector is the same.
CHECK_EQUAL(data.size(), rdata.size());
CHECK(!rdata.empty());
CHECK(rdata.full());
bool is_equal = std::equal(rdata.begin(),
rdata.end(),
data.begin());
CHECK(is_equal);
// Modify the original and check that the memcpy'd vector is not the same.
std::reverse(data.begin(), data.end());
is_equal = std::equal(rdata.begin(),
rdata.end(),
data.begin());
CHECK(!is_equal);
}
//*************************************************************************
TEST(test_memcpy_repair_virtual)
{
DataInt data(int_data1.begin(), int_data1.end());
data.pop_front();
data.pop_front();
data.pop_front();
data.pop_front();
data.insert(data.end(), int_data2.begin(), int_data2.end());
char buffer[sizeof(DataInt)];
memcpy(&buffer, (const void*)&data, sizeof(data));
IDataInt& idata(*reinterpret_cast<DataInt*>(buffer));
idata.repair();
// Check that the memcpy'd vector is the same.
CHECK_EQUAL(data.size(), idata.size());
CHECK(!idata.empty());
CHECK(idata.full());
bool is_equal = std::equal(idata.begin(),
idata.end(),
data.begin());
CHECK(is_equal);
// Modify the original and check that the memcpy'd vector is not the same.
std::reverse(data.begin(), data.end());
is_equal = std::equal(idata.begin(),
idata.end(),
data.begin());
CHECK(!is_equal);
}
//*************************************************************************
TEST(test_move)
{
typedef etl::deque<std::unique_ptr<uint32_t>, SIZE> Data;
Data data1;
std::unique_ptr<uint32_t> p1(new uint32_t(1U));
std::unique_ptr<uint32_t> p2(new uint32_t(2U));
std::unique_ptr<uint32_t> p3(new uint32_t(3U));
std::unique_ptr<uint32_t> p4(new uint32_t(4U));
std::unique_ptr<uint32_t> p5(new uint32_t(5U));
// Move items to data1.
data1.push_front(std::move(p1));
data1.push_back(std::move(p2));
data1.insert(data1.begin(), std::move(p3));
data1.insert(data1.begin() + 1, std::move(p4));
data1.insert(data1.end(), std::move(p5));
const size_t ACTUAL_SIZE = data1.size();
CHECK(!bool(p1));
CHECK(!bool(p2));
CHECK(!bool(p3));
CHECK(!bool(p4));
CHECK(!bool(p5));
CHECK_EQUAL(3U, *(*(data1.begin() + 0)));
CHECK_EQUAL(4U, *(*(data1.begin() + 1)));
CHECK_EQUAL(1U, *(*(data1.begin() + 2)));
CHECK_EQUAL(2U, *(*(data1.begin() + 3)));
CHECK_EQUAL(5U, *(*(data1.begin() + 4)));
// Move constructor.
Data data2(std::move(data1));
CHECK_EQUAL(3U, *(*(data2.begin() + 0)));
CHECK_EQUAL(4U, *(*(data2.begin() + 1)));
CHECK_EQUAL(1U, *(*(data2.begin() + 2)));
CHECK_EQUAL(2U, *(*(data2.begin() + 3)));
CHECK_EQUAL(5U, *(*(data2.begin() + 4)));
CHECK_EQUAL(ACTUAL_SIZE, data2.size());
// Move assignment.
Data data3;
data3 = std::move(data2);
CHECK_EQUAL(3U, *(*(data3.begin() + 0)));
CHECK_EQUAL(4U, *(*(data3.begin() + 1)));
CHECK_EQUAL(1U, *(*(data3.begin() + 2)));
CHECK_EQUAL(2U, *(*(data3.begin() + 3)));
CHECK_EQUAL(5U, *(*(data3.begin() + 4)));
CHECK_EQUAL(ACTUAL_SIZE, data3.size());
}
//*************************************************************************
TEST(test_two_parameter_constructor_same_type_not_iterator)
{
// No compilation error.
etl::deque<int, 10> v(5, 5);
}
//*************************************************************************
TEST(test_sort)
{
std::array<int, 10> initial = { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
std::array<int, 10> result = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };
etl::deque<int, 10> data(initial.begin(), initial.end());
std::sort(data.begin(), data.end());
bool is_equal = std::equal(data.begin(),
data.end(),
result.begin());
CHECK(is_equal);
}
//*************************************************************************
#if ETL_USING_CPP17 && ETL_HAS_INITIALIZER_LIST && !defined(ETL_TEMPLATE_DEDUCTION_GUIDE_TESTS_DISABLED)
TEST(test_deque_template_deduction)
{
etl::deque data{ char(0), short(1), 2, long(3), 4, 5, 6, 7, 8, 9 };
using Type = std::remove_reference_t<decltype(data[0])>;
CHECK((std::is_same_v<long, Type>));
CHECK_EQUAL(0, data[0]);
CHECK_EQUAL(1, data[1]);
CHECK_EQUAL(2, data[2]);
CHECK_EQUAL(3, data[3]);
CHECK_EQUAL(4, data[4]);
CHECK_EQUAL(5, data[5]);
CHECK_EQUAL(6, data[6]);
CHECK_EQUAL(7, data[7]);
CHECK_EQUAL(8, data[8]);
CHECK_EQUAL(9, data[9]);
}
#endif
//*************************************************************************
#if ETL_USING_CPP11 && ETL_HAS_INITIALIZER_LIST
TEST(test_make_deque)
{
auto data = etl::make_deque<int>(0, 1, 2, 3, 4, 5, 6, 7, 8, 9);
CHECK_EQUAL(0, data[0]);
CHECK_EQUAL(1, data[1]);
CHECK_EQUAL(2, data[2]);
CHECK_EQUAL(3, data[3]);
CHECK_EQUAL(4, data[4]);
CHECK_EQUAL(5, data[5]);
CHECK_EQUAL(6, data[6]);
CHECK_EQUAL(7, data[7]);
CHECK_EQUAL(8, data[8]);
CHECK_EQUAL(9, data[9]);
}
#endif
//*************************************************************************
TEST(test_fill)
{
DataNDC data(initial_data.begin(), initial_data.end());
data.fill(N999);
CHECK(std::equal(blank_data.begin(), blank_data.end(), data.begin()));
}
};
}
#include "etl/private/diagnostic_pop.h"