| /* | 
 |  * Copyright 2014 Google Inc. | 
 |  * | 
 |  * Use of this source code is governed by a BSD-style license that can be | 
 |  * found in the LICENSE file. | 
 |  */ | 
 |  | 
 | // This is a GPU-backend specific test | 
 | #if SK_SUPPORT_GPU | 
 |  | 
 | #include "GrRedBlackTree.h" | 
 | #include "SkRandom.h" | 
 | #include "Test.h" | 
 |  | 
 | typedef GrRedBlackTree<int> Tree; | 
 |  | 
 | DEF_TEST(GrRedBlackTreeTest, reporter) { | 
 |     Tree tree; | 
 |  | 
 |     SkRandom r; | 
 |  | 
 |     int count[100] = {0}; | 
 |     // add 10K ints | 
 |     for (int i = 0; i < 10000; ++i) { | 
 |         int x = r.nextU() % 100; | 
 |         Tree::Iter xi = tree.insert(x); | 
 |         REPORTER_ASSERT(reporter, *xi == x); | 
 |         ++count[x]; | 
 |     } | 
 |  | 
 |     tree.insert(0); | 
 |     ++count[0]; | 
 |     tree.insert(99); | 
 |     ++count[99]; | 
 |     REPORTER_ASSERT(reporter, *tree.begin() == 0); | 
 |     REPORTER_ASSERT(reporter, *tree.last() == 99); | 
 |     REPORTER_ASSERT(reporter, --(++tree.begin()) == tree.begin()); | 
 |     REPORTER_ASSERT(reporter, --tree.end() == tree.last()); | 
 |     REPORTER_ASSERT(reporter, tree.count() == 10002); | 
 |  | 
 |     int c = 0; | 
 |     // check that we iterate through the correct number of | 
 |     // elements and they are properly sorted. | 
 |     for (Tree::Iter a = tree.begin(); tree.end() != a; ++a) { | 
 |         Tree::Iter b = a; | 
 |         ++b; | 
 |         ++c; | 
 |         REPORTER_ASSERT(reporter, b == tree.end() || *a <= *b); | 
 |     } | 
 |     REPORTER_ASSERT(reporter, c == tree.count()); | 
 |  | 
 |     // check that the tree reports the correct number of each int | 
 |     // and that we can iterate through them correctly both forward | 
 |     // and backward. | 
 |     for (int i = 0; i < 100; ++i) { | 
 |         int c; | 
 |         c = tree.countOf(i); | 
 |         REPORTER_ASSERT(reporter, c == count[i]); | 
 |         c = 0; | 
 |         Tree::Iter iter = tree.findFirst(i); | 
 |         while (iter != tree.end() && *iter == i) { | 
 |             ++c; | 
 |             ++iter; | 
 |         } | 
 |         REPORTER_ASSERT(reporter, count[i] == c); | 
 |         c = 0; | 
 |         iter = tree.findLast(i); | 
 |         if (iter != tree.end()) { | 
 |             do { | 
 |                 if (*iter == i) { | 
 |                     ++c; | 
 |                 } else { | 
 |                     break; | 
 |                 } | 
 |                 if (iter != tree.begin()) { | 
 |                     --iter; | 
 |                 } else { | 
 |                     break; | 
 |                 } | 
 |             } while (true); | 
 |         } | 
 |         REPORTER_ASSERT(reporter, c == count[i]); | 
 |     } | 
 |     // remove all the ints between 25 and 74. Randomly chose to remove | 
 |     // the first, last, or any entry for each. | 
 |     for (int i = 25; i < 75; ++i) { | 
 |         while (0 != tree.countOf(i)) { | 
 |             --count[i]; | 
 |             int x = r.nextU() % 3; | 
 |             Tree::Iter iter; | 
 |             switch (x) { | 
 |             case 0: | 
 |                 iter = tree.findFirst(i); | 
 |                 break; | 
 |             case 1: | 
 |                 iter = tree.findLast(i); | 
 |                 break; | 
 |             case 2: | 
 |             default: | 
 |                 iter = tree.find(i); | 
 |                 break; | 
 |             } | 
 |             tree.remove(iter); | 
 |         } | 
 |         REPORTER_ASSERT(reporter, 0 == count[i]); | 
 |         REPORTER_ASSERT(reporter, tree.findFirst(i) == tree.end()); | 
 |         REPORTER_ASSERT(reporter, tree.findLast(i) == tree.end()); | 
 |         REPORTER_ASSERT(reporter, tree.find(i) == tree.end()); | 
 |     } | 
 |     // remove all of the 0 entries. (tests removing begin()) | 
 |     REPORTER_ASSERT(reporter, *tree.begin() == 0); | 
 |     REPORTER_ASSERT(reporter, *(--tree.end()) == 99); | 
 |     while (0 != tree.countOf(0)) { | 
 |         --count[0]; | 
 |         tree.remove(tree.find(0)); | 
 |     } | 
 |     REPORTER_ASSERT(reporter, 0 == count[0]); | 
 |     REPORTER_ASSERT(reporter, tree.findFirst(0) == tree.end()); | 
 |     REPORTER_ASSERT(reporter, tree.findLast(0) == tree.end()); | 
 |     REPORTER_ASSERT(reporter, tree.find(0) == tree.end()); | 
 |     REPORTER_ASSERT(reporter, 0 < *tree.begin()); | 
 |  | 
 |     // remove all the 99 entries (tests removing last()). | 
 |     while (0 != tree.countOf(99)) { | 
 |         --count[99]; | 
 |         tree.remove(tree.find(99)); | 
 |     } | 
 |     REPORTER_ASSERT(reporter, 0 == count[99]); | 
 |     REPORTER_ASSERT(reporter, tree.findFirst(99) == tree.end()); | 
 |     REPORTER_ASSERT(reporter, tree.findLast(99) == tree.end()); | 
 |     REPORTER_ASSERT(reporter, tree.find(99) == tree.end()); | 
 |     REPORTER_ASSERT(reporter, 99 > *(--tree.end())); | 
 |     REPORTER_ASSERT(reporter, tree.last() == --tree.end()); | 
 |  | 
 |     // Make sure iteration still goes through correct number of entries | 
 |     // and is still sorted correctly. | 
 |     c = 0; | 
 |     for (Tree::Iter a = tree.begin(); tree.end() != a; ++a) { | 
 |         Tree::Iter b = a; | 
 |         ++b; | 
 |         ++c; | 
 |         REPORTER_ASSERT(reporter, b == tree.end() || *a <= *b); | 
 |     } | 
 |     REPORTER_ASSERT(reporter, c == tree.count()); | 
 |  | 
 |     // repeat check that correct number of each entry is in the tree | 
 |     // and iterates correctly both forward and backward. | 
 |     for (int i = 0; i < 100; ++i) { | 
 |         REPORTER_ASSERT(reporter, tree.countOf(i) == count[i]); | 
 |         int c = 0; | 
 |         Tree::Iter iter = tree.findFirst(i); | 
 |         while (iter != tree.end() && *iter == i) { | 
 |             ++c; | 
 |             ++iter; | 
 |         } | 
 |         REPORTER_ASSERT(reporter, count[i] == c); | 
 |         c = 0; | 
 |         iter = tree.findLast(i); | 
 |         if (iter != tree.end()) { | 
 |             do { | 
 |                 if (*iter == i) { | 
 |                     ++c; | 
 |                 } else { | 
 |                     break; | 
 |                 } | 
 |                 if (iter != tree.begin()) { | 
 |                     --iter; | 
 |                 } else { | 
 |                     break; | 
 |                 } | 
 |             } while (true); | 
 |         } | 
 |         REPORTER_ASSERT(reporter, count[i] == c); | 
 |     } | 
 |  | 
 |     // remove all entries | 
 |     while (!tree.empty()) { | 
 |         tree.remove(tree.begin()); | 
 |     } | 
 |  | 
 |     // test reset on empty tree. | 
 |     tree.reset(); | 
 | } | 
 |  | 
 | #endif |