1
0
Fork 0
arangodb/tests/Basics/vector-test.cpp

498 lines
15 KiB
C++

////////////////////////////////////////////////////////////////////////////////
/// @brief test suite for TRI_vector_t
///
/// @file
///
/// DISCLAIMER
///
/// Copyright 2012 triagens GmbH, Cologne, Germany
///
/// Licensed under the Apache License, Version 2.0 (the "License");
/// you may not use this file except in compliance with the License.
/// You may obtain a copy of the License at
///
/// http://www.apache.org/licenses/LICENSE-2.0
///
/// Unless required by applicable law or agreed to in writing, software
/// distributed under the License is distributed on an "AS IS" BASIS,
/// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
/// See the License for the specific language governing permissions and
/// limitations under the License.
///
/// Copyright holder is triAGENS GmbH, Cologne, Germany
///
/// @author Jan Steemann
/// @author Copyright 2012, triAGENS GmbH, Cologne, Germany
////////////////////////////////////////////////////////////////////////////////
#include "Basics/Common.h"
#include "catch.hpp"
#include "Basics/vector.h"
// -----------------------------------------------------------------------------
// --SECTION-- private macros
// -----------------------------------------------------------------------------
#define VECTOR_INIT \
TRI_vector_t v1; \
TRI_InitVector(&v1, sizeof(int));
#define VECTOR_DESTROY \
TRI_DestroyVector(&v1);
// -----------------------------------------------------------------------------
// --SECTION-- private constants
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
// --SECTION-- test suite
// -----------------------------------------------------------------------------
////////////////////////////////////////////////////////////////////////////////
/// @brief setup
////////////////////////////////////////////////////////////////////////////////
TEST_CASE("CVectorTest", "[vector]") {
////////////////////////////////////////////////////////////////////////////////
/// @brief test length after vector initialization
////////////////////////////////////////////////////////////////////////////////
SECTION("tst_length_init") {
VECTOR_INIT
CHECK((size_t) 0 == TRI_LengthVector(&v1));
VECTOR_DESTROY
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test vector length after insertions
////////////////////////////////////////////////////////////////////////////////
SECTION("tst_length_insert") {
VECTOR_INIT
int p1 = 1;
int p2 = 2;
TRI_PushBackVector(&v1, &p1);
CHECK((size_t) 1 == TRI_LengthVector(&v1));
TRI_PushBackVector(&v1, &p1);
CHECK((size_t) 2 == TRI_LengthVector(&v1));
TRI_PushBackVector(&v1, &p2);
CHECK((size_t) 3 == TRI_LengthVector(&v1));
VECTOR_DESTROY
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test vector length after insertions & deletions
////////////////////////////////////////////////////////////////////////////////
SECTION("tst_length_insert_remove") {
VECTOR_INIT
int p1 = 1;
int p2 = 2;
int p3 = 3;
TRI_PushBackVector(&v1, &p1);
CHECK((size_t) 1 == TRI_LengthVector(&v1));
TRI_RemoveVector(&v1, 0);
CHECK((size_t) 0 == TRI_LengthVector(&v1));
TRI_PushBackVector(&v1, &p2);
TRI_PushBackVector(&v1, &p3);
CHECK((size_t) 2 == TRI_LengthVector(&v1));
TRI_RemoveVector(&v1, 0);
CHECK((size_t) 1 == TRI_LengthVector(&v1));
TRI_RemoveVector(&v1, 0);
CHECK((size_t) 0 == TRI_LengthVector(&v1));
VECTOR_DESTROY
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test removal of elements at invalid positions
////////////////////////////////////////////////////////////////////////////////
SECTION("tst_remove_invalid1") {
VECTOR_INIT
TRI_RemoveVector(&v1, 0); // invalid position
TRI_RemoveVector(&v1, 0); // invalid position
TRI_RemoveVector(&v1, 1); // invalid position
TRI_RemoveVector(&v1, -1); // invalid position
TRI_RemoveVector(&v1, 99); // invalid position
CHECK((size_t) 0 == TRI_LengthVector(&v1));
VECTOR_DESTROY
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test removal of elements at invalid positions
////////////////////////////////////////////////////////////////////////////////
SECTION("tst_remove_invalid2") {
VECTOR_INIT
int p1 = 1;
int p2 = 2;
TRI_PushBackVector(&v1, &p1);
TRI_PushBackVector(&v1, &p2);
TRI_RemoveVector(&v1, 0); // valid
TRI_RemoveVector(&v1, 0); // valid
TRI_RemoveVector(&v1, 0); // now invalid
TRI_RemoveVector(&v1, 1); // invalid position
TRI_RemoveVector(&v1, -1); // invalid position
TRI_RemoveVector(&v1, 99); // invalid position
VECTOR_DESTROY
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test at
////////////////////////////////////////////////////////////////////////////////
SECTION("tst_at_empty") {
VECTOR_INIT
void* r = nullptr;
CHECK(r == TRI_AtVector(&v1, 0));
CHECK(r == TRI_AtVector(&v1, 1));
CHECK(r == TRI_AtVector(&v1, -1));
CHECK(r == TRI_AtVector(&v1, 99));
VECTOR_DESTROY
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test at and insert
////////////////////////////////////////////////////////////////////////////////
SECTION("tst_at_insert") {
VECTOR_INIT
int a = 1;
int b = 2;
int c = 3;
int d = 4;
TRI_PushBackVector(&v1, &a);
CHECK(1 == *(int*) TRI_AtVector(&v1, 0));
TRI_PushBackVector(&v1, &b);
CHECK(1 == *(int*) TRI_AtVector(&v1, 0));
CHECK(2 == *(int*) TRI_AtVector(&v1, 1));
TRI_PushBackVector(&v1, &c);
CHECK(1 == *(int*) TRI_AtVector(&v1, 0));
CHECK(2 == *(int*) TRI_AtVector(&v1, 1));
CHECK(3 == *(int*) TRI_AtVector(&v1, 2));
TRI_PushBackVector(&v1, &d);
CHECK(1 == *(int*) TRI_AtVector(&v1, 0));
CHECK(2 == *(int*) TRI_AtVector(&v1, 1));
CHECK(3 == *(int*) TRI_AtVector(&v1, 2));
CHECK(4 == *(int*) TRI_AtVector(&v1, 3));
VECTOR_DESTROY
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test at and insert and remove
////////////////////////////////////////////////////////////////////////////////
SECTION("tst_at_insert_remove") {
VECTOR_INIT
void* r = nullptr;
int a = 1;
int b = 2;
int c = 3;
int d = 4;
TRI_PushBackVector(&v1, &a);
CHECK(1 == *(int*) TRI_AtVector(&v1, 0));
TRI_RemoveVector(&v1, 0);
CHECK(r == TRI_AtVector(&v1, 0));
TRI_PushBackVector(&v1, &b);
CHECK(2 == *(int*) TRI_AtVector(&v1, 0));
TRI_PushBackVector(&v1, &c);
CHECK(2 == *(int*) TRI_AtVector(&v1, 0));
CHECK(3 == *(int*) TRI_AtVector(&v1, 1));
TRI_RemoveVector(&v1, 0);
CHECK(3 == *(int*) TRI_AtVector(&v1, 0));
TRI_PushBackVector(&v1, &d);
TRI_PushBackVector(&v1, &a);
CHECK(3 == *(int*) TRI_AtVector(&v1, 0));
CHECK(4 == *(int*) TRI_AtVector(&v1, 1));
CHECK(1 == *(int*) TRI_AtVector(&v1, 2));
TRI_RemoveVector(&v1, 1);
CHECK(3 == *(int*) TRI_AtVector(&v1, 0));
CHECK(1 == *(int*) TRI_AtVector(&v1, 1));
VECTOR_DESTROY
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test duplicate pointers
////////////////////////////////////////////////////////////////////////////////
SECTION("tst_push_back_duplicate") {
VECTOR_INIT
int a = 1;
int b = 2;
TRI_PushBackVector(&v1, &a);
TRI_PushBackVector(&v1, &a);
TRI_PushBackVector(&v1, &a);
TRI_PushBackVector(&v1, &a);
TRI_PushBackVector(&v1, &b);
TRI_PushBackVector(&v1, &b);
CHECK((size_t) 6 == TRI_LengthVector(&v1));
CHECK(1 == *(int*) TRI_AtVector(&v1, 0));
CHECK(1 == *(int*) TRI_AtVector(&v1, 1));
CHECK(1 == *(int*) TRI_AtVector(&v1, 2));
CHECK(1 == *(int*) TRI_AtVector(&v1, 3));
CHECK(2 == *(int*) TRI_AtVector(&v1, 4));
CHECK(2 == *(int*) TRI_AtVector(&v1, 5));
VECTOR_DESTROY
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test duplicate pointers
////////////////////////////////////////////////////////////////////////////////
SECTION("tst_remove_duplicate") {
VECTOR_INIT
int a = 1;
int b = 2;
TRI_PushBackVector(&v1, &a);
TRI_PushBackVector(&v1, &a);
TRI_PushBackVector(&v1, &a);
TRI_PushBackVector(&v1, &b);
TRI_PushBackVector(&v1, &b);
CHECK((size_t) 5 == TRI_LengthVector(&v1));
CHECK(1 == *(int*) TRI_AtVector(&v1, 0));
CHECK(1 == *(int*) TRI_AtVector(&v1, 1));
CHECK(1 == *(int*) TRI_AtVector(&v1, 2));
CHECK(2 == *(int*) TRI_AtVector(&v1, 3));
CHECK(2 == *(int*) TRI_AtVector(&v1, 4));
TRI_RemoveVector(&v1, 4);
TRI_RemoveVector(&v1, 0);
TRI_RemoveVector(&v1, 1);
CHECK((size_t) 2 == TRI_LengthVector(&v1));
CHECK(1 == *(int*) TRI_AtVector(&v1, 0));
CHECK(2 == *(int*) TRI_AtVector(&v1, 1));
VECTOR_DESTROY
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test push back and remove
////////////////////////////////////////////////////////////////////////////////
SECTION("tst_push_back_remove") {
VECTOR_INIT
int a = 1;
int b = 2;
int c = 3;
int d = 4;
TRI_PushBackVector(&v1, &a);
TRI_PushBackVector(&v1, &b);
TRI_PushBackVector(&v1, &c);
TRI_PushBackVector(&v1, &d);
TRI_PushBackVector(&v1, &a);
TRI_PushBackVector(&v1, &b);
TRI_PushBackVector(&v1, &c);
TRI_PushBackVector(&v1, &d);
TRI_PushBackVector(&v1, &a);
TRI_PushBackVector(&v1, &a);
CHECK((size_t) 10 == TRI_LengthVector(&v1));
CHECK(1 == *(int*) TRI_AtVector(&v1, 0));
CHECK(2 == *(int*) TRI_AtVector(&v1, 1));
CHECK(3 == *(int*) TRI_AtVector(&v1, 2));
CHECK(4 == *(int*) TRI_AtVector(&v1, 3));
CHECK(1 == *(int*) TRI_AtVector(&v1, 4));
CHECK(2 == *(int*) TRI_AtVector(&v1, 5));
CHECK(3 == *(int*) TRI_AtVector(&v1, 6));
CHECK(4 == *(int*) TRI_AtVector(&v1, 7));
CHECK(1 == *(int*) TRI_AtVector(&v1, 8));
CHECK(1 == *(int*) TRI_AtVector(&v1, 9));
TRI_RemoveVector(&v1, 4);
CHECK((size_t) 9 == TRI_LengthVector(&v1));
CHECK(1 == *(int*) TRI_AtVector(&v1, 0));
CHECK(2 == *(int*) TRI_AtVector(&v1, 1));
CHECK(3 == *(int*) TRI_AtVector(&v1, 2));
CHECK(4 == *(int*) TRI_AtVector(&v1, 3));
CHECK(2 == *(int*) TRI_AtVector(&v1, 4));
CHECK(3 == *(int*) TRI_AtVector(&v1, 5));
CHECK(4 == *(int*) TRI_AtVector(&v1, 6));
CHECK(1 == *(int*) TRI_AtVector(&v1, 7));
CHECK(1 == *(int*) TRI_AtVector(&v1, 8));
TRI_RemoveVector(&v1, 0);
CHECK((size_t) 8 == TRI_LengthVector(&v1));
CHECK(2 == *(int*) TRI_AtVector(&v1, 0));
CHECK(3 == *(int*) TRI_AtVector(&v1, 1));
CHECK(4 == *(int*) TRI_AtVector(&v1, 2));
CHECK(2 == *(int*) TRI_AtVector(&v1, 3));
CHECK(3 == *(int*) TRI_AtVector(&v1, 4));
CHECK(4 == *(int*) TRI_AtVector(&v1, 5));
CHECK(1 == *(int*) TRI_AtVector(&v1, 6));
CHECK(1 == *(int*) TRI_AtVector(&v1, 7));
TRI_RemoveVector(&v1, 7);
CHECK((size_t) 7 == TRI_LengthVector(&v1));
CHECK(2 == *(int*) TRI_AtVector(&v1, 0));
CHECK(3 == *(int*) TRI_AtVector(&v1, 1));
CHECK(4 == *(int*) TRI_AtVector(&v1, 2));
CHECK(2 == *(int*) TRI_AtVector(&v1, 3));
CHECK(3 == *(int*) TRI_AtVector(&v1, 4));
CHECK(4 == *(int*) TRI_AtVector(&v1, 5));
CHECK(1 == *(int*) TRI_AtVector(&v1, 6));
TRI_RemoveVector(&v1, 0);
TRI_RemoveVector(&v1, 0);
CHECK((size_t) 5 == TRI_LengthVector(&v1));
CHECK(4 == *(int*) TRI_AtVector(&v1, 0));
CHECK(2 == *(int*) TRI_AtVector(&v1, 1));
CHECK(3 == *(int*) TRI_AtVector(&v1, 2));
CHECK(4 == *(int*) TRI_AtVector(&v1, 3));
CHECK(1 == *(int*) TRI_AtVector(&v1, 4));
TRI_RemoveVector(&v1, 1);
TRI_RemoveVector(&v1, 1);
CHECK((size_t) 3 == TRI_LengthVector(&v1));
CHECK(4 == *(int*) TRI_AtVector(&v1, 0));
CHECK(4 == *(int*) TRI_AtVector(&v1, 1));
CHECK(1 == *(int*) TRI_AtVector(&v1, 2));
TRI_RemoveVector(&v1, 1);
CHECK((size_t) 2 == TRI_LengthVector(&v1));
CHECK(4 == *(int*) TRI_AtVector(&v1, 0));
CHECK(1 == *(int*) TRI_AtVector(&v1, 1));
TRI_RemoveVector(&v1, 1);
TRI_RemoveVector(&v1, 0);
CHECK((size_t) 0 == TRI_LengthVector(&v1));
VECTOR_DESTROY
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test set
////////////////////////////////////////////////////////////////////////////////
SECTION("tst_set") {
VECTOR_INIT
int a = 1;
int b = 2;
int c = 3;
int d = 4;
TRI_PushBackVector(&v1, &a);
TRI_PushBackVector(&v1, &b);
TRI_PushBackVector(&v1, &c);
TRI_PushBackVector(&v1, &d);
CHECK((size_t) 4 == TRI_LengthVector(&v1));
CHECK(1 == *(int*) TRI_AtVector(&v1, 0));
CHECK(2 == *(int*) TRI_AtVector(&v1, 1));
CHECK(3 == *(int*) TRI_AtVector(&v1, 2));
CHECK(4 == *(int*) TRI_AtVector(&v1, 3));
CHECK(1 == *(int*) TRI_BeginVector(&v1));
CHECK(4 == *((int*) (int*) TRI_BeginVector(&v1) + TRI_LengthVector(&v1) - 1));
TRI_SetVector(&v1, 0, &d);
TRI_SetVector(&v1, 1, &c);
TRI_SetVector(&v1, 2, &b);
TRI_SetVector(&v1, 3, &a);
CHECK((size_t) 4 == TRI_LengthVector(&v1));
CHECK(4 == *(int*) TRI_AtVector(&v1, 0));
CHECK(3 == *(int*) TRI_AtVector(&v1, 1));
CHECK(2 == *(int*) TRI_AtVector(&v1, 2));
CHECK(1 == *(int*) TRI_AtVector(&v1, 3));
CHECK(4 == *(int*) TRI_BeginVector(&v1));
CHECK(1 == *((int*) (int*) TRI_BeginVector(&v1) + TRI_LengthVector(&v1) - 1));
TRI_SetVector(&v1, 0, &b);
CHECK(2 == *(int*) TRI_AtVector(&v1, 0));
CHECK(2 == *(int*) TRI_BeginVector(&v1));
VECTOR_DESTROY
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test modifications
////////////////////////////////////////////////////////////////////////////////
SECTION("tst_value_modifications") {
VECTOR_INIT
int a = 1;
int b = 2;
int c = 3;
int d = 4;
TRI_PushBackVector(&v1, &a);
TRI_PushBackVector(&v1, &b);
TRI_PushBackVector(&v1, &c);
TRI_PushBackVector(&v1, &d);
CHECK(1 == *(int*) TRI_AtVector(&v1, 0));
CHECK(2 == *(int*) TRI_AtVector(&v1, 1));
CHECK(3 == *(int*) TRI_AtVector(&v1, 2));
CHECK(4 == *(int*) TRI_AtVector(&v1, 3));
a = 99;
b = 42;
c = -1;
d = 0;
CHECK(1 == *(int*) TRI_AtVector(&v1, 0));
CHECK(2 == *(int*) TRI_AtVector(&v1, 1));
CHECK(3 == *(int*) TRI_AtVector(&v1, 2));
CHECK(4 == *(int*) TRI_AtVector(&v1, 3));
VECTOR_DESTROY
}
}
////////////////////////////////////////////////////////////////////////////////
/// @brief generate tests
////////////////////////////////////////////////////////////////////////////////
// Local Variables:
// mode: outline-minor
// outline-regexp: "^\\(/// @brief\\|/// {@inheritDoc}\\|/// @addtogroup\\|// --SECTION--\\|/// @\\}\\)"
// End: