hxdeque_test.cpp
上传用户:dangjiwu
上传日期:2013-07-19
资源大小:42019k
文件大小:5k
源码类别:

Symbian

开发平台:

Visual C++

  1. /* ***** BEGIN LICENSE BLOCK *****
  2.  * Source last modified: $Id: hxdeque_test.cpp,v 1.2.42.3 2004/07/09 01:45:54 hubbe Exp $
  3.  * 
  4.  * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
  5.  * 
  6.  * The contents of this file, and the files included with this file,
  7.  * are subject to the current version of the RealNetworks Public
  8.  * Source License (the "RPSL") available at
  9.  * http://www.helixcommunity.org/content/rpsl unless you have licensed
  10.  * the file under the current version of the RealNetworks Community
  11.  * Source License (the "RCSL") available at
  12.  * http://www.helixcommunity.org/content/rcsl, in which case the RCSL
  13.  * will apply. You may also obtain the license terms directly from
  14.  * RealNetworks.  You may not use this file except in compliance with
  15.  * the RPSL or, if you have a valid RCSL with RealNetworks applicable
  16.  * to this file, the RCSL.  Please see the applicable RPSL or RCSL for
  17.  * the rights, obligations and limitations governing use of the
  18.  * contents of the file.
  19.  * 
  20.  * Alternatively, the contents of this file may be used under the
  21.  * terms of the GNU General Public License Version 2 or later (the
  22.  * "GPL") in which case the provisions of the GPL are applicable
  23.  * instead of those above. If you wish to allow use of your version of
  24.  * this file only under the terms of the GPL, and not to allow others
  25.  * to use your version of this file under the terms of either the RPSL
  26.  * or RCSL, indicate your decision by deleting the provisions above
  27.  * and replace them with the notice and other provisions required by
  28.  * the GPL. If you do not delete the provisions above, a recipient may
  29.  * use your version of this file under the terms of any one of the
  30.  * RPSL, the RCSL or the GPL.
  31.  * 
  32.  * This file is part of the Helix DNA Technology. RealNetworks is the
  33.  * developer of the Original Code and owns the copyrights in the
  34.  * portions it created.
  35.  * 
  36.  * This file, and the files included with this file, is distributed
  37.  * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY
  38.  * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS
  39.  * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES
  40.  * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET
  41.  * ENJOYMENT OR NON-INFRINGEMENT.
  42.  * 
  43.  * Technology Compatibility Kit Test Suite(s) Location:
  44.  *    http://www.helixcommunity.org/content/tck
  45.  * 
  46.  * Contributor(s):
  47.  * 
  48.  * ***** END LICENSE BLOCK ***** */
  49. #include <stdio.h>
  50. #include "machdep.h"
  51. #include "types.h"
  52. #include "hxtypes.h"
  53. #include "hxdeque.h"
  54. void fail_tests();
  55. int main()
  56. {
  57. // fail_tests();
  58. HX_deque test_deque;
  59. char* temp_str;
  60. u_long32 i;
  61. HX_deque::Iterator j;
  62. ASSERT(test_deque.empty());
  63. for (j = test_deque.begin(); j != test_deque.end(); ++j)
  64. {
  65.     ASSERT(0);
  66. }
  67. for (i = 0; i < 200; i++)
  68. {
  69. temp_str = new char[256];
  70. sprintf(temp_str, "hello %ld", i); /* Flawfinder: ignore */ //changed from %d to %ld for win16 
  71. test_deque.push_back(temp_str);
  72. }
  73. ASSERT(test_deque.size() == 200);
  74. i = 0;
  75. for (j = test_deque.begin(); j != test_deque.end(); ++j)
  76. {
  77. temp_str = (char*) (*j);
  78. printf("output %d: %sn", i, temp_str);
  79. ++i;
  80. }
  81. for (i = 0; i < 200; i++)
  82. {
  83.      temp_str = (char*) test_deque[i];
  84.      printf("array output %d: %sn", i, temp_str);
  85. }
  86. for (i = 0; i < 50; ++i)
  87. {
  88. temp_str = (char*) test_deque.pop_front();
  89. printf("pop_front %d: %sn", i, temp_str);
  90. delete[] temp_str;
  91. }
  92. ASSERT(test_deque.size() == 150);
  93. for (i = 0; i < 150; ++i)
  94. {
  95. temp_str = (char*) test_deque.pop_back();
  96. printf("pop_back %d: %sn", i, temp_str);
  97. delete[] temp_str;
  98. }
  99. ASSERT(test_deque.size() == 0);
  100. ASSERT(test_deque.empty());
  101. for (j = test_deque.begin(); j != test_deque.end(); ++j)
  102. {
  103.     ASSERT(0);
  104. }
  105. for (i = 0; i < 25; ++i)
  106. {
  107. temp_str = new char[256];
  108. sprintf(temp_str, "hello2 %ld", i);/* Flawfinder: ignore */ //%d to %ld
  109. test_deque.push_front(temp_str);
  110. }
  111. for (i = 25; i < 1000000; ++i)
  112. {
  113. temp_str = new char[256];
  114. sprintf(temp_str, "hello3 %ld", i);/* Flawfinder: ignore */ // %d to %ld
  115. test_deque.push_front(temp_str);
  116. temp_str = (char*) test_deque.pop_back();
  117. printf("resend behaviour %d: %sn", i, temp_str);
  118. delete[] temp_str;
  119. }
  120. ASSERT(test_deque.size() == 25);
  121. //Need some tests for boundary conditions
  122. }
  123. //Each one of these tests should fail with an assertion when compiled with 
  124. //-DDEBUG
  125. //Without -DDEBUG they should not die, but return undefined things.
  126. void fail_tests()
  127. {
  128.     HX_deque test_deque;
  129.     char* temp_str;
  130.     int i;
  131.     ASSERT(test_deque.empty());
  132.     temp_str = (char*) test_deque.pop_front();
  133.     printf("pop front returned %sn", temp_str);
  134.     temp_str = (char*) test_deque.pop_back();
  135.     printf("pop back returned %sn", temp_str);
  136.     temp_str = (char*) test_deque[50];
  137.     printf("operator[50] returned %sn", temp_str);
  138.     for (i = 0; i < 25; ++i)
  139.     {
  140. temp_str = new char[256];
  141. sprintf(temp_str, "fail %ld", i); /* Flawfinder: ignore */ //%d to %ld
  142. test_deque.push_back(temp_str);
  143.     }
  144.     for (i = 0; i < 25; ++i)
  145.     {
  146. test_deque.pop_front();
  147.     }
  148.     ASSERT(test_deque.empty());
  149.     temp_str = (char*) test_deque.pop_front();
  150.     printf("pop front returned %sn", temp_str);
  151.     temp_str = (char*) test_deque.pop_back();
  152.     printf("pop back returned %sn", temp_str);
  153.     temp_str = (char*) test_deque[50];
  154.     printf("operator[50] returned %sn", temp_str);
  155. }