summaryrefslogtreecommitdiff
path: root/test/unit/context/cdvector_black.h
diff options
context:
space:
mode:
Diffstat (limited to 'test/unit/context/cdvector_black.h')
-rw-r--r--test/unit/context/cdvector_black.h127
1 files changed, 127 insertions, 0 deletions
diff --git a/test/unit/context/cdvector_black.h b/test/unit/context/cdvector_black.h
new file mode 100644
index 000000000..8deac3fb3
--- /dev/null
+++ b/test/unit/context/cdvector_black.h
@@ -0,0 +1,127 @@
+
+#include <cxxtest/TestSuite.h>
+
+#include <vector>
+#include <iostream>
+
+#include <limits.h>
+
+#include "memory.h"
+
+#include "context/context.h"
+#include "context/cdvector.h"
+
+using namespace std;
+using namespace CVC4::context;
+using namespace CVC4::test;
+
+struct DtorSensitiveObject {
+ bool& d_dtorCalled;
+ DtorSensitiveObject(bool& dtorCalled) : d_dtorCalled(dtorCalled) {}
+ ~DtorSensitiveObject() { d_dtorCalled = true; }
+};
+
+
+
+class CDListBlack : public CxxTest::TestSuite {
+private:
+
+ Context* d_context;
+
+public:
+
+ void setUp() {
+ d_context = new Context();
+ }
+
+ void tearDown() {
+ delete d_context;
+ }
+
+ void testCDVector17() { vectorTest(17); }
+ void testCDVector31() { vectorTest(31); }
+ void testCDVector191() { vectorTest(113); }
+
+ void vectorTest(unsigned P){
+ vectorTest(P, 2);
+ vectorTest(P, 5);
+ vectorTest(P, P/3 + 1);
+ }
+
+ void vectorTest(unsigned P, unsigned m){
+ for(unsigned g=2; g< P; g++){
+ vectorTest(P, g, m, 1, false);
+ vectorTest(P, g, m, 3, false);
+ }
+ }
+ vector<unsigned> copy(CDVector<unsigned>& v){
+ vector<unsigned> ret;
+ for(unsigned i=0; i < v.size(); ++i){
+ ret.push_back(v[i]);
+ }
+ return ret;
+ }
+
+ void equal(vector<unsigned>& copy, CDVector<unsigned>& v){
+ TS_ASSERT_EQUALS(copy.size(), v.size());
+ for(unsigned i = 0; i < v.size(); ++i){
+ TS_ASSERT_EQUALS(copy[i], v[i]);
+ }
+ }
+
+ void vectorTest(unsigned P, unsigned g, unsigned m, unsigned r, bool callDestructor) {
+ CDVector<unsigned> vec(d_context, callDestructor);
+ vector< vector<unsigned> > copies;
+
+ copies.push_back( copy(vec) );
+ d_context->push();
+
+ TS_ASSERT(vec.empty());
+ for(unsigned i = 0; i < P; ++i){
+ vec.push_back(i);
+ TS_ASSERT_EQUALS(vec.size(), i+1);
+ }
+ TS_ASSERT(!vec.empty());
+ TS_ASSERT_EQUALS(vec.size(), P);
+
+ copies.push_back( copy(vec) );
+ d_context->push();
+
+ for(unsigned i = 0, g_i = 1; i < r*P; ++i, g_i = (g_i * g)% P){
+ if(i % m == 0){
+ copies.push_back( copy(vec) );
+ d_context->push();
+ }
+
+ vec.set(g_i, i);
+
+ TS_ASSERT_EQUALS(vec.get(g_i), i);
+ }
+ TS_ASSERT_EQUALS(vec.size(), P);
+
+ copies.push_back( copy(vec) );
+
+ while(d_context->getLevel() >= 1){
+ TS_ASSERT_EQUALS(vec.size(), P);
+ equal(copies[d_context->getLevel()], vec);
+ d_context->pop();
+ }
+ }
+
+ void testTreeUpdate() {
+ CDVector<int> vec(d_context);
+ vec.push_back(-1);
+
+ vec.set(0, 0);
+ d_context->push();
+ d_context->push();
+ vec.set(0, 1);
+ d_context->pop();
+ d_context->pop();
+
+ d_context->push();
+ d_context->push();
+ TS_ASSERT_EQUALS(vec.get(0), 0);
+ }
+
+};
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback