diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index 68f7f08d7..268440ff4 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -187,6 +187,6 @@ ei_add_test(parametrizedline) ei_add_test(alignedbox) ei_add_test(regression) ei_add_test(stdvector) -ei_add_test(sparse_basic " " "${SPARSE_LIBS}") -ei_add_test(sparse_vector " " "${SPARSE_LIBS}") +ei_add_test(sparse_basic) +ei_add_test(sparse_vector) ei_add_test(sparse_solvers " " "${SPARSE_LIBS}") diff --git a/test/stdvector.cpp b/test/stdvector.cpp index d14b85f95..ea57c0736 100644 --- a/test/stdvector.cpp +++ b/test/stdvector.cpp @@ -40,15 +40,25 @@ void check_stdvector(const MatrixType& m) { VERIFY_IS_APPROX(w[i], v[i]); } - + v.resize(21); v[20].set(x); VERIFY_IS_APPROX(v[20], x); v.resize(22,y); - VERIFY_IS_APPROX(v[21], y); + VERIFY_IS_APPROX(v[21], y); v.push_back(x); VERIFY_IS_APPROX(v[22], x); VERIFY((size_t)&(v[22]) == (size_t)&(v[21]) + sizeof(MatrixType)); + + // do a lot of push_back such that the vector gets internally resized + // (with memory reallocation) + MatrixType* ref = &w[0]; + for(int i=0; i<30 | ((ref==&w[0]) && i<300); ++i) + v.push_back(w[i%w.size()]); + for(int i=23; i