///****************************************************************************** //The MIT License(MIT) // //Embedded Template Library. //https://github.com/ETLCPP/etl //http://www.etlcpp.com // //Copyright(c) 2014 jwellbelove // //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 "UnitTest++.h" #include #include #include #include "vector.h" #include "data.h" namespace { SUITE(test_vector_non_trivial) { static const size_t SIZE = 10; typedef TestDataNDC NDC; typedef TestDataDC DC; static NDC ndc("NDC"); typedef etl::vector DataNDC; typedef etl::ivector IDataNDC; typedef std::vector CompareDataNDC; typedef etl::vector DataDC; typedef etl::ivector IDataDC; typedef std::vector CompareDataDC; CompareDataNDC initial_data; CompareDataNDC less_data; CompareDataNDC greater_data; CompareDataNDC shorter_data; CompareDataNDC different_data; CompareDataNDC insert_data; //************************************************************************* struct SetupFixture { SetupFixture() { NDC n[] = { NDC("0"), NDC("1"), NDC("2"), NDC("3"), NDC("4"), NDC("5"), NDC("6"), NDC("7"), NDC("8"), NDC("9") }; NDC n_insert[] = { NDC("11"), NDC("12"), NDC("13") }; NDC n_less[] = { NDC("0"), NDC("1"), NDC("2"), NDC("3"), NDC("3"), NDC("5"), NDC("6"), NDC("7"), NDC("8"), NDC("9") }; NDC n_greater[] = { NDC("0"), NDC("1"), NDC("2"), NDC("4"), NDC("4"), NDC("5"), NDC("6"), NDC("7"), NDC("8"), NDC("9") }; initial_data.assign(std::begin(n), std::end(n)); insert_data.assign(std::begin(n_insert), std::end(n_insert)); less_data.assign(std::begin(n_less), std::end(n_less)); greater_data.assign(std::begin(n_greater), std::end(n_greater)); shorter_data.assign(std::begin(n_greater), std::end(n_greater) - 1); different_data.assign(initial_data.rbegin(), initial_data.rend()); } }; //************************************************************************* TEST_FIXTURE(SetupFixture, test_default_constructor) { DataDC data; CHECK_EQUAL(data.size(), size_t(0)); CHECK(data.empty()); CHECK_EQUAL(data.capacity(), SIZE); CHECK_EQUAL(data.max_size(), SIZE); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_destruct_via_ivector) { const size_t INITIAL_SIZE = 5; const NDC INITIAL_VALUE("1"); int current_count = NDC::get_instance_count(); DataNDC* p = new DataNDC(INITIAL_SIZE, INITIAL_VALUE); delete p; DataNDC* pdata = new DataNDC(INITIAL_SIZE, INITIAL_VALUE); CHECK_EQUAL(int(current_count + INITIAL_SIZE), NDC::get_instance_count()); IDataNDC* pidata = pdata; delete pidata; CHECK_EQUAL(current_count, NDC::get_instance_count()); } //************************************************************************* TEST(test_iterator_comparison_empty) { DataDC data; CHECK(data.begin() == data.end()); CHECK(data.cbegin() == data.cend()); CHECK(data.rbegin() == data.rend()); CHECK(data.crbegin() == data.crend()); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_constructor_size) { const size_t INITIAL_SIZE = 5; DataDC data(INITIAL_SIZE); CHECK(data.size() == INITIAL_SIZE); CHECK(!data.empty()); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_constructor_size_value) { const size_t INITIAL_SIZE = 5; const NDC INITIAL_VALUE("1"); std::vector compare_data(INITIAL_SIZE, INITIAL_VALUE); DataNDC data(size_t(5), NDC("1")); CHECK(data.size() == INITIAL_SIZE); CHECK(!data.empty()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_constructor_size_excess) { CHECK_THROW(DataDC data(SIZE + 1), etl::vector_full); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_constructor_range) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); DataNDC data(compare_data.begin(), compare_data.end()); CHECK(data.size() == SIZE); CHECK(!data.empty()); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_copy_constructor) { DataNDC data(initial_data.begin(), initial_data.end()); DataNDC data2(data); CHECK(data2 == data); data2[2] = NDC("X"); CHECK(data2 != data); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_assignment) { DataNDC data(initial_data.begin(), initial_data.end()); DataNDC other_data; other_data = data; bool is_equal = std::equal(data.begin(), data.end(), other_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_assignment_iterface) { DataNDC data1(initial_data.begin(), initial_data.end()); DataNDC data2; IDataNDC& idata1 = data1; IDataNDC& idata2 = data2; idata2 = idata1; bool is_equal = std::equal(data1.begin(), data1.end(), data2.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_self_assignment) { DataNDC data(initial_data.begin(), initial_data.end()); DataNDC other_data(data); other_data = other_data; bool is_equal = std::equal(data.begin(), data.end(), other_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_begin) { DataDC data(10); const DataDC constData(10); CHECK_EQUAL(&data[0], data.begin()); CHECK_EQUAL(&constData[0], constData.begin()); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_end) { DataDC data(10); const DataDC constData(10); CHECK_EQUAL(&data[10], data.end()); CHECK_EQUAL(&constData[10], constData.end()); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_resize_up) { const size_t INITIAL_SIZE = 5; const size_t NEW_SIZE = 8; DataDC data(INITIAL_SIZE); data.resize(NEW_SIZE); CHECK_EQUAL(data.size(), NEW_SIZE); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_resize_up_value) { const size_t INITIAL_SIZE = 5; const size_t NEW_SIZE = 8; const NDC INITIAL_VALUE("1"); DataNDC data(INITIAL_SIZE, INITIAL_VALUE); data.resize(NEW_SIZE, INITIAL_VALUE); std::vector compare_data(NEW_SIZE, INITIAL_VALUE); CHECK_EQUAL(compare_data.size(), data.size()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_resize_excess) { const size_t INITIAL_SIZE = 5; const size_t NEW_SIZE = SIZE + 1; DataDC data(INITIAL_SIZE); CHECK_THROW(data.resize(NEW_SIZE), etl::vector_full); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_resize_down) { const size_t INITIAL_SIZE = 5; const size_t NEW_SIZE = 2; DataDC data(INITIAL_SIZE); data.resize(NEW_SIZE); CHECK_EQUAL(data.size(), NEW_SIZE); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_resize_down_value) { const size_t INITIAL_SIZE = 5; const size_t NEW_SIZE = 2; const NDC INITIAL_VALUE("1"); DataNDC data(INITIAL_SIZE, INITIAL_VALUE); data.resize(NEW_SIZE, INITIAL_VALUE); CHECK_EQUAL(data.size(), NEW_SIZE); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_empty) { DataDC data; data.resize(data.max_size()); CHECK(data.full()); CHECK(!data.empty()); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_full) { DataNDC data; CHECK(!data.full()); CHECK(data.empty()); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_index) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); DataNDC data(compare_data.begin(), compare_data.end()); for (size_t i = 0; i < data.size(); ++i) { CHECK_EQUAL(data[i], compare_data[i]); } } //************************************************************************* TEST_FIXTURE(SetupFixture, test_index_const) { const CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); const DataNDC data(compare_data.begin(), compare_data.end()); for (size_t i = 0; i < data.size(); ++i) { CHECK_EQUAL(data[i], compare_data[i]); } } //************************************************************************* TEST_FIXTURE(SetupFixture, test_at) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); DataNDC data(initial_data.begin(), initial_data.end()); for (size_t i = 0; i < data.size(); ++i) { CHECK_EQUAL(data.at(i), compare_data.at(i)); } CHECK_THROW(data.at(data.size()), etl::vector_out_of_bounds); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_at_const) { const CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); const DataNDC data(initial_data.begin(), initial_data.end()); for (size_t i = 0; i < data.size(); ++i) { CHECK_EQUAL(data.at(i), compare_data.at(i)); } CHECK_THROW(data.at(data.size()), etl::vector_out_of_bounds); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_front) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); DataNDC data(initial_data.begin(), initial_data.end()); CHECK(data.front() == compare_data.front()); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_front_const) { const CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); const DataNDC data(initial_data.begin(), initial_data.end()); CHECK(data.front() == compare_data.front()); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_back) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); DataNDC data(initial_data.begin(), initial_data.end()); CHECK(data.back() == compare_data.back()); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_back_const) { const CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); const DataNDC data(initial_data.begin(), initial_data.end()); CHECK(data.back() == compare_data.back()); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_data) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); DataNDC data(compare_data.begin(), compare_data.end()); bool is_equal = std::equal(data.data(), data.data() + data.size(), compare_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_data_const) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); const DataNDC data(compare_data.begin(), compare_data.end()); bool is_equal = std::equal(data.data(), data.data() + data.size(), compare_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_assign_range) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); DataNDC data; data.assign(compare_data.begin(), compare_data.end()); CHECK_EQUAL(compare_data.size(), data.size()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_assign_size_value) { const size_t INITIAL_SIZE = 5; const NDC INITIAL_VALUE("1"); std::vector compare_data(INITIAL_SIZE, INITIAL_VALUE); DataNDC data; data.assign(INITIAL_SIZE, INITIAL_VALUE); CHECK_EQUAL(compare_data.size(), data.size()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_assign_size_value_excess) { const size_t INITIAL_SIZE = SIZE; const size_t EXCESS_SIZE = SIZE + 1; const NDC INITIAL_VALUE("1"); std::vector compare_data(INITIAL_SIZE, INITIAL_VALUE); DataNDC data; CHECK_THROW(data.assign(EXCESS_SIZE, INITIAL_VALUE), etl::vector_full); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_push_back) { CompareDataNDC compare_data; DataNDC data; for (size_t i = 0; i < SIZE; ++i) { std::string value(" "); value[0] = char('A' + i); compare_data.push_back(NDC(value)); data.push_back(NDC(value)); } CHECK_EQUAL(compare_data.size(), data.size()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_push_back_null) { CompareDataDC compare_data; DataDC data; compare_data.push_back(DC("1")); data.push_back(); data[0] = DC("1"); CHECK_EQUAL(compare_data.size(), data.size()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_push_back_excess) { DataNDC data; for (size_t i = 0; i < SIZE; ++i) { std::string value(" "); value[0] = char('A' + i); data.push_back(NDC(value)); } CHECK_THROW(data.push_back(NDC("Z")), etl::vector_full); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_emplace_back) { CompareDataNDC compare_data; DataNDC data; for (size_t i = 0; i < SIZE; ++i) { std::string value(" "); value[0] = char('A' + i); compare_data.emplace_back(value); data.emplace_back(value); } CHECK_EQUAL(compare_data.size(), data.size()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_pop_back) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); DataNDC data(initial_data.begin(), initial_data.end()); compare_data.pop_back(); compare_data.pop_back(); data.pop_back(); data.pop_back(); CHECK_EQUAL(compare_data.size(), data.size()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_pop_back_exception) { DataDC data; data.resize(2); data.pop_back(); data.pop_back(); CHECK_THROW(data.pop_back(), etl::vector_empty); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_insert_position_value) { const size_t INITIAL_SIZE = 5; const NDC INITIAL_VALUE("1"); for (size_t offset = 0; offset <= INITIAL_SIZE; ++offset) { CompareDataNDC compare_data; DataNDC data; data.assign(initial_data.begin(), initial_data.begin() + INITIAL_SIZE); compare_data.assign(initial_data.begin(), initial_data.begin() + INITIAL_SIZE); data.insert(data.begin() + offset, INITIAL_VALUE); compare_data.insert(compare_data.begin() + offset, INITIAL_VALUE); CHECK_EQUAL(compare_data.size(), data.size()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } } //************************************************************************* TEST_FIXTURE(SetupFixture, test_emplace_position_value) { const size_t INITIAL_SIZE = 5; const std::string INITIAL_VALUE("1"); for (size_t offset = 0; offset <= INITIAL_SIZE; ++offset) { CompareDataNDC compare_data; DataNDC data; data.assign(initial_data.begin(), initial_data.begin() + INITIAL_SIZE); compare_data.assign(initial_data.begin(), initial_data.begin() + INITIAL_SIZE); data.emplace(data.begin() + offset, INITIAL_VALUE); compare_data.emplace(compare_data.begin() + offset, INITIAL_VALUE); CHECK_EQUAL(compare_data.size(), data.size()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } } //************************************************************************* TEST_FIXTURE(SetupFixture, test_insert_position_value_excess) { const size_t INITIAL_SIZE = SIZE; const NDC INITIAL_VALUE("1"); const NDC UNINITIALISED_VALUE("Z"); DataNDC data(INITIAL_SIZE, INITIAL_VALUE); size_t offset = 2; CHECK_THROW(data.insert(data.begin() + offset, INITIAL_VALUE), etl::vector_full); offset = 0; CHECK_THROW(data.insert(data.begin() + offset, INITIAL_VALUE), etl::vector_full); offset = data.size(); CHECK_THROW(data.insert(data.begin() + offset, INITIAL_VALUE), etl::vector_full); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_insert_position_n_value) { const size_t INITIAL_SIZE = 5; const size_t INSERT_SIZE = 3; const NDC INITIAL_VALUE("1"); for (size_t offset = 0; offset <= INITIAL_SIZE; ++offset) { CompareDataNDC compare_data; DataNDC data; data.assign(initial_data.begin(), initial_data.begin() + INITIAL_SIZE); compare_data.assign(initial_data.begin(), initial_data.begin() + INITIAL_SIZE); data.insert(data.begin() + offset, INSERT_SIZE, INITIAL_VALUE); compare_data.insert(compare_data.begin() + offset, INSERT_SIZE, INITIAL_VALUE); CHECK_EQUAL(compare_data.size(), data.size()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } } //************************************************************************* TEST_FIXTURE(SetupFixture, test_insert_position_n_value_excess) { const size_t INITIAL_SIZE = SIZE; const size_t INSERT_SIZE = 4; const NDC INITIAL_VALUE("1"); DataNDC data(INITIAL_SIZE, INITIAL_VALUE); size_t offset = 0; CHECK_THROW(data.insert(data.begin() + offset, INSERT_SIZE, INITIAL_VALUE), etl::vector_full); offset = 2; CHECK_THROW(data.insert(data.begin() + offset, INSERT_SIZE, INITIAL_VALUE), etl::vector_full); offset = 4; CHECK_THROW(data.insert(data.begin() + offset, INSERT_SIZE, INITIAL_VALUE), etl::vector_full); offset = data.size(); CHECK_THROW(data.insert(data.begin() + offset, INSERT_SIZE, INITIAL_VALUE), etl::vector_full); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_insert_position_range) { const size_t INITIAL_SIZE = 5; const NDC INITIAL_VALUE("1"); for (size_t offset = 0; offset <= INITIAL_SIZE; ++offset) { CompareDataNDC compare_data; DataNDC data; data.resize(SIZE, NDC("Z")); data.assign(initial_data.begin(), initial_data.begin() + INITIAL_SIZE); compare_data.assign(initial_data.begin(), initial_data.begin() + INITIAL_SIZE); data.insert(data.begin() + offset, insert_data.begin(), insert_data.end()); compare_data.insert(compare_data.begin() + offset, insert_data.begin(), insert_data.end()); CHECK_EQUAL(compare_data.size(), data.size()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } } //************************************************************************* TEST_FIXTURE(SetupFixture, test_insert_position_range_excess) { const size_t INITIAL_SIZE = 5; const NDC INITIAL_VALUE("1"); DataNDC data(INITIAL_SIZE, INITIAL_VALUE); size_t offset = 0; CHECK_THROW(data.insert(data.begin() + offset, initial_data.begin(), initial_data.end()), etl::vector_full); offset = 2; CHECK_THROW(data.insert(data.begin() + offset, initial_data.begin(), initial_data.end()), etl::vector_full); offset = 4; CHECK_THROW(data.insert(data.begin() + offset, initial_data.begin(), initial_data.end()), etl::vector_full); offset = data.size(); CHECK_THROW(data.insert(data.begin() + offset, initial_data.begin(), initial_data.end()), etl::vector_full); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_erase_single) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); DataNDC data(initial_data.begin(), initial_data.end()); compare_data.erase(compare_data.begin() + 2); data.erase(data.begin() + 2); CHECK_EQUAL(compare_data.size(), data.size()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_erase_range) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); DataNDC data(initial_data.begin(), initial_data.end()); compare_data.erase(compare_data.begin() + 2, compare_data.begin() + 4); data.erase(data.begin() + 2, data.begin() + 4); CHECK_EQUAL(compare_data.size(), data.size()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_clear) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); DataNDC data(compare_data.begin(), compare_data.end()); data.clear(); CHECK_EQUAL(data.size(), size_t(0)); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_iterator) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); DataNDC data(compare_data.begin(), compare_data.end()); bool is_equal = std::equal(data.begin(), data.end(), compare_data.begin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_const_iterator) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); DataNDC data(compare_data.begin(), compare_data.end()); bool is_equal = std::equal(data.cbegin(), data.cend(), compare_data.cbegin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_reverse_iterator) { CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); DataNDC data(compare_data.begin(), compare_data.end()); bool is_equal = std::equal(data.rbegin(), data.rend(), compare_data.rbegin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_const_reverse_iterator) { const CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); const DataNDC data(compare_data.begin(), compare_data.end()); bool is_equal = std::equal(data.crbegin(), data.crend(), compare_data.crbegin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_const_reverse_iterator2) { const CompareDataNDC compare_data(initial_data.begin(), initial_data.end()); const DataNDC data(compare_data.begin(), compare_data.end()); bool is_equal = std::equal(data.rbegin(), data.rend(), compare_data.rbegin()); CHECK(is_equal); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_equal) { const DataNDC initial1(initial_data.begin(), initial_data.end()); const DataNDC initial2(initial_data.begin(), initial_data.end()); CHECK(initial1 == initial2); const DataNDC different(different_data.begin(), different_data.end()); CHECK(!(initial1 == different)); const DataNDC shorter(shorter_data.begin(), shorter_data.end()); CHECK(!(shorter == initial1)); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_not_equal) { const DataNDC initial1(initial_data.begin(), initial_data.end()); const DataNDC initial2(initial_data.begin(), initial_data.end()); CHECK(!(initial1 != initial2)); const DataNDC different(different_data.begin(), different_data.end()); CHECK(initial1 != different); const DataNDC shorter(shorter_data.begin(), shorter_data.end()); CHECK(shorter != initial1); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_less_than) { const DataNDC less(less_data.begin(), less_data.end()); const DataNDC initial(initial_data.begin(), initial_data.end()); CHECK((less < initial) == (less_data < initial_data)); const DataNDC greater(greater_data.begin(), greater_data.end()); CHECK((greater < initial) == (greater_data < initial_data)); const DataNDC shorter(shorter_data.begin(), shorter_data.end()); CHECK((shorter < initial) == (shorter_data < initial_data)); CHECK((initial < shorter) == (initial_data < shorter_data)); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_less_than_or_equal) { const DataNDC less(less_data.begin(), less_data.end()); const DataNDC initial(initial_data.begin(), initial_data.end()); CHECK((less <= initial) == (less_data <= initial_data)); const DataNDC greater(greater_data.begin(), greater_data.end()); CHECK((greater <= initial) == (greater_data <= initial_data)); const DataNDC shorter(shorter_data.begin(), shorter_data.end()); CHECK((shorter <= initial) == (shorter_data <= initial_data)); CHECK((initial <= shorter) == (initial_data <= shorter_data)); const DataNDC initial2(initial_data.begin(), initial_data.end()); CHECK((initial <= initial2) == (initial_data <= initial_data)); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_greater_than) { const DataNDC less(less_data.begin(), less_data.end()); const DataNDC initial(initial_data.begin(), initial_data.end()); CHECK((less > initial) == (less_data > initial_data)); const DataNDC greater(greater_data.begin(), greater_data.end()); CHECK((greater > initial) == (greater_data > initial_data)); const DataNDC shorter(shorter_data.begin(), shorter_data.end()); CHECK((shorter > initial) == (shorter_data > initial_data)); CHECK((initial > shorter) == (initial_data > shorter_data)); } //************************************************************************* TEST_FIXTURE(SetupFixture, test_greater_than_or_equal) { const DataNDC less(less_data.begin(), less_data.end()); const DataNDC initial(initial_data.begin(), initial_data.end()); CHECK((less >= initial) == (less_data >= initial_data)); const DataNDC greater(greater_data.begin(), greater_data.end()); CHECK((greater >= initial) == (greater_data >= initial_data)); const DataNDC shorter(shorter_data.begin(), shorter_data.end()); CHECK((shorter >= initial) == (shorter_data >= initial_data)); CHECK((initial >= shorter) == (initial_data > shorter_data)); const DataNDC initial2(initial_data.begin(), initial_data.end()); CHECK((initial >= initial2) == (initial_data >= initial_data)); } }; }