Fix memory leak in test_casereader_clone().
authorBen Pfaff <blp@gnu.org>
Sat, 14 Oct 2006 23:23:17 +0000 (23:23 +0000)
committerBen Pfaff <blp@gnu.org>
Sat, 14 Oct 2006 23:23:17 +0000 (23:23 +0000)
src/language/tests/ChangeLog
src/language/tests/casefile-test.c

index 80c27c0d983d9925c82b2e8028fcf435ac635e76..605b8cc5edf0e1588b2efa488682fa9b4342e94a 100644 (file)
@@ -1,3 +1,8 @@
+Sat Oct 14 16:21:45 2006  Ben Pfaff  <blp@gnu.org>
+
+       * casefile-test.c: (test_casereader_clone) Free cases that we
+       read, to avoid memory leak.
+
 Tue Jun  6 18:48:00 2006  Ben Pfaff  <blp@gnu.org>
 
        * casefile-test.c: (test_casefile) Test the new casereader_seek()
index a1927ddb98dc3009820ed3b5200ca7a416997c44..30ffdd2b0f17e4760f3eb270501ac871772e66a4 100644 (file)
@@ -232,14 +232,17 @@ test_casereader_clone (struct casereader *reader1, size_t case_cnt)
 
   /* Read a 3rd of the cases */
   for ( i = 0 ; i < case_cnt / 3 ; ++i ) 
-    casereader_read (reader1, &c1);
+    {
+      casereader_read (reader1, &c1);
+      case_destroy (&c1);
+    }
 
   clone = casereader_clone (reader1);
 
   /* Copy all the cases into a new file */
   while( casereader_read (reader1, &c1))
     { 
-      casefile_append (newfile, &c1);
+      casefile_append_xfer (newfile, &c1);
       cases ++;
     }
 
@@ -254,13 +257,19 @@ test_casereader_clone (struct casereader *reader1, size_t case_cnt)
       cases --;
 
       if ( ! casereader_read_xfer (newreader, &c2) ) 
-       break;
+        {
+          case_destroy (&c1);
+          break; 
+        }
       
       v1 = case_data_all (&c1) ;
       v2 = case_data_all (&c2) ;
 
       if ( 0 != memcmp (v1, v2, value_cnt * MAX_SHORT_STRING))
        fail_test ("Cloned reader read different value at case %ld", cases);
+
+      case_destroy (&c1);
+      case_destroy (&c2);
     }
 
   if ( cases > 0 )