| 
     
      
      
      From: Marcus M. <mar...@us...> - 2017-07-26 15:30:23
      
     
   | 
Update of /cvsroot/libexif/libexif/test In directory sfp-cvs-1.v30.ch3.sourceforge.com:/tmp/cvs-serv29106/test Modified Files: test-fuzzer.c Log Message: also switch byte order, and also test saving Index: test-fuzzer.c =================================================================== RCS file: /cvsroot/libexif/libexif/test/test-fuzzer.c,v retrieving revision 1.2 retrieving revision 1.3 diff -u -d -r1.2 -r1.3 --- test-fuzzer.c 25 Jul 2017 22:04:17 -0000 1.2 +++ test-fuzzer.c 26 Jul 2017 15:30:19 -0000 1.3 @@ -34,17 +34,18 @@ void content_foreach_func(ExifEntry *entry, void *callback_data); void content_foreach_func(ExifEntry *entry, void *UNUSED(callback_data)) { - char buf[2000]; - exif_entry_get_value(entry, buf, sizeof(buf)); - printf(" Entry %p: %s (%s)\n" - " Size, Comps: %d, %d\n" - " Value: %s\n", - entry, - exif_tag_get_name(entry->tag), - exif_format_get_name(entry->format), - entry->size, - (int)(entry->components), - exif_entry_get_value(entry, buf, sizeof(buf))); + char buf[2000]; + + exif_entry_get_value(entry, buf, sizeof(buf)); + printf(" Entry %p: %s (%s)\n" + " Size, Comps: %d, %d\n" + " Value: %s\n", + entry, + exif_tag_get_name(entry->tag), + exif_format_get_name(entry->format), + entry->size, + (int)(entry->components), + exif_entry_get_value(entry, buf, sizeof(buf))); } @@ -52,8 +53,8 @@ void data_foreach_func(ExifContent *content, void *callback_data); void data_foreach_func(ExifContent *content, void *callback_data) { - printf(" Content %p: ifd=%d\n", content, exif_content_get_ifd(content)); - exif_content_foreach_entry(content, content_foreach_func, callback_data); + printf(" Content %p: ifd=%d\n", content, exif_content_get_ifd(content)); + exif_content_foreach_entry(content, content_foreach_func, callback_data); } static int test_exif_data (ExifData *d) @@ -84,8 +85,7 @@ fprintf (stdout, " Description: '%s'\n", exif_mnote_data_get_description (md, i)); p = exif_mnote_data_get_value (md, i, v, sizeof (v)); - if (!p) break; - fprintf (stdout, " Value: '%s'\n", v); + if (p) fprintf (stdout, " Value: '%s'\n", v); } return 0; @@ -97,10 +97,24 @@ static void test_parse(const char *filename, void *callback_data) { ExifData *d; + unsigned int buf_size; + unsigned char *buf; d = exif_data_new_from_file(filename); exif_data_foreach_content(d, data_foreach_func, callback_data); test_exif_data (d); + + buf = NULL; + exif_data_save_data (d, &buf, &buf_size); + free (buf); + + exif_data_set_byte_order(d, EXIF_BYTE_ORDER_INTEL); + + buf = NULL; + exif_data_save_data (d, &buf, &buf_size); + free (buf); + + exif_data_unref(d); }  |