#ifndef TESTS_VECTORS_CPP #define TESTS_VECTORS_CPP #include "tests_utils.hpp" TEST(tests_vector_constructor) { // title TITLE(cplusplus.com reference) // constructors used in the same order as described above: ft::vector first; // empty vector of ints ft::vector second (4,VAL(100)); // four ints with value 100 ft::vector third (second.begin(),second.end()); // iterating through second ft::vector fourth (third); // a copy of third // the iterator constructor can also be used to construct from arrays: T myints[] = {VAL(16),VAL(2),VAL(77),VAL(29)}; ft::vector fifth (myints, myints + sizeof(myints) / sizeof(T) ); PRINT(fifth); } TEST(tests_vector_operator_assignation) { // title TITLE(cplusplus.com reference) ft::vector foo (3,VAL(0)); ft::vector bar (5,VAL(0)); bar = foo; foo = ft::vector(); std::cout << "Size of foo: " << int(foo.size()) << '\n'; std::cout << "Size of bar: " << int(bar.size()) << '\n'; // title TITLE(more informations) std::cout << "foo:\n"; PRINT(foo); std::cout << "bar:\n"; PRINT(bar); } TEST(tests_vector_begin) { // title TITLE(cplusplus.com reference :) ft::vector myvector; for (int i=1; i<=5; i++) myvector.push_back(VAL(i)); std::cout << "myvector contains:\n"; PRINT(myvector); } TEST(tests_vector_end) { // title TITLE(cplusplus.com reference :) ft::vector myvector; for (int i=1; i<=5; i++) myvector.push_back(VAL(i)); std::cout << "myvector contains:\n"; PRINT(myvector); } TEST(tests_vector_rbegin) { // title TITLE(cplusplus.com reference :) ft::vector myvector (5); int i=0; typename ft::vector::reverse_iterator rit = myvector.rbegin(); for (; rit!= myvector.rend(); ++rit) *rit = VAL(++i); std::cout << "myvector contains:"; PRINT(myvector); } TEST(tests_vector_rend) { // title TITLE(cplusplus.com reference :) ft::vector myvector (5); // 5 default-constructed Ts typename ft::vector::reverse_iterator rit = myvector.rbegin(); int i=0; for (rit = myvector.rbegin(); rit!= myvector.rend(); ++rit) *rit = VAL(++i); std::cout << "myvector contains:"; PRINT(myvector); } TEST(tests_vector_size) { // title TITLE(cplusplus.com reference :) ft::vector myarr; std::cout << "0. size: " << myarr.size() << '\n'; for (int i=0; i<10; i++) myarr.push_back(VAL(i)); std::cout << "1. size: " << myarr.size() << '\n'; myarr.insert (myarr.end(),10,VAL(100)); std::cout << "2. size: " << myarr.size() << '\n'; myarr.pop_back(); std::cout << "3. size: " << myarr.size() << '\n'; PRINT(myarr); } TEST(tests_vector_max_size) { // title TITLE(cplusplus.com reference :) ft::vector myvector; // set some content in the vector: for (int i=0; i<100; i++) myvector.push_back(VAL(i)); std::cout << "size: " << myvector.size() << "\n"; std::cout << "capacity: " << myvector.capacity() << "\n"; std::cout << "max_size: " << myvector.max_size() << "\n"; PRINT(myvector); } TEST(tests_vector_resize) { // title TITLE(cplusplus.com reference :) ft::vector myvector; // set some initial content: for (int i = 1; i < 10; i++) myvector.push_back(VAL(i)); myvector.resize(5); myvector.resize(8,VAL(100)); myvector.resize(12); std::cout << "myvector contains:"; PRINT(myvector); // title TITLE(test size and capacity 1 :) ft::vector vector2; std::cout << "size: " << vector2.size() << " - capacity: " << vector2.capacity() << "\n\n"; std::cout << "assign(10, 1)\n"; vector2.assign(10, VAL(1)); PRINT(vector2); std::cout << "\n"; std::cout << "resize(15)\n"; vector2.resize(15); PRINT(vector2); std::cout << "\n"; std::cout << "resize(10)\n"; vector2.resize(10); PRINT(vector2); std::cout << "\n"; std::cout << "resize(19)\n"; vector2.resize(19); PRINT(vector2); std::cout << "\n"; std::cout << "resize(20)\n"; vector2.resize(20); PRINT(vector2); std::cout << "\n"; std::cout << "resize(21)\n"; vector2.resize(21); PRINT(vector2); std::cout << "\n"; // title TITLE(test size and capacity 2 :) ft::vector vector3; std::cout << "size: " << vector3.size() << " - capacity: " << vector3.capacity() << "\n\n"; std::cout << "assign(10, 1)\n"; vector3.assign(10, VAL(1)); PRINT(vector3); std::cout << "\n"; std::cout << "resize(21)\n"; vector3.resize(21); PRINT(vector3); std::cout << "\n"; DELETE } /* void tests_vector_capacity() { TEST(vector::capacity) { // title TITLE(cplusplus.com reference :) ft::vector myvector; // set some content in the vector: for (int i=0; i<100; i++) myvector.push_back(i); std::cout << "size: " << (int) myvector.size() << '\n'; std::cout << "capacity: " << (int) myvector.capacity() << '\n'; std::cout << "max_size: " << (int) myvector.max_size() << '\n'; } TESTEND } void tests_vector_empty() { TEST(vector::empty) { // title TITLE(cplusplus.com reference :) ft::vector myvector; int sum (0); for (int i=1;i<=10;i++) myvector.push_back(i); while (!myvector.empty()) { sum += myvector.back(); myvector.pop_back(); } std::cout << "total: " << sum << '\n'; } TESTEND } void tests_vector_reserve() { TEST(vector::reserve) { // title TITLE(cplusplus.com reference :) ft::vector::size_type sz; ft::vector foo; sz = foo.capacity(); std::cout << "making foo grow:\n"; for (int i=0; i<100; ++i) { foo.push_back(i); if (sz!=foo.capacity()) { sz = foo.capacity(); std::cout << "capacity changed: " << sz << '\n'; } } ft::vector bar; sz = bar.capacity(); bar.reserve(100); // this is the only difference with foo above std::cout << "making bar grow:\n"; for (int i=0; i<100; ++i) { bar.push_back(i); if (sz!=bar.capacity()) { sz = bar.capacity(); std::cout << "capacity changed: " << sz << '\n'; } } } TESTEND } void tests_vector_operator_access() { TEST(vector::operator[]) { // title TITLE(cplusplus.com reference :) ft::vector myvector (10); // 10 zero-initialized elements ft::vector::size_type sz = myvector.size(); // assign some values: for (unsigned i=0; i myvector (10); // 10 zero-initialized ints // assign some values: for (unsigned i=0; i myvector; myvector.push_back(78); myvector.push_back(16); // now front equals 78, and back 16 myvector.front() -= myvector.back(); std::cout << "myvector.front() is now " << myvector.front() << '\n'; } TESTEND } void tests_vector_back() { TEST(vector::back) { // title TITLE(cplusplus.com reference :) ft::vector myvector; myvector.push_back(78); myvector.push_back(16); // now front equals 78, and back 16 myvector.front() -= myvector.back(); std::cout << "myvector.front() is now " << myvector.front() << '\n'; // title TITLE(test with negatives :) myvector.push_back(236); myvector.push_back(8973); myvector.front() -= myvector.back(); std::cout << "myvector.front() is now " << myvector.front() << '\n'; // title TITLE(test with char :) ft::vector letters; letters.push_back('o'); letters.push_back('m'); letters.push_back('g'); letters.push_back('w'); letters.push_back('t'); letters.push_back('f'); if (!letters.empty()) { std::cout << "The first character is '" << letters.front() << "'.\n"; } } TESTEND } void tests_vector_assign() { TEST(vector::assign) { // title TITLE(cplusplus.com reference :) ft::vector first; ft::vector second; ft::vector third; first.assign (7,100); // 7 ints with a value of 100 ft::vector::iterator it; it=first.begin()+1; second.assign (it,first.end()-1); // the 5 central values of first int myints[] = {1776,7,4}; third.assign (myints,myints+3); // assigning from array. std::cout << "Size of first: " << int (first.size()) << '\n'; std::cout << "Size of second: " << int (second.size()) << '\n'; std::cout << "Size of third: " << int (third.size()) << '\n'; // title TITLE(capacity tests of assignation :) ft::vector myvector; int size; std::cout << "capacity before assignation : " << myvector.capacity() << "\n"; std::cout << "\nassign 1\n"; myvector.assign(1, 12); size = myvector.size(); for (int i = 0; i < size; i++) std::cout << "[" << i << "] " << myvector[i] << " - "; std::cout << "\nsize : " << size << " , capacity : " << myvector.capacity() << "\n"; std::cout << "\nassign 3\n"; myvector.assign(3, 12); size = myvector.size(); for (int i = 0; i < size; i++) std::cout << "[" << i << "] " << myvector[i] << " - "; std::cout << "\nsize : " << size << " , capacity : " << myvector.capacity() << "\n"; std::cout << "\nassign 7268\n"; myvector.assign(7268, 12); size = myvector.size(); for (int i = 0; i < size; i++) std::cout << "[" << i << "] " << myvector[i] << " - "; std::cout << "\nsize : " << size << " , capacity : " << myvector.capacity() << "\n"; // title TITLE(tests of iterators :) ft::vector int_vector_1; ft::vector int_vector_2; ft::vector int_vector_3; ft::vector it_vector; int ssize; std::cout << "\nassign 1\n"; int_vector_1.assign(1, 12); it_vector.assign(int_vector_1.begin(), int_vector_1.end()); ssize = it_vector.size(); for (int i = 0; i < ssize; i++) std::cout << "[" << i << "] " << it_vector[i] << " - "; std::cout << "\nsize : " << ssize << " , capacity : " << it_vector.capacity() << "\n"; std::cout << "\nassign 0\n"; int_vector_2.assign(1, 6); it_vector.assign(int_vector_2.begin(), int_vector_2.end() - 1); ssize = it_vector.size(); for (int i = 0; i < ssize; i++) std::cout << "[" << i << "] " << it_vector[i] << " - "; std::cout << "\nsize : " << ssize << " , capacity : " << it_vector.capacity() << "\n"; std::cout << "\nassign 266 - 13 - 172 = 81\n"; int_vector_3.assign(266, 1); it_vector.assign(int_vector_3.begin() + 13, int_vector_3.end() - 172); ssize = it_vector.size(); for (int i = 0; i < ssize; i++) std::cout << "[" << i << "] " << it_vector[i] << " - "; std::cout << "\nsize : " << ssize << " , capacity : " << it_vector.capacity() << "\n"; } TESTEND } void tests_vector_push_back() { TEST(vector::push_back) { // title TITLE(cplusplus.com reference :) ft::vector myvector; int myint[] = {12434, -2432, 12, 5345, 23, 0, -4, 387, 8432, -934723, 1}; int size = sizeof(myint) / sizeof(myint[0]); for (int i = 0; i < size; i++) { myvector.push_back(myint[i]); std::cout << "[capacity : " << std::setw(2) << myvector.capacity() << "] " << myvector[i] << "\n"; } for (int i = 0; i < size; i++) std::cout << "[" << std::setw(2) << i << "] " << myvector[i] << "\n"; std::cout << " -> size : " << myvector.size() << " , capacity :" << myvector.capacity() << "\n"; // title TITLE(big push back :) for (int i = 0; i < 72363; i++) { myvector.push_back(9); std::cout << "[" << i << ":" << myvector.capacity() << "] "; } std::cout << " -> size : " << myvector.size() << " , capacity :" << myvector.capacity() << "\n"; } TESTEND } void tests_vector_pop_back() { TEST(vector::pop_back) { // title TITLE(cplusplus.com reference :) ft::vector myvector; int sum (0); myvector.push_back (100); myvector.push_back (200); myvector.push_back (300); while (!myvector.empty()) { sum+=myvector.back(); myvector.pop_back(); } std::cout << "The elements of myvector add up to " << sum << '\n'; // title TITLE(check state :) std::cout << "size : " << myvector.size() << '\n'; std::cout << "capacity : " << myvector.capacity() << '\n'; } TESTEND } void tests_vector_insert() { TEST(vector::insert) { ft::vector::iterator it; ft::vector::iterator its; int i; // title TITLE(cplusplus.com reference :) ft::vector myvector (3,100); it = myvector.begin(); it = myvector.insert ( it , 200 ); myvector.insert (it,2,300); ft::vector anothervector (2,400); it = myvector.begin(); myvector.insert (it+2,anothervector.begin(),anothervector.end()); int myarray [] = { 501,502,503 }; myvector.insert (myvector.begin(), myarray, myarray+3); std::cout << "myvector contains:"; for (it=myvector.begin(); it myvector2 (3,100); it = myvector2.begin(); std::cout << "size:" << myvector2.size() << " capacity:" << myvector2.capacity() << "\n"; myvector2.insert ( it , 200 ); std::cout << "myvector contains:"; for (it = myvector2.begin(); it < myvector2.end(); it++) std::cout << ' ' << *it; std::cout << "\nsize:" << myvector2.size() << " capacity:" << myvector2.capacity() << "\n"; ft::vector myvector3 (3,100); it = myvector3.end(); std::cout << "\nsize:" << myvector3.size() << " capacity:" << myvector3.capacity() << "\n"; myvector3.insert ( it , 200 ); std::cout << "myvector contains:"; for (it = myvector3.begin(); it < myvector3.end(); it++) std::cout << ' ' << *it; std::cout << "\nsize:" << myvector3.size() << " capacity:" << myvector3.capacity() << "\n"; // title TITLE(tests positions on insert(pos, value) with struct :) ft::vector myvector4; mystruct *s; i = 0; while (i < 3) { s = new mystruct(i++); myvector4.push_back(s); } its = myvector4.begin(); std::cout << "size:" << myvector4.size() << " capacity:" << myvector4.capacity() << "\n"; s = new mystruct(i++); myvector4.insert ( its , s ); std::cout << "myvector contains:"; for (its = myvector4.begin(); its < myvector4.end(); its++) std::cout << ' ' << **its; std::cout << "\nsize:" << myvector4.size() << " capacity:" << myvector4.capacity() << "\n"; its = myvector4.begin() + 2; std::cout << "\nsize:" << myvector4.size() << " capacity:" << myvector4.capacity() << "\n"; s = new mystruct(i++); myvector4.insert ( its , s ); std::cout << "myvector contains:"; for (its = myvector4.begin(); its < myvector4.end(); its++) std::cout << ' ' << **its; std::cout << "\nsize:" << myvector4.size() << " capacity:" << myvector4.capacity() << "\n"; its = myvector4.end(); std::cout << "\nsize:" << myvector4.size() << " capacity:" << myvector4.capacity() << "\n"; s = new mystruct(i++); myvector4.insert ( its , s ); std::cout << "myvector contains:"; for (its = myvector4.begin(); its < myvector4.end(); its++) std::cout << ' ' << **its; std::cout << "\nsize:" << myvector4.size() << " capacity:" << myvector4.capacity() << "\n"; // title TITLE(tests insert(pos, size, value) :) ft::vector myvector5; for (i = 1; i <= 5; i++) myvector5.push_back(i * 100); it = myvector5.begin() + 1; myvector5.insert ( it , 150 ); it = myvector5.end(); myvector5.insert (it,2,600); it = myvector5.end() - 2; myvector5.insert (it,2,550); std::cout << "myvector contains:"; for (it = myvector5.begin(); it < myvector5.end(); it++) std::cout << ' ' << *it; std::cout << '\n'; std::cout << "\nsize:" << myvector5.size() << " capacity:" << myvector5.capacity() << "\n"; // title TITLE(tests positions on insert(pos, value) with struct :) ft::vector myvector6; i = 1; while (i <= 5) { s = new mystruct(i++ * 100); myvector6.push_back(s); } its = myvector6.begin() + 1; s = new mystruct(150); myvector6.insert ( its , s ); its = myvector6.end(); s = new mystruct(600); myvector6.insert ( its, 2, s ); its = myvector6.end() - 2; s = new mystruct(550); myvector6.insert ( its, 2, s ); std::cout << "myvector contains:"; for (its = myvector6.begin(); its < myvector6.end(); its++) std::cout << ' ' << **its; std::cout << "\nsize:" << myvector6.size() << " capacity:" << myvector6.capacity() << "\n"; // title TITLE(tests insert(pos, first, last) with struct :) ft::vector myvector7; for (i = 0; i < 5; i++) { s = new mystruct(42); myvector7.push_back(s); } its = myvector7.begin() + 2; myvector7.insert ( its, myvector6.begin() + 3, myvector6.end() - 2 ); std::cout << "myvector contains:"; for (its = myvector7.begin(); its < myvector7.end(); its++) std::cout << ' ' << **its; std::cout << "\nsize:" << myvector7.size() << " capacity:" << myvector7.capacity() << "\n"; } TESTEND } void tests_vector_erase() { TEST(vector::erase) { // title TITLE(cplusplus.com reference :) ft::vector myvector; // set some values (from 1 to 10) for (int i=1; i<=10; i++) myvector.push_back(i); // erase the 6th element myvector.erase (myvector.begin()+5); // erase the first 3 elements: myvector.erase (myvector.begin(),myvector.begin()+3); std::cout << "myvector contains:"; for (unsigned i=0; i vector2; int size; for (int i=1; i<=100; i++) vector2.push_back(i); size = vector2.size(); for (int i = 0; i < size; i++) std::cout << "[" << i << "] " << vector2[i] << " "; std::cout << "\nsize:" << size << " capacity:" << vector2.capacity() << "\n"; std::cout << "\nerase pos(7,36) :\n"; vector2.erase(vector2.begin() + 7, vector2.begin() + 36); size = vector2.size(); for (int i = 0; i < size; i++) std::cout << "[" << i << "] " << vector2[i] << " "; std::cout << "\nsize:" << size << " capacity:" << vector2.capacity() << "\n"; std::cout << "\nerase pos(46,54) :\n"; vector2.erase(vector2.begin() + 46, vector2.begin() + 54); size = vector2.size(); for (int i = 0; i < size; i++) std::cout << "[" << i << "] " << vector2[i] << " "; std::cout << "\nsize:" << size << " capacity:" << vector2.capacity() << "\n"; std::cout << "\nerase pos(7,7) :\n"; vector2.erase(vector2.begin() + 7, vector2.begin() + 7); size = vector2.size(); for (int i = 0; i < size; i++) std::cout << "[" << i << "] " << vector2[i] << " "; std::cout << "\nsize:" << size << " capacity:" << vector2.capacity() << "\n"; } TESTEND } void tests_vector_swap() { TEST(vector::swap) { // title TITLE(cplusplus.com reference :) ft::vector foo (3,100); // three ints with a value of 100 ft::vector bar (5,200); // five ints with a value of 200 foo.swap(bar); std::cout << "foo contains:"; for (unsigned i=0; i myvector; myvector.push_back (100); myvector.push_back (200); myvector.push_back (300); std::cout << "myvector contains:"; for (unsigned i=0; i myvector; int * p; unsigned int i; // allocate an array with space for 5 elements using vector's allocator: p = myvector.get_allocator().allocate(5); // construct values in-place on the array: for (i=0; i<5; i++) myvector.get_allocator().construct(&p[i],i); std::cout << "The allocated array contains:"; for (i=0; i<5; i++) std::cout << ' ' << p[i]; std::cout << '\n'; // destroy and deallocate: for (i=0; i<5; i++) myvector.get_allocator().destroy(&p[i]); myvector.get_allocator().deallocate(p,5); } TESTEND } void tests_vector_relational_operators() { TEST(ft::relational operators) { // title TITLE(cplusplus.com reference :) ft::vector foo (3,100); // three ints with a value of 100 ft::vector bar (2,200); // two ints with a value of 200 if (foo==bar) std::cout << "foo and bar are equal\n"; if (foo!=bar) std::cout << "foo and bar are not equal\n"; if (foo< bar) std::cout << "foo is less than bar\n"; if (foo> bar) std::cout << "foo is greater than bar\n"; if (foo<=bar) std::cout << "foo is less than or equal to bar\n"; if (foo>=bar) std::cout << "foo is greater than or equal to bar\n"; } TESTEND } void tests_vector_swap_non_member() { TEST(ft::swap vector) { // title TITLE(cplusplus.com reference :) ft::vector foo (3,100); // three ints with a value of 100 ft::vector bar (5,200); // five ints with a value of 200 foo.swap(bar); std::cout << "foo contains:"; for (ft::vector::iterator it = foo.begin(); it!=foo.end(); ++it) std::cout << ' ' << *it; std::cout << '\n'; std::cout << "bar contains:"; for (ft::vector::iterator it = bar.begin(); it!=bar.end(); ++it) std::cout << ' ' << *it; std::cout << '\n'; } TESTEND } void tests_vector_reverse_iterators() { TEST(ft::reverse_iterator) { // title TITLE(cplusplus.com reference) TITLE(::constructor ::operator* ::operator++(int)) ft::vector myvector; for (int i=0; i<10; i++) myvector.push_back(i); typedef ft::vector::iterator iter_type; // ? 0 1 2 3 4 5 6 7 8 9 ? iter_type from (myvector.begin()); // ^ iter_type until (myvector.end()); // ^ ft::reverse_iterator rev_until (from); // ^ ft::reverse_iterator rev_from (until); // ^ std::cout << "myvector:"; while (rev_from != rev_until) std::cout << ' ' << *rev_from++; std::cout << '\n'; // title TITLE(::operator++) std::cout << "myvector:"; while (rev_from != rev_until) { std::cout << ' ' << *rev_from; ++rev_from; } std::cout << '\n'; // title TITLE(::base) ft::reverse_iterator rev_end (myvector.begin()); ft::reverse_iterator rev_begin (myvector.end()); std::cout << "myvector:"; for (iter_type it = rev_end.base(); it != rev_begin.base(); ++it) std::cout << ' ' << *it; std::cout << '\n'; // title TITLE(::operator+) ft::reverse_iterator rev_it_add; rev_it_add = myvector.rbegin() +3; std::cout << "The fourth element from the end is: " << *rev_it_add << '\n'; // title TITLE(::operator+=) ft::reverse_iterator rev_it_add_equal = myvector.rbegin(); rev_it_add_equal += 2; std::cout << "The third element from the end is: " << *rev_it_add_equal << '\n'; // title TITLE(::operator-) ft::reverse_iterator rev_it_minus; rev_it_minus = myvector.rend() - 3; std::cout << "myvector.rend()-3 points to: " << *rev_it_minus << '\n'; // title TITLE(::operator--) ft::reverse_iterator rev_it_minus_minus = rev_begin; while ( rev_it_minus_minus != rev_end ) std::cout << *rev_it_minus_minus++ << ' '; std::cout << '\n'; while ( rev_it_minus_minus != rev_begin ) std::cout << *(--rev_it_minus_minus) << ' '; std::cout << '\n'; // title TITLE(::operator-=) ft::reverse_iterator rev_it_minus_equal = myvector.rend(); rev_it_minus_equal -= 4; std::cout << "rev_it_minus_equal now points to: " << *rev_it_minus_equal << '\n'; // title TITLE(::operator->) std::map numbers; numbers.insert (std::make_pair(1,"one")); numbers.insert (std::make_pair(2,"two")); numbers.insert (std::make_pair(3,"three")); typedef std::map::iterator map_iter; ft::reverse_iterator rev_map_end (numbers.begin()); ft::reverse_iterator rev_map_ite (numbers.end()); for ( ; rev_map_ite != rev_map_end ; ++rev_map_ite ) std::cout << rev_map_ite->first << ' ' << rev_map_ite->second << '\n'; // title TITLE(::operator[]) ft::reverse_iterator rev_it_at = myvector.rbegin(); std::cout << "The fourth element from the end is: " << rev_it_at[3] << '\n'; // title TITLE(::operator- non-member) ft::reverse_iterator::iterator> rev_it_from,rev_it_until; rev_it_from = myvector.rbegin(); rev_it_until = myvector.rend(); std::cout << "myvector has " << (rev_it_until-rev_it_from) << " elements.\n"; // title TITLE(::operator+ non-member) ft::reverse_iterator rev_it_n_memb; rev_it_n_memb = 3 + myvector.rbegin(); std::cout << "The fourth element from the end is: " << *rev_it_n_memb << '\n'; } TESTEND } */ #endif