]> CyberLeo.Net >> Repos - FreeBSD/releng/8.1.git/blob - lib/libarchive/test/test_read_data_large.c
Copy stable/8 to releng/8.1 in preparation for 8.1-RC1.
[FreeBSD/releng/8.1.git] / lib / libarchive / test / test_read_data_large.c
1 /*-
2  * Copyright (c) 2003-2007 Tim Kientzle
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in the
12  *    documentation and/or other materials provided with the distribution.
13  *
14  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS OR
15  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
16  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
17  * IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT, INDIRECT,
18  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
19  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
20  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
21  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
23  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  */
25 #include "test.h"
26 __FBSDID("$FreeBSD$");
27
28 /*
29  * Test read/write of a 10M block of data in a single operation.
30  * Uses an in-memory archive with a single 10M entry.  Exercises
31  * archive_read_data() to ensure it can handle large blocks like
32  * this and also exercises archive_read_data_into_fd() (which
33  * had a bug relating to this, fixed in Nov 2006).
34  */
35
36 char buff1[11000000];
37 char buff2[10000000];
38 char buff3[10000000];
39
40 DEFINE_TEST(test_read_data_large)
41 {
42         struct archive_entry *ae;
43         struct archive *a;
44         char tmpfilename[] = "largefile";
45         int tmpfilefd;
46         unsigned int i;
47         size_t used;
48
49         /* Create a new archive in memory. */
50         assert((a = archive_write_new()) != NULL);
51         assertA(0 == archive_write_set_format_ustar(a));
52         assertA(0 == archive_write_set_compression_none(a));
53         assertA(0 == archive_write_open_memory(a, buff1, sizeof(buff1), &used));
54
55         /*
56          * Write a file (with random contents) to it.
57          */
58         assert((ae = archive_entry_new()) != NULL);
59         archive_entry_copy_pathname(ae, "file");
60         archive_entry_set_mode(ae, S_IFREG | 0755);
61         for (i = 0; i < sizeof(buff2); i++)
62                 buff2[i] = (unsigned char)rand();
63         archive_entry_set_size(ae, sizeof(buff2));
64         assertA(0 == archive_write_header(a, ae));
65         archive_entry_free(ae);
66         assertA(sizeof(buff2) == archive_write_data(a, buff2, sizeof(buff2)));
67
68         /* Close out the archive. */
69         assertA(0 == archive_write_close(a));
70 #if ARCHIVE_VERSION_NUMBER < 2000000
71         archive_write_finish(a);
72 #else
73         assertA(0 == archive_write_finish(a));
74 #endif
75
76         /* Check that archive_read_data can handle 10*10^6 at a pop. */
77         assert((a = archive_read_new()) != NULL);
78         assertA(0 == archive_read_support_format_all(a));
79         assertA(0 == archive_read_support_compression_all(a));
80         assertA(0 == archive_read_open_memory(a, buff1, sizeof(buff1)));
81         assertA(0 == archive_read_next_header(a, &ae));
82         failure("Wrote 10MB, but didn't read the same amount");
83         assertEqualIntA(a, sizeof(buff2),archive_read_data(a, buff3, sizeof(buff3)));
84         failure("Read expected 10MB, but data read didn't match what was written");
85         assert(0 == memcmp(buff2, buff3, sizeof(buff3)));
86         assert(0 == archive_read_close(a));
87 #if ARCHIVE_VERSION_NUMBER < 2000000
88         archive_read_finish(a);
89 #else
90         assert(0 == archive_read_finish(a));
91 #endif
92
93         /* Check archive_read_data_into_fd */
94         assert((a = archive_read_new()) != NULL);
95         assertA(0 == archive_read_support_format_all(a));
96         assertA(0 == archive_read_support_compression_all(a));
97         assertA(0 == archive_read_open_memory(a, buff1, sizeof(buff1)));
98         assertA(0 == archive_read_next_header(a, &ae));
99         tmpfilefd = open(tmpfilename, O_WRONLY | O_CREAT, 0777);
100         assert(tmpfilefd != 0);
101         assertEqualIntA(a, 0, archive_read_data_into_fd(a, tmpfilefd));
102         assert(0 == archive_read_close(a));
103 #if ARCHIVE_VERSION_NUMBER < 2000000
104         archive_read_finish(a);
105 #else
106         assert(0 == archive_read_finish(a));
107 #endif
108         close(tmpfilefd);
109
110         tmpfilefd = open(tmpfilename, O_RDONLY);
111         assert(tmpfilefd != 0);
112         assertEqualIntA(NULL, sizeof(buff3), read(tmpfilefd, buff3, sizeof(buff3)));
113         close(tmpfilefd);
114         assert(0 == memcmp(buff2, buff3, sizeof(buff3)));
115
116         unlink(tmpfilename);
117 }