xref: /aoo42x/main/sw/qa/core/Test-BigPtrArray.cxx (revision efeef26f)
1 /**************************************************************
2  *
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  You may obtain a copy of the License at
10  *
11  *   http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  *
20  *************************************************************/
21 
22 
23 
24 // MARKER(update_precomp.py): autogen include statement, do not remove
25 #include "precompiled_sw.hxx"
26 #define TIMELOG
27 
28 #include <testshl/simpleheader.hxx>
29 #include <bparr.hxx>
30 #include <string>
31 #include <stdlib.h>
32 #include <rtl/logfile.hxx>
33 
34 #undef ENABLE_DEBUG_OUTPUT
35 
36 using namespace std;
37 
38 
39 namespace /* private */
40 {
41     const int NUM_ENTRIES = 100000;
42 
43     class BigPtrEntryMock : public BigPtrEntry
44     {
45     public:
46         BigPtrEntryMock(int count) : count_(count)
47         {
48         }
49 
50         ~BigPtrEntryMock()
51         {
52         #ifdef ENABLE_DEBUG_OUTPUT
53             printf("Destructor called (%i)\n", count_);
54         #endif
55         }
56 
57         int getCount() const
58         {
59             return count_;
60         }
61 
62         void setCount(int newCount)
63         {
64             count_ = newCount;
65         }
66 
67         sal_uLong Position() const
68         {
69             return GetPos();
70         }
71 
72     private:
73         int count_;
74     };
75 
76     sal_Bool AddToCount(const ElementPtr& rElem, void* pArgs)
77     {
78         BigPtrEntryMock* const pbem = static_cast<BigPtrEntryMock* const>(rElem);
79         pbem->setCount(pbem->getCount() + *((int*)pArgs));
80         return true;
81     }
82 
83     void dumpBigPtrArray(const BigPtrArray& bparr)
84     {
85     #ifdef ENABLE_DEBUG_OUTPUT
86         for (int i = 0; i < bparr.Count(); i++)
87             printf("bparr[%i,%i]: %i\n", i, static_cast<BigPtrEntryMock*>(bparr[i])->Position(), static_cast<BigPtrEntryMock*>(bparr[i])->getCount());
88 
89         printf("\n");
90     #endif
91     }
92 
93     void fillBigPtrArray(BigPtrArray& bparr, sal_uLong numEntries)
94     {
95         for (int i = 0; i < numEntries; i++)
96             bparr.Insert(new BigPtrEntryMock(i), bparr.Count());
97     }
98 
99     void printMethodName(const char* name)
100     {
101     #ifdef ENABLE_DEBUG_OUTPUT
102         printf(name);
103     #endif
104     }
105 
106     bool checkElementPositions(const BigPtrArray& bparr)
107     {
108         for (int i = 0; i < bparr.Count(); i++)
109         {
110             if (static_cast<BigPtrEntryMock*>(bparr[i])->Position() != i)
111                 return false;
112         }
113         return true;
114     }
115 
116     void releaseBigPtrArrayContent(BigPtrArray& bparr)
117     {
118         for (int i = 0; i < bparr.Count(); i++)
119             delete bparr[i];
120     }
121 
122     RTL_LOGFILE_CONTEXT(logFile, "BigPtrArray performance measures" );
123 }
124 
125 class BigPtrArrayUnittest : public CppUnit::TestFixture
126 {
127 public:
128 
129     BigPtrArrayUnittest()
130     {
131     }
132 
133     /** Test constructor/destructor
134         The size of the BigPtrArray
135         aka the 'Count' should be 0
136         initially.
137     */
138     void test_ctor()
139     {
140         printMethodName("test_ctor\n");
141 
142         BigPtrArray bparr;
143 
144         CPPUNIT_ASSERT_MESSAGE
145         (
146             "BigPtrArray ctor failed",
147             bparr.Count() == 0
148         );
149     }
150 
151     void test_insert_entries_at_front()
152     {
153         printMethodName("test_insert_entries_at_front\n");
154 
155         RTL_LOGFILE_CONTEXT_TRACE(logFile, "START: test_insert_entries_at_front");
156 
157         BigPtrArray bparr;
158 
159         for (int i = 0; i < NUM_ENTRIES; i++)
160         {
161             sal_uLong oldCount = bparr.Count();
162             bparr.Insert(new BigPtrEntryMock(i), 0);
163             CPPUNIT_ASSERT_MESSAGE
164             (
165                 "test_insert_entries_at_front failed",
166                 (bparr.Count() == oldCount + 1)
167             )
168         }
169 
170         RTL_LOGFILE_CONTEXT_TRACE(logFile, "END: test_insert_entries_at_front");
171 
172         for (int i = 0, j = NUM_ENTRIES - 1; i < NUM_ENTRIES; i++, j--)
173         {
174             CPPUNIT_ASSERT_MESSAGE
175             (
176                 "test_insert_entries_at_front failed",
177                 static_cast<BigPtrEntryMock*>(bparr[i])->getCount() == j
178             )
179         }
180 
181         CPPUNIT_ASSERT_MESSAGE
182         (
183             "test_insert_entries_at_front failed",
184             checkElementPositions(bparr)
185         )
186 
187         releaseBigPtrArrayContent(bparr);
188         dumpBigPtrArray(bparr);
189     }
190 
191     void test_insert_entries_in_the_middle()
192     {
193         printMethodName("test_insert_entries_in_the_middle\n");
194 
195         RTL_LOGFILE_CONTEXT_TRACE(logFile, "START: test_insert_entries_in_the_middle");
196 
197         BigPtrArray bparr;
198 
199         fillBigPtrArray(bparr, NUM_ENTRIES);
200         dumpBigPtrArray(bparr);
201 
202         sal_uLong oldCount = bparr.Count();
203 
204         bparr.Insert(new BigPtrEntryMock(NUM_ENTRIES), bparr.Count() / 2);
205 
206         RTL_LOGFILE_CONTEXT_TRACE(logFile, "END: test_insert_entries_in_the_middle");
207 
208         CPPUNIT_ASSERT_MESSAGE
209         (
210             "test_insert_entries_in_the_middle failed",
211             (oldCount + 1 == bparr.Count() && static_cast<BigPtrEntryMock*>(bparr[bparr.Count() / 2])->getCount() == NUM_ENTRIES)
212         )
213 
214         CPPUNIT_ASSERT_MESSAGE
215         (
216             "test_insert_entries_in_the_middle failed",
217             checkElementPositions(bparr)
218         )
219 
220         releaseBigPtrArrayContent(bparr);
221         dumpBigPtrArray(bparr);
222     }
223 
224     void test_insert_at_already_used_index()
225     {
226         printMethodName("test_insert_at_already_used_index\n");
227 
228         RTL_LOGFILE_CONTEXT_TRACE(logFile, "START: test_insert_at_already_used_index");
229 
230         BigPtrArray bparr;
231 
232         fillBigPtrArray(bparr, NUM_ENTRIES);
233         dumpBigPtrArray(bparr);
234 
235         int oldCount = bparr.Count();
236 
237         for (int i = 0, j = -5; i < 5; i++, j++)
238             bparr.Insert(new BigPtrEntryMock(j), i);
239 
240         RTL_LOGFILE_CONTEXT_TRACE(logFile, "END: test_insert_at_already_used_index");
241 
242         CPPUNIT_ASSERT_MESSAGE
243         (
244             "test_insert_at_already_used_index failed",
245             (oldCount + 5 == bparr.Count())
246         )
247 
248         for (int i = 0, j = -5; i < bparr.Count(); i++, j++)
249         {
250             CPPUNIT_ASSERT_MESSAGE
251             (
252                 "test_insert_at_already_used_index failed",
253                 static_cast<BigPtrEntryMock*>(bparr[i])->getCount() == j
254             )
255         }
256 
257         CPPUNIT_ASSERT_MESSAGE
258         (
259             "test_insert_at_already_used_index failed",
260             checkElementPositions(bparr)
261         )
262 
263         releaseBigPtrArrayContent(bparr);
264         dumpBigPtrArray(bparr);
265     }
266 
267     void test_insert_at_end()
268     {
269         printMethodName("test_insert_at_end\n");
270 
271         BigPtrArray bparr;
272 
273         fillBigPtrArray(bparr, NUM_ENTRIES);
274         dumpBigPtrArray(bparr);
275 
276         sal_uLong oldCount = bparr.Count();
277         bparr.Insert(new BigPtrEntryMock(NUM_ENTRIES), bparr.Count());
278 
279         CPPUNIT_ASSERT_MESSAGE
280         (
281             "test_insert_at_end failed",
282             (oldCount + 1 == bparr.Count() && static_cast<BigPtrEntryMock*>(bparr[bparr.Count()-1])->getCount() == NUM_ENTRIES)
283         )
284 
285         CPPUNIT_ASSERT_MESSAGE
286         (
287             "test_insert_at_end failed",
288             checkElementPositions(bparr)
289         )
290 
291         releaseBigPtrArrayContent(bparr);
292         dumpBigPtrArray(bparr);
293     }
294 
295     void test_remove_at_front()
296     {
297         printMethodName("test_remove_at_front\n");
298 
299         RTL_LOGFILE_CONTEXT_TRACE(logFile, "START: test_remove_at_front");
300 
301         BigPtrArray bparr;
302 
303         fillBigPtrArray(bparr, NUM_ENTRIES);
304         dumpBigPtrArray(bparr);
305 
306         for (int i = 0; i < NUM_ENTRIES; i++)
307         {
308             sal_uLong oldCount = bparr.Count();
309 
310             delete bparr[0]; // release content
311             bparr.Remove(0); // remove item from container
312 
313             CPPUNIT_ASSERT_MESSAGE
314             (
315                 "test_remove_at_front failed (wrong count)",
316                 (oldCount - 1 == bparr.Count())
317             )
318 
319             for (int j = 0, k = i + 1; j < bparr.Count(); j++, k++)
320             {
321                 CPPUNIT_ASSERT_MESSAGE
322                 (
323                     "test_remove_at_front failed",
324                     static_cast<BigPtrEntryMock*>(bparr[j])->getCount() == k
325                 )
326             }
327 
328             CPPUNIT_ASSERT_MESSAGE
329             (
330                 "test_remove_at_front failed",
331                 checkElementPositions(bparr)
332             )
333 
334             dumpBigPtrArray(bparr);
335         }
336 
337         RTL_LOGFILE_CONTEXT_TRACE(logFile, "END: test_remove_at_front");
338     }
339 
340     void test_remove_at_back()
341     {
342         printMethodName("test_remove_at_back\n");
343 
344         BigPtrArray bparr;
345 
346         fillBigPtrArray(bparr, NUM_ENTRIES);
347         dumpBigPtrArray(bparr);
348 
349         for (int i = NUM_ENTRIES - 1; i >= 0; i--)
350         {
351             sal_uLong oldCount = bparr.Count();
352             delete bparr[i];
353             bparr.Remove(i);
354 
355             CPPUNIT_ASSERT_MESSAGE
356             (
357                 "test_remove_at_back failed (wrong count)",
358                 (oldCount - 1 == bparr.Count())
359             )
360 
361             for (int j = 0; j < bparr.Count(); j++)
362             {
363                 CPPUNIT_ASSERT_MESSAGE
364                 (
365                     "test_remove_at_back failed",
366                     static_cast<BigPtrEntryMock*>(bparr[j])->getCount() == j
367                 )
368             }
369 
370             CPPUNIT_ASSERT_MESSAGE
371             (
372                 "test_remove_at_back failed",
373                 checkElementPositions(bparr)
374             )
375 
376             dumpBigPtrArray(bparr);
377         }
378     }
379 
380     void test_remove_in_the_middle()
381     {
382         printMethodName("test_remove_in_the_middle\n");
383 
384         RTL_LOGFILE_CONTEXT_TRACE(logFile, "START: test_remove_in_the_middle");
385 
386         BigPtrArray bparr;
387 
388         fillBigPtrArray(bparr, NUM_ENTRIES);
389         dumpBigPtrArray(bparr);
390 
391         while (bparr.Count())
392         {
393             sal_uLong oldCount = bparr.Count();
394             int oldElement = static_cast<BigPtrEntryMock*>(bparr[bparr.Count() / 2])->getCount();
395 
396             delete bparr[bparr.Count() / 2];
397             bparr.Remove(bparr.Count() / 2);
398 
399             CPPUNIT_ASSERT_MESSAGE
400             (
401                 "test_remove_in_the_middle failed (wrong count)",
402                 (oldCount - 1 == bparr.Count())
403             )
404 
405             for (int i = 0; i < bparr.Count(); i++)
406             {
407                 CPPUNIT_ASSERT_MESSAGE
408                 (
409                     "test_remove_in_the_middle failed",
410                     static_cast<BigPtrEntryMock*>(bparr[i])->getCount() != oldElement
411                 )
412             }
413 
414             CPPUNIT_ASSERT_MESSAGE
415             (
416                 "test_remove_in_the_middle failed",
417                 checkElementPositions(bparr)
418             )
419 
420             dumpBigPtrArray(bparr);
421         }
422         RTL_LOGFILE_CONTEXT_TRACE(logFile, "END: test_remove_in_the_middle");
423     }
424 
425     void test_remove_multiple_elements_at_once()
426     {
427         printMethodName("test_remove_multiple_elements_at_once\n");
428 
429         BigPtrArray bparr;
430 
431         fillBigPtrArray(bparr, NUM_ENTRIES);
432         dumpBigPtrArray(bparr);
433 
434         while(bparr.Count())
435         {
436             sal_uLong nRemove = (bparr.Count() > 3) ? 3 : bparr.Count();
437             sal_uLong oldCount = bparr.Count();
438 
439             for (int i = 0; i < nRemove; i++)
440                 delete bparr[i];
441 
442             bparr.Remove(0, nRemove);
443 
444             CPPUNIT_ASSERT_MESSAGE
445             (
446                 "test_remove_multiple_elements_at_once failed",
447                 (oldCount - nRemove == bparr.Count())
448             )
449 
450             CPPUNIT_ASSERT_MESSAGE
451             (
452                 "test_remove_multiple_elements_at_once failed",
453                 checkElementPositions(bparr)
454             )
455 
456             dumpBigPtrArray(bparr);
457         }
458     }
459 
460     void test_remove_all_elements_at_once()
461     {
462         printMethodName("test_remove_all_elements_at_once\n");
463 
464         BigPtrArray bparr;
465 
466         fillBigPtrArray(bparr, NUM_ENTRIES);
467         dumpBigPtrArray(bparr);
468 
469         releaseBigPtrArrayContent(bparr);
470         bparr.Remove(0, bparr.Count());
471 
472         CPPUNIT_ASSERT_MESSAGE
473         (
474             "test_remove_all_elements_at_once failed",
475             bparr.Count() == 0
476         )
477 
478         dumpBigPtrArray(bparr);
479     }
480 
481     void test_move_elements_from_lower_to_higher_pos()
482     {
483         printMethodName("test_move_elements_from_lower_to_higher_pos\n");
484 
485         BigPtrArray bparr;
486 
487         fillBigPtrArray(bparr, NUM_ENTRIES);
488         dumpBigPtrArray(bparr);
489 
490         for (int i = 0; i < NUM_ENTRIES - 1; i++)
491         {
492             bparr.Move(i, i + 2);
493             dumpBigPtrArray(bparr);
494         }
495 
496         for (int i = 0; i < (NUM_ENTRIES - 1); i++)
497         {
498             CPPUNIT_ASSERT_MESSAGE
499             (
500                 "test_move_elements_from_lower_to_higher_pos failed",
501                 static_cast<BigPtrEntryMock*>(bparr[i])->getCount() == (i + 1)
502             )
503         }
504 
505         CPPUNIT_ASSERT_MESSAGE
506         (
507             "test_move_elements_from_lower_to_higher_pos failed",
508             static_cast<BigPtrEntryMock*>(bparr[NUM_ENTRIES -1])->getCount() == 0
509         )
510 
511         CPPUNIT_ASSERT_MESSAGE
512         (
513             "test_move_elements_from_lower_to_higher_pos failed",
514             checkElementPositions(bparr)
515         )
516 
517         releaseBigPtrArrayContent(bparr);
518     }
519 
520     void test_move_elements_from_higher_to_lower_pos()
521     {
522         printMethodName("test_move_elements_from_higher_to_lower_pos\n");
523 
524         BigPtrArray bparr;
525 
526         fillBigPtrArray(bparr, NUM_ENTRIES);
527         dumpBigPtrArray(bparr);
528 
529         for (int i = NUM_ENTRIES - 1; i >= 1; i--)
530         {
531             bparr.Move(i, i - 1);
532             dumpBigPtrArray(bparr);
533         }
534 
535         CPPUNIT_ASSERT_MESSAGE
536         (
537             "test_move_elements_from_higher_to_lower_pos failed",
538             static_cast<BigPtrEntryMock*>(bparr[0])->getCount() == (NUM_ENTRIES - 1)
539         )
540 
541         for (int i = 1; i < NUM_ENTRIES; i++)
542         {
543             CPPUNIT_ASSERT_MESSAGE
544             (
545                 "test_move_elements_from_higher_to_lower_pos failed",
546                 static_cast<BigPtrEntryMock*>(bparr[i])->getCount() == (i - 1)
547             )
548         }
549 
550         CPPUNIT_ASSERT_MESSAGE
551         (
552             "test_move_elements_from_higher_to_lower_pos failed",
553             checkElementPositions(bparr)
554         )
555 
556         releaseBigPtrArrayContent(bparr);
557     }
558 
559     void test_move_to_same_position()
560     {
561         printMethodName("test_move_to_same_position\n");
562 
563         BigPtrArray bparr;
564 
565         fillBigPtrArray(bparr, NUM_ENTRIES);
566         dumpBigPtrArray(bparr);
567 
568         for (int i = 0; i < NUM_ENTRIES; i++)
569         {
570             bparr.Move(i, i);
571         }
572 
573         dumpBigPtrArray(bparr);
574 
575         for (int i = 0; i < NUM_ENTRIES; i++)
576         {
577             CPPUNIT_ASSERT_MESSAGE
578             (
579                 "test_move_to_same_position failed",
580                 static_cast<BigPtrEntryMock*>(bparr[i])->getCount() == i
581             )
582         }
583 
584         CPPUNIT_ASSERT_MESSAGE
585         (
586             "test_move_to_same_position failed",
587             checkElementPositions(bparr)
588         )
589 
590         releaseBigPtrArrayContent(bparr);
591         dumpBigPtrArray(bparr);
592     }
593 
594     void test_replace_elements()
595     {
596         printMethodName("test_replace_elements\n");
597 
598         BigPtrArray bparr;
599 
600         fillBigPtrArray(bparr, NUM_ENTRIES);
601         dumpBigPtrArray(bparr);
602 
603         for (int i = 0, j = NUM_ENTRIES - 1; i < NUM_ENTRIES; i++, j--)
604         {
605             delete bparr[i];
606             bparr.Replace(i, new BigPtrEntryMock(j));
607             dumpBigPtrArray(bparr);
608         }
609 
610         for (int i = 0; i < NUM_ENTRIES; i++)
611         {
612             CPPUNIT_ASSERT_MESSAGE
613             (
614                 "test_replace_elements failed",
615                 static_cast<BigPtrEntryMock*>(bparr[i])->getCount() == (NUM_ENTRIES - i - 1)
616             )
617         }
618 
619         CPPUNIT_ASSERT_MESSAGE
620         (
621             "test_replace_elements failed",
622             checkElementPositions(bparr)
623         )
624 
625         releaseBigPtrArrayContent(bparr);
626     }
627 
628     void test_for_each()
629     {
630         printMethodName("test_for_each\n");
631 
632         BigPtrArray bparr;
633 
634         fillBigPtrArray(bparr, NUM_ENTRIES);
635         dumpBigPtrArray(bparr);
636 
637         int addCount = 1;
638         bparr.ForEach(AddToCount, &addCount);
639 
640         for (int i = 0; i < NUM_ENTRIES; i++)
641         {
642             CPPUNIT_ASSERT_MESSAGE
643             (
644                 "test_for_each failed",
645                 static_cast<BigPtrEntryMock*>(bparr[i])->getCount() == (i+1)
646             )
647         }
648 
649         releaseBigPtrArrayContent(bparr);
650         dumpBigPtrArray(bparr);
651     }
652 
653     void test_for_some1()
654     {
655          printMethodName("test_for_some1\n");
656 
657         BigPtrArray bparr;
658 
659         fillBigPtrArray(bparr, NUM_ENTRIES);
660         dumpBigPtrArray(bparr);
661 
662         int addCount = 1;
663         bparr.ForEach(0, NUM_ENTRIES / 2, AddToCount, &addCount);
664 
665         int i = 0;
666         for (/* */; i < NUM_ENTRIES / 2; i++)
667         {
668             CPPUNIT_ASSERT_MESSAGE
669             (
670                 "test_for_some1 failed",
671                 static_cast<BigPtrEntryMock*>(bparr[i])->getCount() == (i+1)
672             )
673         }
674 
675         for (/* */; i < NUM_ENTRIES; i++)
676         {
677             CPPUNIT_ASSERT_MESSAGE
678             (
679                 "test_for_some1 failed",
680                 static_cast<BigPtrEntryMock*>(bparr[i])->getCount() == (i)
681             )
682         }
683 
684         releaseBigPtrArrayContent(bparr);
685         dumpBigPtrArray(bparr);
686     }
687 
688     void test_for_some2()
689     {
690         printMethodName("test_for_some2\n");
691 
692         BigPtrArray bparr;
693 
694         fillBigPtrArray(bparr, NUM_ENTRIES);
695         dumpBigPtrArray(bparr);
696 
697         int addCount = 1;
698         bparr.ForEach(NUM_ENTRIES / 2, NUM_ENTRIES, AddToCount, &addCount);
699 
700         int i = 0;
701         for (/* */; i < NUM_ENTRIES / 2; i++)
702         {
703             CPPUNIT_ASSERT_MESSAGE
704             (
705                 "test_for_some2 failed",
706                 static_cast<BigPtrEntryMock*>(bparr[i])->getCount() == (i)
707             )
708         }
709 
710         for (/* */; i < NUM_ENTRIES; i++)
711         {
712             CPPUNIT_ASSERT_MESSAGE
713             (
714                 "test_for_some2 failed",
715                 static_cast<BigPtrEntryMock*>(bparr[i])->getCount() == (i+1)
716             )
717         }
718 
719         releaseBigPtrArrayContent(bparr);
720         dumpBigPtrArray(bparr);
721     }
722 
723     void test_for_some3()
724     {
725         printMethodName("test_for_some3\n");
726 
727         BigPtrArray bparr;
728 
729         fillBigPtrArray(bparr, NUM_ENTRIES);
730         dumpBigPtrArray(bparr);
731 
732         int addCount = 1;
733         bparr.ForEach(0, 0, AddToCount, &addCount);
734 
735         for (int i = 0; i < NUM_ENTRIES; i++)
736         {
737             CPPUNIT_ASSERT_MESSAGE
738             (
739                 "test_for_some3 failed",
740                 static_cast<BigPtrEntryMock*>(bparr[i])->getCount() == i
741             )
742         }
743         releaseBigPtrArrayContent(bparr);
744     }
745 
746     CPPUNIT_TEST_SUITE(BigPtrArrayUnittest);
747     CPPUNIT_TEST(test_ctor);
748     CPPUNIT_TEST(test_insert_entries_at_front);
749     CPPUNIT_TEST(test_insert_entries_in_the_middle);
750     CPPUNIT_TEST(test_insert_at_already_used_index);
751     CPPUNIT_TEST(test_insert_at_end);
752     CPPUNIT_TEST(test_remove_at_front);
753     CPPUNIT_TEST(test_remove_at_back);
754     CPPUNIT_TEST(test_remove_in_the_middle);
755     CPPUNIT_TEST(test_remove_multiple_elements_at_once);
756     CPPUNIT_TEST(test_remove_all_elements_at_once);
757     CPPUNIT_TEST(test_move_elements_from_lower_to_higher_pos);
758     CPPUNIT_TEST(test_move_elements_from_higher_to_lower_pos);
759     CPPUNIT_TEST(test_replace_elements);
760     CPPUNIT_TEST(test_for_each);
761     CPPUNIT_TEST(test_for_some1);
762     CPPUNIT_TEST(test_for_some2);
763     CPPUNIT_TEST(test_for_some3);
764     CPPUNIT_TEST_SUITE_END();
765 };
766 
767 const char* START = "START: ";
768 const char* END = "END: ";
769 
770 class PerformanceTracer
771 {
772 public:
773 
774 public:
775     PerformanceTracer(const string& methodName) :
776         startString_(START),
777         endString_(END)
778     {
779         startString_ += methodName;
780         endString_ += methodName;
781         RTL_LOGFILE_CONTEXT_TRACE(logFile, startString_.c_str());
782     }
783 
784     ~PerformanceTracer()
785     {
786         RTL_LOGFILE_CONTEXT_TRACE(logFile, endString_.c_str());
787     }
788 
789 private:
790     string startString_;
791     string endString_;
792 };
793 
794 class BigPtrArrayPerformanceTest : public CppUnit::TestFixture
795 {
796 public:
797     BigPtrArrayPerformanceTest()
798     {
799     }
800 
801     void test_insert_at_end_1000()
802     { test_insert_at_end("1000"); }
803 
804     void test_insert_at_end_10000()
805     { test_insert_at_end("10000"); }
806 
807     void test_insert_at_end_100000()
808     { test_insert_at_end("100000"); }
809 
810     void test_insert_at_end_1000000()
811     { test_insert_at_end("1000000"); }
812 
813     void test_insert_at_front_1000()
814     { test_insert_at_front("1000"); }
815 
816     void test_insert_at_front_10000()
817     { test_insert_at_front("10000"); }
818 
819     void test_insert_at_front_100000()
820     { test_insert_at_front("100000"); }
821 
822     void test_insert_at_front_1000000()
823     { test_insert_at_front("1000000"); }
824 
825     CPPUNIT_TEST_SUITE(BigPtrArrayPerformanceTest);
826     CPPUNIT_TEST(test_insert_at_end_1000);
827     CPPUNIT_TEST(test_insert_at_end_10000);
828     CPPUNIT_TEST(test_insert_at_end_100000);
829     CPPUNIT_TEST(test_insert_at_end_1000000);
830     CPPUNIT_TEST(test_insert_at_front_1000);
831     CPPUNIT_TEST(test_insert_at_front_10000);
832     CPPUNIT_TEST(test_insert_at_front_100000);
833     CPPUNIT_TEST(test_insert_at_front_1000000);
834     CPPUNIT_TEST_SUITE_END();
835 
836 private:
837     void test_insert_at_end(const char* numElements)
838     {
839         char buff[100] = { 0 };
840         strcat(buff, "test_insert_at_end ");
841         strcat(buff, numElements);
842         int n = atoi(numElements);
843         PerformanceTracer tracer(buff);
844         BigPtrArray bparr;
845         for (int i = 0; i < n; i++)
846             bparr.Insert(new BigPtrEntryMock(i), bparr.Count());
847 
848         releaseBigPtrArrayContent(bparr);
849     }
850 
851     void test_insert_at_front(const char* numElements)
852     {
853         char buff[100] = { 0 };
854         strcat(buff, "test_insert_at_front ");
855         strcat(buff, numElements);
856         int n = atoi(numElements);
857         PerformanceTracer tracer(buff);
858         BigPtrArray bparr;
859         for (int i = 0; i < n; i++)
860             bparr.Insert(new BigPtrEntryMock(i), 0);
861 
862         releaseBigPtrArrayContent(bparr);
863     }
864 };
865 
866 
867 //#####################################
868 // register test suites
869 CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(BigPtrArrayUnittest, "BigPtrArrayUnittest");
870 CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(BigPtrArrayPerformanceTest, "BigPtrArrayPerformanceTest");
871 
872 NOADDITIONAL;
873 
874