1*6236dae4SAndroid Build Coastguard Worker /***************************************************************************
2*6236dae4SAndroid Build Coastguard Worker * _ _ ____ _
3*6236dae4SAndroid Build Coastguard Worker * Project ___| | | | _ \| |
4*6236dae4SAndroid Build Coastguard Worker * / __| | | | |_) | |
5*6236dae4SAndroid Build Coastguard Worker * | (__| |_| | _ <| |___
6*6236dae4SAndroid Build Coastguard Worker * \___|\___/|_| \_\_____|
7*6236dae4SAndroid Build Coastguard Worker *
8*6236dae4SAndroid Build Coastguard Worker * Copyright (C) Daniel Stenberg, <[email protected]>, et al.
9*6236dae4SAndroid Build Coastguard Worker *
10*6236dae4SAndroid Build Coastguard Worker * This software is licensed as described in the file COPYING, which
11*6236dae4SAndroid Build Coastguard Worker * you should have received as part of this distribution. The terms
12*6236dae4SAndroid Build Coastguard Worker * are also available at https://curl.se/docs/copyright.html.
13*6236dae4SAndroid Build Coastguard Worker *
14*6236dae4SAndroid Build Coastguard Worker * You may opt to use, copy, modify, merge, publish, distribute and/or sell
15*6236dae4SAndroid Build Coastguard Worker * copies of the Software, and permit persons to whom the Software is
16*6236dae4SAndroid Build Coastguard Worker * furnished to do so, under the terms of the COPYING file.
17*6236dae4SAndroid Build Coastguard Worker *
18*6236dae4SAndroid Build Coastguard Worker * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
19*6236dae4SAndroid Build Coastguard Worker * KIND, either express or implied.
20*6236dae4SAndroid Build Coastguard Worker *
21*6236dae4SAndroid Build Coastguard Worker * SPDX-License-Identifier: curl
22*6236dae4SAndroid Build Coastguard Worker *
23*6236dae4SAndroid Build Coastguard Worker ***************************************************************************/
24*6236dae4SAndroid Build Coastguard Worker #include "curlcheck.h"
25*6236dae4SAndroid Build Coastguard Worker
26*6236dae4SAndroid Build Coastguard Worker #include "urldata.h"
27*6236dae4SAndroid Build Coastguard Worker #include "bufq.h"
28*6236dae4SAndroid Build Coastguard Worker #include "curl_trc.h"
29*6236dae4SAndroid Build Coastguard Worker
unit_setup(void)30*6236dae4SAndroid Build Coastguard Worker static CURLcode unit_setup(void)
31*6236dae4SAndroid Build Coastguard Worker {
32*6236dae4SAndroid Build Coastguard Worker CURLcode res = CURLE_OK;
33*6236dae4SAndroid Build Coastguard Worker return res;
34*6236dae4SAndroid Build Coastguard Worker }
35*6236dae4SAndroid Build Coastguard Worker
unit_stop(void)36*6236dae4SAndroid Build Coastguard Worker static void unit_stop(void)
37*6236dae4SAndroid Build Coastguard Worker {
38*6236dae4SAndroid Build Coastguard Worker }
39*6236dae4SAndroid Build Coastguard Worker
tail_err(struct bufq * q)40*6236dae4SAndroid Build Coastguard Worker static const char *tail_err(struct bufq *q)
41*6236dae4SAndroid Build Coastguard Worker {
42*6236dae4SAndroid Build Coastguard Worker struct buf_chunk *chunk;
43*6236dae4SAndroid Build Coastguard Worker
44*6236dae4SAndroid Build Coastguard Worker if(!q->tail) {
45*6236dae4SAndroid Build Coastguard Worker return q->head ? "tail is NULL, but head is not" : NULL;
46*6236dae4SAndroid Build Coastguard Worker }
47*6236dae4SAndroid Build Coastguard Worker
48*6236dae4SAndroid Build Coastguard Worker chunk = q->head;
49*6236dae4SAndroid Build Coastguard Worker while(chunk) {
50*6236dae4SAndroid Build Coastguard Worker if(chunk == q->tail) {
51*6236dae4SAndroid Build Coastguard Worker if(chunk->next) {
52*6236dae4SAndroid Build Coastguard Worker return "tail points to queue, but not at the end";
53*6236dae4SAndroid Build Coastguard Worker }
54*6236dae4SAndroid Build Coastguard Worker return NULL;
55*6236dae4SAndroid Build Coastguard Worker }
56*6236dae4SAndroid Build Coastguard Worker chunk = chunk->next;
57*6236dae4SAndroid Build Coastguard Worker }
58*6236dae4SAndroid Build Coastguard Worker return "tail not part of queue";
59*6236dae4SAndroid Build Coastguard Worker }
60*6236dae4SAndroid Build Coastguard Worker
dump_bufq(struct bufq * q,const char * msg)61*6236dae4SAndroid Build Coastguard Worker static void dump_bufq(struct bufq *q, const char *msg)
62*6236dae4SAndroid Build Coastguard Worker {
63*6236dae4SAndroid Build Coastguard Worker struct buf_chunk *chunk;
64*6236dae4SAndroid Build Coastguard Worker const char *terr;
65*6236dae4SAndroid Build Coastguard Worker size_t n;
66*6236dae4SAndroid Build Coastguard Worker
67*6236dae4SAndroid Build Coastguard Worker fprintf(stderr, "bufq[chunk_size=%zu, max_chunks=%zu] %s\n",
68*6236dae4SAndroid Build Coastguard Worker q->chunk_size, q->max_chunks, msg);
69*6236dae4SAndroid Build Coastguard Worker fprintf(stderr, "- queue[\n");
70*6236dae4SAndroid Build Coastguard Worker chunk = q->head;
71*6236dae4SAndroid Build Coastguard Worker while(chunk) {
72*6236dae4SAndroid Build Coastguard Worker fprintf(stderr, " chunk[len=%zu, roff=%zu, woff=%zu]\n",
73*6236dae4SAndroid Build Coastguard Worker chunk->dlen, chunk->r_offset, chunk->w_offset);
74*6236dae4SAndroid Build Coastguard Worker chunk = chunk->next;
75*6236dae4SAndroid Build Coastguard Worker }
76*6236dae4SAndroid Build Coastguard Worker fprintf(stderr, " ]\n");
77*6236dae4SAndroid Build Coastguard Worker terr = tail_err(q);
78*6236dae4SAndroid Build Coastguard Worker fprintf(stderr, "- tail: %s\n", terr ? terr : "ok");
79*6236dae4SAndroid Build Coastguard Worker n = 0;
80*6236dae4SAndroid Build Coastguard Worker chunk = q->spare;
81*6236dae4SAndroid Build Coastguard Worker while(chunk) {
82*6236dae4SAndroid Build Coastguard Worker ++n;
83*6236dae4SAndroid Build Coastguard Worker chunk = chunk->next;
84*6236dae4SAndroid Build Coastguard Worker }
85*6236dae4SAndroid Build Coastguard Worker fprintf(stderr, "- chunks: %zu\n", q->chunk_count);
86*6236dae4SAndroid Build Coastguard Worker fprintf(stderr, "- spares: %zu\n", n);
87*6236dae4SAndroid Build Coastguard Worker }
88*6236dae4SAndroid Build Coastguard Worker
89*6236dae4SAndroid Build Coastguard Worker static unsigned char test_data[32*1024];
90*6236dae4SAndroid Build Coastguard Worker
check_bufq(size_t pool_spares,size_t chunk_size,size_t max_chunks,size_t wsize,size_t rsize,int opts)91*6236dae4SAndroid Build Coastguard Worker static void check_bufq(size_t pool_spares,
92*6236dae4SAndroid Build Coastguard Worker size_t chunk_size, size_t max_chunks,
93*6236dae4SAndroid Build Coastguard Worker size_t wsize, size_t rsize, int opts)
94*6236dae4SAndroid Build Coastguard Worker {
95*6236dae4SAndroid Build Coastguard Worker struct bufq q;
96*6236dae4SAndroid Build Coastguard Worker struct bufc_pool pool;
97*6236dae4SAndroid Build Coastguard Worker size_t max_len = chunk_size * max_chunks;
98*6236dae4SAndroid Build Coastguard Worker CURLcode result;
99*6236dae4SAndroid Build Coastguard Worker ssize_t n, i;
100*6236dae4SAndroid Build Coastguard Worker size_t nwritten, nread;
101*6236dae4SAndroid Build Coastguard Worker
102*6236dae4SAndroid Build Coastguard Worker if(pool_spares > 0) {
103*6236dae4SAndroid Build Coastguard Worker Curl_bufcp_init(&pool, chunk_size, pool_spares);
104*6236dae4SAndroid Build Coastguard Worker Curl_bufq_initp(&q, &pool, max_chunks, opts);
105*6236dae4SAndroid Build Coastguard Worker }
106*6236dae4SAndroid Build Coastguard Worker else {
107*6236dae4SAndroid Build Coastguard Worker Curl_bufq_init2(&q, chunk_size, max_chunks, opts);
108*6236dae4SAndroid Build Coastguard Worker }
109*6236dae4SAndroid Build Coastguard Worker
110*6236dae4SAndroid Build Coastguard Worker fail_unless(q.chunk_size == chunk_size, "chunk_size init wrong");
111*6236dae4SAndroid Build Coastguard Worker fail_unless(q.max_chunks == max_chunks, "max_chunks init wrong");
112*6236dae4SAndroid Build Coastguard Worker fail_unless(q.head == NULL, "init: head not NULL");
113*6236dae4SAndroid Build Coastguard Worker fail_unless(q.tail == NULL, "init: tail not NULL");
114*6236dae4SAndroid Build Coastguard Worker fail_unless(q.spare == NULL, "init: spare not NULL");
115*6236dae4SAndroid Build Coastguard Worker fail_unless(Curl_bufq_len(&q) == 0, "init: bufq length != 0");
116*6236dae4SAndroid Build Coastguard Worker
117*6236dae4SAndroid Build Coastguard Worker n = Curl_bufq_write(&q, test_data, wsize, &result);
118*6236dae4SAndroid Build Coastguard Worker fail_unless(n >= 0, "write: negative size returned");
119*6236dae4SAndroid Build Coastguard Worker fail_unless((size_t)n <= wsize, "write: wrong size returned");
120*6236dae4SAndroid Build Coastguard Worker fail_unless(result == CURLE_OK, "write: wrong result returned");
121*6236dae4SAndroid Build Coastguard Worker
122*6236dae4SAndroid Build Coastguard Worker /* write empty bufq full */
123*6236dae4SAndroid Build Coastguard Worker nwritten = 0;
124*6236dae4SAndroid Build Coastguard Worker Curl_bufq_reset(&q);
125*6236dae4SAndroid Build Coastguard Worker while(!Curl_bufq_is_full(&q)) {
126*6236dae4SAndroid Build Coastguard Worker n = Curl_bufq_write(&q, test_data, wsize, &result);
127*6236dae4SAndroid Build Coastguard Worker if(n >= 0) {
128*6236dae4SAndroid Build Coastguard Worker nwritten += (size_t)n;
129*6236dae4SAndroid Build Coastguard Worker }
130*6236dae4SAndroid Build Coastguard Worker else if(result != CURLE_AGAIN) {
131*6236dae4SAndroid Build Coastguard Worker fail_unless(result == CURLE_AGAIN, "write-loop: unexpected result");
132*6236dae4SAndroid Build Coastguard Worker break;
133*6236dae4SAndroid Build Coastguard Worker }
134*6236dae4SAndroid Build Coastguard Worker }
135*6236dae4SAndroid Build Coastguard Worker if(nwritten != max_len) {
136*6236dae4SAndroid Build Coastguard Worker fprintf(stderr, "%zu bytes written, but max_len=%zu\n",
137*6236dae4SAndroid Build Coastguard Worker nwritten, max_len);
138*6236dae4SAndroid Build Coastguard Worker dump_bufq(&q, "after writing full");
139*6236dae4SAndroid Build Coastguard Worker fail_if(TRUE, "write: bufq full but nwritten wrong");
140*6236dae4SAndroid Build Coastguard Worker }
141*6236dae4SAndroid Build Coastguard Worker
142*6236dae4SAndroid Build Coastguard Worker /* read full bufq empty */
143*6236dae4SAndroid Build Coastguard Worker nread = 0;
144*6236dae4SAndroid Build Coastguard Worker while(!Curl_bufq_is_empty(&q)) {
145*6236dae4SAndroid Build Coastguard Worker n = Curl_bufq_read(&q, test_data, rsize, &result);
146*6236dae4SAndroid Build Coastguard Worker if(n >= 0) {
147*6236dae4SAndroid Build Coastguard Worker nread += (size_t)n;
148*6236dae4SAndroid Build Coastguard Worker }
149*6236dae4SAndroid Build Coastguard Worker else if(result != CURLE_AGAIN) {
150*6236dae4SAndroid Build Coastguard Worker fail_unless(result == CURLE_AGAIN, "read-loop: unexpected result");
151*6236dae4SAndroid Build Coastguard Worker break;
152*6236dae4SAndroid Build Coastguard Worker }
153*6236dae4SAndroid Build Coastguard Worker }
154*6236dae4SAndroid Build Coastguard Worker if(nread != max_len) {
155*6236dae4SAndroid Build Coastguard Worker fprintf(stderr, "%zu bytes read, but max_len=%zu\n",
156*6236dae4SAndroid Build Coastguard Worker nwritten, max_len);
157*6236dae4SAndroid Build Coastguard Worker dump_bufq(&q, "after reading empty");
158*6236dae4SAndroid Build Coastguard Worker fail_if(TRUE, "read: bufq empty but nread wrong");
159*6236dae4SAndroid Build Coastguard Worker }
160*6236dae4SAndroid Build Coastguard Worker if(q.tail) {
161*6236dae4SAndroid Build Coastguard Worker dump_bufq(&q, "after reading empty");
162*6236dae4SAndroid Build Coastguard Worker fail_if(TRUE, "read empty, but tail is not NULL");
163*6236dae4SAndroid Build Coastguard Worker }
164*6236dae4SAndroid Build Coastguard Worker
165*6236dae4SAndroid Build Coastguard Worker for(i = 0; i < 1000; ++i) {
166*6236dae4SAndroid Build Coastguard Worker n = Curl_bufq_write(&q, test_data, wsize, &result);
167*6236dae4SAndroid Build Coastguard Worker if(n < 0 && result != CURLE_AGAIN) {
168*6236dae4SAndroid Build Coastguard Worker fail_unless(result == CURLE_AGAIN, "rw-loop: unexpected write result");
169*6236dae4SAndroid Build Coastguard Worker break;
170*6236dae4SAndroid Build Coastguard Worker }
171*6236dae4SAndroid Build Coastguard Worker n = Curl_bufq_read(&q, test_data, rsize, &result);
172*6236dae4SAndroid Build Coastguard Worker if(n < 0 && result != CURLE_AGAIN) {
173*6236dae4SAndroid Build Coastguard Worker fail_unless(result == CURLE_AGAIN, "rw-loop: unexpected read result");
174*6236dae4SAndroid Build Coastguard Worker break;
175*6236dae4SAndroid Build Coastguard Worker }
176*6236dae4SAndroid Build Coastguard Worker }
177*6236dae4SAndroid Build Coastguard Worker
178*6236dae4SAndroid Build Coastguard Worker /* Test SOFT_LIMIT option */
179*6236dae4SAndroid Build Coastguard Worker Curl_bufq_free(&q);
180*6236dae4SAndroid Build Coastguard Worker Curl_bufq_init2(&q, chunk_size, max_chunks, (opts|BUFQ_OPT_SOFT_LIMIT));
181*6236dae4SAndroid Build Coastguard Worker nwritten = 0;
182*6236dae4SAndroid Build Coastguard Worker while(!Curl_bufq_is_full(&q)) {
183*6236dae4SAndroid Build Coastguard Worker n = Curl_bufq_write(&q, test_data, wsize, &result);
184*6236dae4SAndroid Build Coastguard Worker if(n < 0 || (size_t)n != wsize) {
185*6236dae4SAndroid Build Coastguard Worker fail_unless(n > 0 && (size_t)n == wsize, "write should be complete");
186*6236dae4SAndroid Build Coastguard Worker break;
187*6236dae4SAndroid Build Coastguard Worker }
188*6236dae4SAndroid Build Coastguard Worker nwritten += (size_t)n;
189*6236dae4SAndroid Build Coastguard Worker }
190*6236dae4SAndroid Build Coastguard Worker if(nwritten < max_len) {
191*6236dae4SAndroid Build Coastguard Worker fprintf(stderr, "%zu bytes written, but max_len=%zu\n",
192*6236dae4SAndroid Build Coastguard Worker nwritten, max_len);
193*6236dae4SAndroid Build Coastguard Worker dump_bufq(&q, "after writing full");
194*6236dae4SAndroid Build Coastguard Worker fail_if(TRUE, "write: bufq full but nwritten wrong");
195*6236dae4SAndroid Build Coastguard Worker }
196*6236dae4SAndroid Build Coastguard Worker /* do one more write on a full bufq, should work */
197*6236dae4SAndroid Build Coastguard Worker n = Curl_bufq_write(&q, test_data, wsize, &result);
198*6236dae4SAndroid Build Coastguard Worker fail_unless(n > 0 && (size_t)n == wsize, "write should be complete");
199*6236dae4SAndroid Build Coastguard Worker nwritten += (size_t)n;
200*6236dae4SAndroid Build Coastguard Worker /* see that we get all out again */
201*6236dae4SAndroid Build Coastguard Worker nread = 0;
202*6236dae4SAndroid Build Coastguard Worker while(!Curl_bufq_is_empty(&q)) {
203*6236dae4SAndroid Build Coastguard Worker n = Curl_bufq_read(&q, test_data, rsize, &result);
204*6236dae4SAndroid Build Coastguard Worker if(n <= 0) {
205*6236dae4SAndroid Build Coastguard Worker fail_unless(n > 0, "read-loop: unexpected fail");
206*6236dae4SAndroid Build Coastguard Worker break;
207*6236dae4SAndroid Build Coastguard Worker }
208*6236dae4SAndroid Build Coastguard Worker nread += (size_t)n;
209*6236dae4SAndroid Build Coastguard Worker }
210*6236dae4SAndroid Build Coastguard Worker fail_unless(nread == nwritten, "did not get the same out as put in");
211*6236dae4SAndroid Build Coastguard Worker
212*6236dae4SAndroid Build Coastguard Worker /* CHECK bufq_unwrite: write a string repeatedly into the second chunk.
213*6236dae4SAndroid Build Coastguard Worker * bufq_unwrite() 1 byte. Read strings again and check for content.
214*6236dae4SAndroid Build Coastguard Worker * We had a bug that unwrite used the head chunk instead of tail, which
215*6236dae4SAndroid Build Coastguard Worker * did corrupt the read values. */
216*6236dae4SAndroid Build Coastguard Worker if(TRUE) {
217*6236dae4SAndroid Build Coastguard Worker const unsigned char buf[] = "0123456789--";
218*6236dae4SAndroid Build Coastguard Worker size_t roffset;
219*6236dae4SAndroid Build Coastguard Worker Curl_bufq_reset(&q);
220*6236dae4SAndroid Build Coastguard Worker while(Curl_bufq_len(&q) < chunk_size) {
221*6236dae4SAndroid Build Coastguard Worker n = Curl_bufq_write(&q, buf, sizeof(buf), &result);
222*6236dae4SAndroid Build Coastguard Worker fail_unless(n > 0 && (size_t)n == sizeof(buf), "write incomplete");
223*6236dae4SAndroid Build Coastguard Worker if(result)
224*6236dae4SAndroid Build Coastguard Worker break;
225*6236dae4SAndroid Build Coastguard Worker }
226*6236dae4SAndroid Build Coastguard Worker result = Curl_bufq_unwrite(&q, 1);
227*6236dae4SAndroid Build Coastguard Worker roffset = 0;
228*6236dae4SAndroid Build Coastguard Worker while(!Curl_bufq_is_empty(&q)) {
229*6236dae4SAndroid Build Coastguard Worker unsigned char rbuf[sizeof(buf)];
230*6236dae4SAndroid Build Coastguard Worker n = Curl_bufq_read(&q, rbuf, sizeof(rbuf), &result);
231*6236dae4SAndroid Build Coastguard Worker fail_unless(n > 0, "read should work");
232*6236dae4SAndroid Build Coastguard Worker if(result)
233*6236dae4SAndroid Build Coastguard Worker break;
234*6236dae4SAndroid Build Coastguard Worker if(n != sizeof(rbuf)) {
235*6236dae4SAndroid Build Coastguard Worker fail_unless(Curl_bufq_is_empty(&q), "should be last read");
236*6236dae4SAndroid Build Coastguard Worker }
237*6236dae4SAndroid Build Coastguard Worker if(memcmp(buf, rbuf, n)) {
238*6236dae4SAndroid Build Coastguard Worker fprintf(stderr, "at offset %zu expected '%.*s', got '%.*s'\n",
239*6236dae4SAndroid Build Coastguard Worker roffset, (int)n, buf, (int)n, rbuf);
240*6236dae4SAndroid Build Coastguard Worker fail("read buf content wrong");
241*6236dae4SAndroid Build Coastguard Worker }
242*6236dae4SAndroid Build Coastguard Worker roffset += n;
243*6236dae4SAndroid Build Coastguard Worker }
244*6236dae4SAndroid Build Coastguard Worker Curl_bufq_reset(&q);
245*6236dae4SAndroid Build Coastguard Worker }
246*6236dae4SAndroid Build Coastguard Worker
247*6236dae4SAndroid Build Coastguard Worker dump_bufq(&q, "at end of test");
248*6236dae4SAndroid Build Coastguard Worker Curl_bufq_free(&q);
249*6236dae4SAndroid Build Coastguard Worker if(pool_spares > 0)
250*6236dae4SAndroid Build Coastguard Worker Curl_bufcp_free(&pool);
251*6236dae4SAndroid Build Coastguard Worker }
252*6236dae4SAndroid Build Coastguard Worker
253*6236dae4SAndroid Build Coastguard Worker UNITTEST_START
254*6236dae4SAndroid Build Coastguard Worker struct bufq q;
255*6236dae4SAndroid Build Coastguard Worker ssize_t n;
256*6236dae4SAndroid Build Coastguard Worker CURLcode result;
257*6236dae4SAndroid Build Coastguard Worker unsigned char buf[16*1024];
258*6236dae4SAndroid Build Coastguard Worker
259*6236dae4SAndroid Build Coastguard Worker Curl_bufq_init(&q, 8*1024, 12);
260*6236dae4SAndroid Build Coastguard Worker n = Curl_bufq_read(&q, buf, 128, &result);
261*6236dae4SAndroid Build Coastguard Worker fail_unless(n < 0 && result == CURLE_AGAIN, "read empty fail");
262*6236dae4SAndroid Build Coastguard Worker Curl_bufq_free(&q);
263*6236dae4SAndroid Build Coastguard Worker
264*6236dae4SAndroid Build Coastguard Worker check_bufq(0, 1024, 4, 128, 128, BUFQ_OPT_NONE);
265*6236dae4SAndroid Build Coastguard Worker check_bufq(0, 1024, 4, 129, 127, BUFQ_OPT_NONE);
266*6236dae4SAndroid Build Coastguard Worker check_bufq(0, 1024, 4, 2000, 16000, BUFQ_OPT_NONE);
267*6236dae4SAndroid Build Coastguard Worker check_bufq(0, 1024, 4, 16000, 3000, BUFQ_OPT_NONE);
268*6236dae4SAndroid Build Coastguard Worker
269*6236dae4SAndroid Build Coastguard Worker check_bufq(0, 8000, 10, 1234, 1234, BUFQ_OPT_NONE);
270*6236dae4SAndroid Build Coastguard Worker check_bufq(0, 8000, 10, 8*1024, 4*1024, BUFQ_OPT_NONE);
271*6236dae4SAndroid Build Coastguard Worker
272*6236dae4SAndroid Build Coastguard Worker check_bufq(0, 1024, 4, 128, 128, BUFQ_OPT_NO_SPARES);
273*6236dae4SAndroid Build Coastguard Worker check_bufq(0, 1024, 4, 129, 127, BUFQ_OPT_NO_SPARES);
274*6236dae4SAndroid Build Coastguard Worker check_bufq(0, 1024, 4, 2000, 16000, BUFQ_OPT_NO_SPARES);
275*6236dae4SAndroid Build Coastguard Worker check_bufq(0, 1024, 4, 16000, 3000, BUFQ_OPT_NO_SPARES);
276*6236dae4SAndroid Build Coastguard Worker
277*6236dae4SAndroid Build Coastguard Worker check_bufq(8, 1024, 4, 128, 128, BUFQ_OPT_NONE);
278*6236dae4SAndroid Build Coastguard Worker check_bufq(8, 8000, 10, 1234, 1234, BUFQ_OPT_NONE);
279*6236dae4SAndroid Build Coastguard Worker check_bufq(8, 1024, 4, 129, 127, BUFQ_OPT_NO_SPARES);
280*6236dae4SAndroid Build Coastguard Worker
281*6236dae4SAndroid Build Coastguard Worker UNITTEST_STOP
282