Mercurial > hg > Members > Moririn
diff src/parallel_execution/test/rbTree_test.cbc @ 453:40ea6277b91c
add rbTree_test.cbc
author | ryokka |
---|---|
date | Fri, 08 Dec 2017 15:32:14 +0900 (2017-12-08) |
parents | |
children | 77de0283ac92 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/parallel_execution/test/rbTree_test.cbc Fri Dec 08 15:32:14 2017 +0900 @@ -0,0 +1,65 @@ +#include "../../context.h" +#include <assert.h> + +__code rbTreeTest1(struct Tree* tree) { + printf("insert1\n"); + Node* node = new Node(); + node->value = 3; + node->key = 3; + printf("value->%d,key->%d\n",node->value,node->key); + goto tree->put(node, rbTreeTest2); +} + +__code rbTreeTest1_stub(struct Context* context) { + printf("insert1_stub\n"); + Tree* tree = createRedBlackTree(context); + goto rbTreeTest1(context,tree); +} + + +__code rbTreeTest2(struct Tree* tree) { + printf("insert2\n"); + Node* node = new Node(); + node->value = 4; + node->key = 4; + goto tree->put(node, rbTreeTest3); +} + + + +__code rbTreeTest3(struct Tree* tree) { + printf("insert3\n"); + Node* node = new Node(); + node->value = 2; + node->key = 2; + goto tree->put(node, rbTreeTest4); +} + + +__code rbTreeTest4(struct Tree* tree) { + printf("insert4\n"); + Node* node = new Node(); + node->value = 8; + node->key = 8; + goto tree->put(node, rbTreeTest5); +} + + +__code rbTreeTest5(struct Tree* tree) { + printf("insert5\n"); + Node* node = new Node(); + node->value = 7; + node->key = 7; + goto tree->put(node, assert1); +} + + +__code assert1(struct RedBlackTree* tree) { + printf("assert\n"); + assert(tree->root->color == Black); + goto exit_code(0); +} + +int main(int argc, char const* argv[]) { + goto rbTreeTest1(); +}