3 /* dynar_double: A test case for the dynar using doubles as content */
5 /* Copyright (c) 2003,2004 Martin Quinson. All rights reserved. */
7 /* This program is free software; you can redistribute it and/or modify it
8 * under the terms of the license (GNU LGPL) which comes with this package. */
12 XBT_LOG_NEW_DEFAULT_CATEGORY(test,"Logging specific to this test");
14 int main(int argc,char *argv[]) {
21 INFO0("==== Traverse the empty dynar");
22 d=xbt_dynar_new(sizeof(int),NULL);
23 xbt_dynar_foreach(d,cursor,cpt){
25 "Damnit, there is something in the empty dynar");
30 INFO0("==== Push/shift 5000 doubles");
31 d=xbt_dynar_new(sizeof(double),NULL);
32 for (cpt=0; cpt< 5000; cpt++) {
34 xbt_dynar_push(d,&d1);
36 xbt_dynar_foreach(d,cursor,d2){
39 "The retrieved value is not the same than the injected one (%f!=%f)",
42 for (cpt=0; cpt< 5000; cpt++) {
44 xbt_dynar_shift(d,&d2);
46 "The retrieved value is not the same than the injected one (%f!=%f)",
53 INFO0("==== Unshift/pop 5000 doubles");
54 d=xbt_dynar_new(sizeof(double),NULL);
55 for (cpt=0; cpt< 5000; cpt++) {
57 xbt_dynar_unshift(d,&d1);
59 for (cpt=0; cpt< 5000; cpt++) {
62 xbt_assert2 (d1 == d2,
63 "The retrieved value is not the same than the injected one (%f!=%f)",
71 INFO0("==== Push 5000 doubles, insert 1000 doubles in the middle, shift everything");
72 d=xbt_dynar_new(sizeof(double),NULL);
73 for (cpt=0; cpt< 5000; cpt++) {
75 xbt_dynar_push(d,&d1);
77 for (cpt=0; cpt< 1000; cpt++) {
79 xbt_dynar_insert_at(d,2500,&d1);
82 for (cpt=0; cpt< 2500; cpt++) {
84 xbt_dynar_shift(d,&d2);
86 "The retrieved value is not the same than the injected one at the begining (%f!=%f)",
88 DEBUG2("Pop %d, length=%lu",cpt, xbt_dynar_length(d));
90 for (cpt=999; cpt>=0; cpt--) {
92 xbt_dynar_shift(d,&d2);
93 xbt_assert2 (d1 == d2,
94 "The retrieved value is not the same than the injected one in the middle (%f!=%f)",
97 for (cpt=2500; cpt< 5000; cpt++) {
99 xbt_dynar_shift(d,&d2);
100 xbt_assert2 (d1 == d2,
101 "The retrieved value is not the same than the injected one at the end (%f!=%f)",
108 INFO0("==== Push 5000 double, remove 2000-4000. free the rest");
109 d=xbt_dynar_new(sizeof(double),NULL);
110 for (cpt=0; cpt< 5000; cpt++) {
112 xbt_dynar_push(d,&d1);
114 for (cpt=2000; cpt< 4000; cpt++) {
116 xbt_dynar_remove_at(d,2000,&d2);
117 xbt_assert2 (d1 == d2,
118 "Remove a bad value. Got %f, expected %f",