aboutsummaryrefslogtreecommitdiffhomepage
path: root/test/core
diff options
context:
space:
mode:
Diffstat (limited to 'test/core')
-rw-r--r--test/core/bad_client/bad_client.c11
-rw-r--r--test/core/channel/channel_stack_test.c9
-rw-r--r--test/core/client_config/lb_policies_test.c4
-rw-r--r--test/core/client_config/set_initial_connect_string_test.c221
-rw-r--r--test/core/compression/compression_test.c3
-rw-r--r--test/core/compression/message_compress_test.c8
-rw-r--r--test/core/end2end/fixtures/h2_sockpair+trace.c27
-rw-r--r--test/core/end2end/fixtures/h2_sockpair.c27
-rw-r--r--test/core/end2end/fixtures/h2_sockpair_1byte.c27
-rw-r--r--test/core/end2end/fixtures/h2_uchannel.c19
-rw-r--r--test/core/end2end/fixtures/proxy.c6
-rwxr-xr-xtest/core/end2end/gen_build_yaml.py14
-rw-r--r--test/core/end2end/tests/cancel_with_status.c3
-rw-r--r--test/core/end2end/tests/hpack_size.c446
-rw-r--r--test/core/end2end/tests/negative_deadline.c3
-rw-r--r--test/core/fling/client.c11
-rw-r--r--test/core/fling/server.c9
-rw-r--r--test/core/iomgr/fd_posix_test.c8
-rw-r--r--test/core/iomgr/tcp_posix_test.c72
-rw-r--r--test/core/network_benchmarks/low_level_ping_pong.c8
-rw-r--r--test/core/security/credentials_test.c85
-rw-r--r--test/core/security/oauth2_utils.c5
-rw-r--r--test/core/security/print_google_default_creds_token.c5
-rw-r--r--test/core/support/avl_test.c3671
-rw-r--r--test/core/surface/byte_buffer_reader_test.c4
-rw-r--r--test/core/transport/chttp2/hpack_encoder_test.c9
-rw-r--r--test/core/transport/chttp2/hpack_parser_test.c21
-rw-r--r--test/core/transport/chttp2/hpack_table_test.c50
-rw-r--r--test/core/transport/metadata_test.c105
-rw-r--r--test/core/util/reconnect_server.c49
-rw-r--r--test/core/util/reconnect_server.h6
-rw-r--r--test/core/util/test_tcp_server.c120
-rw-r--r--test/core/util/test_tcp_server.h55
33 files changed, 4836 insertions, 285 deletions
diff --git a/test/core/bad_client/bad_client.c b/test/core/bad_client/bad_client.c
index ed46e7b009..e1a4b8ed90 100644
--- a/test/core/bad_client/bad_client.c
+++ b/test/core/bad_client/bad_client.c
@@ -64,14 +64,13 @@ static void done_write(grpc_exec_ctx *exec_ctx, void *arg, int success) {
gpr_event_set(&a->done_write, (void *)1);
}
-static void server_setup_transport(void *ts, grpc_transport *transport,
- grpc_mdctx *mdctx) {
+static void server_setup_transport(void *ts, grpc_transport *transport) {
thd_args *a = ts;
static grpc_channel_filter const *extra_filters[] = {
&grpc_http_server_filter};
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
grpc_server_setup_transport(&exec_ctx, a->server, transport, extra_filters,
- GPR_ARRAY_SIZE(extra_filters), mdctx,
+ GPR_ARRAY_SIZE(extra_filters),
grpc_server_get_channel_args(a->server));
grpc_exec_ctx_finish(&exec_ctx);
}
@@ -84,7 +83,6 @@ void grpc_run_bad_client_test(grpc_bad_client_server_side_validator validator,
gpr_thd_id id;
char *hex;
grpc_transport *transport;
- grpc_mdctx *mdctx = grpc_mdctx_create();
gpr_slice slice =
gpr_slice_from_copied_buffer(client_payload, client_payload_length);
gpr_slice_buffer outgoing;
@@ -113,9 +111,8 @@ void grpc_run_bad_client_test(grpc_bad_client_server_side_validator validator,
a.validator = validator;
grpc_server_register_completion_queue(a.server, a.cq, NULL);
grpc_server_start(a.server);
- transport =
- grpc_create_chttp2_transport(&exec_ctx, NULL, sfd.server, mdctx, 0);
- server_setup_transport(&a, transport, mdctx);
+ transport = grpc_create_chttp2_transport(&exec_ctx, NULL, sfd.server, 0);
+ server_setup_transport(&a, transport);
grpc_chttp2_transport_start_reading(&exec_ctx, transport, NULL, 0);
grpc_exec_ctx_finish(&exec_ctx);
diff --git a/test/core/channel/channel_stack_test.c b/test/core/channel/channel_stack_test.c
index 5e1ba11857..9dbb879300 100644
--- a/test/core/channel/channel_stack_test.c
+++ b/test/core/channel/channel_stack_test.c
@@ -93,13 +93,10 @@ static void test_create_channel_stack(void) {
grpc_call_element *call_elem;
grpc_arg arg;
grpc_channel_args chan_args;
- grpc_mdctx *metadata_context;
int *channel_data;
int *call_data;
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
- metadata_context = grpc_mdctx_create();
-
arg.type = GRPC_ARG_INTEGER;
arg.key = "test_key";
arg.value.integer = 42;
@@ -109,7 +106,7 @@ static void test_create_channel_stack(void) {
channel_stack = gpr_malloc(grpc_channel_stack_size(&filters, 1));
grpc_channel_stack_init(&exec_ctx, &filters, 1, NULL, &chan_args,
- metadata_context, channel_stack);
+ channel_stack);
GPR_ASSERT(channel_stack->count == 1);
channel_elem = grpc_channel_stack_element(channel_stack, 0);
channel_data = (int *)channel_elem->channel_data;
@@ -133,13 +130,13 @@ static void test_create_channel_stack(void) {
grpc_channel_stack_destroy(&exec_ctx, channel_stack);
gpr_free(channel_stack);
- grpc_mdctx_unref(metadata_context);
-
grpc_exec_ctx_finish(&exec_ctx);
}
int main(int argc, char **argv) {
grpc_test_init(argc, argv);
+ grpc_init();
test_create_channel_stack();
+ grpc_shutdown();
return 0;
}
diff --git a/test/core/client_config/lb_policies_test.c b/test/core/client_config/lb_policies_test.c
index 0218b8f07f..5aa8140e08 100644
--- a/test/core/client_config/lb_policies_test.c
+++ b/test/core/client_config/lb_policies_test.c
@@ -269,8 +269,8 @@ int *perform_request(servers_fixture *f, grpc_channel *client,
memset(s_valid, 0, f->num_servers * sizeof(int));
c = grpc_channel_create_call(client, NULL, GRPC_PROPAGATE_DEFAULTS, f->cq,
- "/foo", "foo.test.google.fr", gpr_inf_future(GPR_CLOCK_REALTIME),
- NULL);
+ "/foo", "foo.test.google.fr",
+ gpr_inf_future(GPR_CLOCK_REALTIME), NULL);
GPR_ASSERT(c);
completed_client = 0;
diff --git a/test/core/client_config/set_initial_connect_string_test.c b/test/core/client_config/set_initial_connect_string_test.c
new file mode 100644
index 0000000000..ceca56c833
--- /dev/null
+++ b/test/core/client_config/set_initial_connect_string_test.c
@@ -0,0 +1,221 @@
+/*
+ *
+ * Copyright 2015, Google Inc.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ *
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following disclaimer
+ * in the documentation and/or other materials provided with the
+ * distribution.
+ * * Neither the name of Google Inc. nor the names of its
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+#include <string.h>
+
+#include <grpc/grpc.h>
+#include <grpc/support/alloc.h>
+#include <grpc/support/host_port.h>
+#include <grpc/support/log.h>
+#include <grpc/support/slice.h>
+
+#include "src/core/client_config/initial_connect_string.h"
+#include "src/core/iomgr/sockaddr.h"
+#include "src/core/security/credentials.h"
+#include "src/core/support/string.h"
+#include "test/core/util/port.h"
+#include "test/core/util/test_config.h"
+#include "test/core/util/test_tcp_server.h"
+
+struct rpc_state {
+ char *target;
+ grpc_channel_credentials *creds;
+ grpc_completion_queue *cq;
+ grpc_channel *channel;
+ grpc_call *call;
+ grpc_op op;
+ gpr_slice_buffer incoming_buffer;
+ gpr_slice_buffer temp_incoming_buffer;
+ grpc_endpoint *tcp;
+ int done;
+};
+
+static const char *magic_connect_string = "magic initial string";
+static int server_port;
+static struct rpc_state state;
+static grpc_closure on_read;
+
+static void handle_read(grpc_exec_ctx *exec_ctx, void *arg, int success) {
+ GPR_ASSERT(success);
+ gpr_slice_buffer_move_into(&state.temp_incoming_buffer,
+ &state.incoming_buffer);
+ if (state.incoming_buffer.length > strlen(magic_connect_string)) {
+ state.done = 1;
+ grpc_endpoint_shutdown(exec_ctx, state.tcp);
+ grpc_endpoint_destroy(exec_ctx, state.tcp);
+ } else {
+ grpc_endpoint_read(exec_ctx, state.tcp, &state.temp_incoming_buffer,
+ &on_read);
+ }
+}
+
+static void on_connect(grpc_exec_ctx *exec_ctx, void *arg, grpc_endpoint *tcp) {
+ test_tcp_server *server = arg;
+ grpc_closure_init(&on_read, handle_read, NULL);
+ gpr_slice_buffer_init(&state.incoming_buffer);
+ gpr_slice_buffer_init(&state.temp_incoming_buffer);
+ state.tcp = tcp;
+ grpc_endpoint_add_to_pollset(exec_ctx, tcp, &server->pollset);
+ grpc_endpoint_read(exec_ctx, tcp, &state.temp_incoming_buffer, &on_read);
+}
+
+static void set_magic_initial_string(struct sockaddr **addr, size_t *addr_len,
+ gpr_slice *connect_string) {
+ GPR_ASSERT(addr);
+ GPR_ASSERT(addr_len);
+ *connect_string = gpr_slice_from_copied_string(magic_connect_string);
+}
+
+static void reset_addr_and_set_magic_string(struct sockaddr **addr,
+ size_t *addr_len,
+ gpr_slice *connect_string) {
+ struct sockaddr_in target;
+ *connect_string = gpr_slice_from_copied_string(magic_connect_string);
+ gpr_free(*addr);
+ target.sin_family = AF_INET;
+ target.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
+ target.sin_port = htons((uint16_t)server_port);
+ *addr_len = sizeof(target);
+ *addr = (struct sockaddr *)gpr_malloc(sizeof(target));
+ memcpy(*addr, &target, sizeof(target));
+}
+
+static gpr_timespec n_sec_deadline(int seconds) {
+ return gpr_time_add(gpr_now(GPR_CLOCK_REALTIME),
+ gpr_time_from_seconds(seconds, GPR_TIMESPAN));
+}
+
+static void start_rpc(int use_creds, int target_port) {
+ state.done = 0;
+ state.cq = grpc_completion_queue_create(NULL);
+ if (use_creds) {
+ state.creds = grpc_fake_transport_security_credentials_create();
+ } else {
+ state.creds = NULL;
+ }
+ gpr_join_host_port(&state.target, "127.0.0.1", target_port);
+ if (use_creds) {
+ state.channel =
+ grpc_secure_channel_create(state.creds, state.target, NULL, NULL);
+ } else {
+ state.channel = grpc_insecure_channel_create(state.target, NULL, NULL);
+ }
+ state.call = grpc_channel_create_call(
+ state.channel, NULL, GRPC_PROPAGATE_DEFAULTS, state.cq, "/Service/Method",
+ "localhost", gpr_inf_future(GPR_CLOCK_REALTIME), NULL);
+ state.op.op = GRPC_OP_SEND_INITIAL_METADATA;
+ state.op.data.send_initial_metadata.count = 0;
+ state.op.flags = 0;
+ state.op.reserved = NULL;
+ GPR_ASSERT(GRPC_CALL_OK == grpc_call_start_batch(state.call, &state.op,
+ (size_t)(1), NULL, NULL));
+ grpc_completion_queue_next(state.cq, n_sec_deadline(1), NULL);
+}
+
+static void cleanup_rpc(void) {
+ grpc_event ev;
+ gpr_slice_buffer_destroy(&state.incoming_buffer);
+ gpr_slice_buffer_destroy(&state.temp_incoming_buffer);
+ grpc_channel_credentials_unref(state.creds);
+ grpc_call_destroy(state.call);
+ grpc_completion_queue_shutdown(state.cq);
+ do {
+ ev = grpc_completion_queue_next(state.cq, n_sec_deadline(1), NULL);
+ } while (ev.type != GRPC_QUEUE_SHUTDOWN);
+ grpc_completion_queue_destroy(state.cq);
+ grpc_channel_destroy(state.channel);
+ gpr_free(state.target);
+}
+
+static void poll_server_until_read_done(test_tcp_server *server) {
+ gpr_timespec deadline = n_sec_deadline(5);
+ while (state.done == 0 &&
+ gpr_time_cmp(gpr_now(GPR_CLOCK_REALTIME), deadline) < 0) {
+ test_tcp_server_poll(server, 1);
+ }
+}
+
+static void match_initial_magic_string(gpr_slice_buffer *buffer) {
+ size_t i, j, cmp_length;
+ size_t magic_length = strlen(magic_connect_string);
+ GPR_ASSERT(buffer->length >= magic_length);
+ for (i = 0, j = 0; i < state.incoming_buffer.count && j < magic_length; i++) {
+ char *dump =
+ gpr_dump_slice(state.incoming_buffer.slices[i], GPR_DUMP_ASCII);
+ cmp_length = GPR_MIN(strlen(dump), magic_length - j);
+ GPR_ASSERT(strncmp(dump, magic_connect_string + j, cmp_length) == 0);
+ j += cmp_length;
+ gpr_free(dump);
+ }
+}
+
+static void test_initial_string(test_tcp_server *server, int secure) {
+ grpc_test_set_initial_connect_string_function(set_magic_initial_string);
+ start_rpc(secure, server_port);
+ poll_server_until_read_done(server);
+ match_initial_magic_string(&state.incoming_buffer);
+ cleanup_rpc();
+}
+
+static void test_initial_string_with_redirect(test_tcp_server *server,
+ int secure) {
+ int another_port = grpc_pick_unused_port_or_die();
+ grpc_test_set_initial_connect_string_function(
+ reset_addr_and_set_magic_string);
+ start_rpc(secure, another_port);
+ poll_server_until_read_done(server);
+ match_initial_magic_string(&state.incoming_buffer);
+ cleanup_rpc();
+}
+
+static void run_test(void (*test)(test_tcp_server *server, int secure),
+ int secure) {
+ test_tcp_server test_server;
+ server_port = grpc_pick_unused_port_or_die();
+ test_tcp_server_init(&test_server, on_connect, &test_server);
+ test_tcp_server_start(&test_server, server_port);
+ test(&test_server, secure);
+ test_tcp_server_destroy(&test_server);
+}
+
+int main(int argc, char **argv) {
+ grpc_test_init(argc, argv);
+ grpc_init();
+
+ run_test(test_initial_string, 0);
+ run_test(test_initial_string, 1);
+ run_test(test_initial_string_with_redirect, 0);
+ run_test(test_initial_string_with_redirect, 1);
+
+ grpc_shutdown();
+ return 0;
+}
diff --git a/test/core/compression/compression_test.c b/test/core/compression/compression_test.c
index 633fbd97f4..35fadc00c0 100644
--- a/test/core/compression/compression_test.c
+++ b/test/core/compression/compression_test.c
@@ -35,6 +35,7 @@
#include <string.h>
#include <grpc/compression.h>
+#include <grpc/grpc.h>
#include <grpc/support/log.h>
#include <grpc/support/useful.h>
@@ -71,7 +72,9 @@ static void test_compression_algorithm_parse(void) {
}
int main(int argc, char **argv) {
+ grpc_init();
test_compression_algorithm_parse();
+ grpc_shutdown();
return 0;
}
diff --git a/test/core/compression/message_compress_test.c b/test/core/compression/message_compress_test.c
index 98da6a1eaa..4b45d22885 100644
--- a/test/core/compression/message_compress_test.c
+++ b/test/core/compression/message_compress_test.c
@@ -36,11 +36,13 @@
#include <stdlib.h>
#include <string.h>
-#include "test/core/util/test_config.h"
-#include "src/core/support/murmur_hash.h"
+#include <grpc/grpc.h>
#include <grpc/support/log.h>
#include <grpc/support/useful.h>
+
+#include "src/core/support/murmur_hash.h"
#include "test/core/util/slice_splitter.h"
+#include "test/core/util/test_config.h"
typedef enum { ONE_A = 0, ONE_KB_A, ONE_MB_A, TEST_VALUE_COUNT } test_value;
@@ -175,6 +177,7 @@ int main(int argc, char **argv) {
GRPC_SLICE_SPLIT_ONE_BYTE};
grpc_test_init(argc, argv);
+ grpc_init();
for (i = 0; i < GRPC_COMPRESS_ALGORITHMS_COUNT; i++) {
for (j = 0; j < GPR_ARRAY_SIZE(uncompressed_split_modes); j++) {
@@ -189,6 +192,7 @@ int main(int argc, char **argv) {
}
test_bad_data();
+ grpc_shutdown();
return 0;
}
diff --git a/test/core/end2end/fixtures/h2_sockpair+trace.c b/test/core/end2end/fixtures/h2_sockpair+trace.c
index 1f5051f0ab..ccc8631d94 100644
--- a/test/core/end2end/fixtures/h2_sockpair+trace.c
+++ b/test/core/end2end/fixtures/h2_sockpair+trace.c
@@ -57,14 +57,13 @@
/* chttp2 transport that is immediately available (used for testing
connected_channel without a client_channel */
-static void server_setup_transport(void *ts, grpc_transport *transport,
- grpc_mdctx *mdctx) {
+static void server_setup_transport(void *ts, grpc_transport *transport) {
grpc_end2end_test_fixture *f = ts;
static grpc_channel_filter const *extra_filters[] = {
&grpc_http_server_filter};
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
grpc_server_setup_transport(&exec_ctx, f->server, transport, extra_filters,
- GPR_ARRAY_SIZE(extra_filters), mdctx,
+ GPR_ARRAY_SIZE(extra_filters),
grpc_server_get_channel_args(f->server));
grpc_exec_ctx_finish(&exec_ctx);
}
@@ -75,17 +74,15 @@ typedef struct {
} sp_client_setup;
static void client_setup_transport(grpc_exec_ctx *exec_ctx, void *ts,
- grpc_transport *transport,
- grpc_mdctx *mdctx) {
+ grpc_transport *transport) {
sp_client_setup *cs = ts;
const grpc_channel_filter *filters[] = {&grpc_http_client_filter,
&grpc_compress_filter,
&grpc_connected_channel_filter};
size_t nfilters = sizeof(filters) / sizeof(*filters);
- grpc_channel *channel =
- grpc_channel_create_from_filters(exec_ctx, "socketpair-target", filters,
- nfilters, cs->client_args, mdctx, 1);
+ grpc_channel *channel = grpc_channel_create_from_filters(
+ exec_ctx, "socketpair-target", filters, nfilters, cs->client_args, 1);
cs->f->client = channel;
@@ -112,13 +109,12 @@ static void chttp2_init_client_socketpair(grpc_end2end_test_fixture *f,
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
grpc_endpoint_pair *sfd = f->fixture_data;
grpc_transport *transport;
- grpc_mdctx *mdctx = grpc_mdctx_create();
sp_client_setup cs;
cs.client_args = client_args;
cs.f = f;
- transport = grpc_create_chttp2_transport(&exec_ctx, client_args, sfd->client,
- mdctx, 1);
- client_setup_transport(&exec_ctx, &cs, transport, mdctx);
+ transport =
+ grpc_create_chttp2_transport(&exec_ctx, client_args, sfd->client, 1);
+ client_setup_transport(&exec_ctx, &cs, transport);
GPR_ASSERT(f->client);
grpc_chttp2_transport_start_reading(&exec_ctx, transport, NULL, 0);
grpc_exec_ctx_finish(&exec_ctx);
@@ -128,15 +124,14 @@ static void chttp2_init_server_socketpair(grpc_end2end_test_fixture *f,
grpc_channel_args *server_args) {
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
grpc_endpoint_pair *sfd = f->fixture_data;
- grpc_mdctx *mdctx = grpc_mdctx_create();
grpc_transport *transport;
GPR_ASSERT(!f->server);
f->server = grpc_server_create_from_filters(NULL, 0, server_args);
grpc_server_register_completion_queue(f->server, f->cq, NULL);
grpc_server_start(f->server);
- transport = grpc_create_chttp2_transport(&exec_ctx, server_args, sfd->server,
- mdctx, 0);
- server_setup_transport(f, transport, mdctx);
+ transport =
+ grpc_create_chttp2_transport(&exec_ctx, server_args, sfd->server, 0);
+ server_setup_transport(f, transport);
grpc_chttp2_transport_start_reading(&exec_ctx, transport, NULL, 0);
grpc_exec_ctx_finish(&exec_ctx);
}
diff --git a/test/core/end2end/fixtures/h2_sockpair.c b/test/core/end2end/fixtures/h2_sockpair.c
index b61fe98610..a6a84c9b1a 100644
--- a/test/core/end2end/fixtures/h2_sockpair.c
+++ b/test/core/end2end/fixtures/h2_sockpair.c
@@ -56,14 +56,13 @@
/* chttp2 transport that is immediately available (used for testing
connected_channel without a client_channel */
-static void server_setup_transport(void *ts, grpc_transport *transport,
- grpc_mdctx *mdctx) {
+static void server_setup_transport(void *ts, grpc_transport *transport) {
grpc_end2end_test_fixture *f = ts;
static grpc_channel_filter const *extra_filters[] = {
&grpc_http_server_filter};
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
grpc_server_setup_transport(&exec_ctx, f->server, transport, extra_filters,
- GPR_ARRAY_SIZE(extra_filters), mdctx,
+ GPR_ARRAY_SIZE(extra_filters),
grpc_server_get_channel_args(f->server));
grpc_exec_ctx_finish(&exec_ctx);
}
@@ -74,17 +73,15 @@ typedef struct {
} sp_client_setup;
static void client_setup_transport(grpc_exec_ctx *exec_ctx, void *ts,
- grpc_transport *transport,
- grpc_mdctx *mdctx) {
+ grpc_transport *transport) {
sp_client_setup *cs = ts;
const grpc_channel_filter *filters[] = {&grpc_http_client_filter,
&grpc_compress_filter,
&grpc_connected_channel_filter};
size_t nfilters = sizeof(filters) / sizeof(*filters);
- grpc_channel *channel =
- grpc_channel_create_from_filters(exec_ctx, "socketpair-target", filters,
- nfilters, cs->client_args, mdctx, 1);
+ grpc_channel *channel = grpc_channel_create_from_filters(
+ exec_ctx, "socketpair-target", filters, nfilters, cs->client_args, 1);
cs->f->client = channel;
@@ -111,13 +108,12 @@ static void chttp2_init_client_socketpair(grpc_end2end_test_fixture *f,
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
grpc_endpoint_pair *sfd = f->fixture_data;
grpc_transport *transport;
- grpc_mdctx *mdctx = grpc_mdctx_create();
sp_client_setup cs;
cs.client_args = client_args;
cs.f = f;
- transport = grpc_create_chttp2_transport(&exec_ctx, client_args, sfd->client,
- mdctx, 1);
- client_setup_transport(&exec_ctx, &cs, transport, mdctx);
+ transport =
+ grpc_create_chttp2_transport(&exec_ctx, client_args, sfd->client, 1);
+ client_setup_transport(&exec_ctx, &cs, transport);
GPR_ASSERT(f->client);
grpc_chttp2_transport_start_reading(&exec_ctx, transport, NULL, 0);
grpc_exec_ctx_finish(&exec_ctx);
@@ -127,15 +123,14 @@ static void chttp2_init_server_socketpair(grpc_end2end_test_fixture *f,
grpc_channel_args *server_args) {
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
grpc_endpoint_pair *sfd = f->fixture_data;
- grpc_mdctx *mdctx = grpc_mdctx_create();
grpc_transport *transport;
GPR_ASSERT(!f->server);
f->server = grpc_server_create_from_filters(NULL, 0, server_args);
grpc_server_register_completion_queue(f->server, f->cq, NULL);
grpc_server_start(f->server);
- transport = grpc_create_chttp2_transport(&exec_ctx, server_args, sfd->server,
- mdctx, 0);
- server_setup_transport(f, transport, mdctx);
+ transport =
+ grpc_create_chttp2_transport(&exec_ctx, server_args, sfd->server, 0);
+ server_setup_transport(f, transport);
grpc_chttp2_transport_start_reading(&exec_ctx, transport, NULL, 0);
grpc_exec_ctx_finish(&exec_ctx);
}
diff --git a/test/core/end2end/fixtures/h2_sockpair_1byte.c b/test/core/end2end/fixtures/h2_sockpair_1byte.c
index 9f0fd2ea9a..4b8f9054ef 100644
--- a/test/core/end2end/fixtures/h2_sockpair_1byte.c
+++ b/test/core/end2end/fixtures/h2_sockpair_1byte.c
@@ -56,14 +56,13 @@
/* chttp2 transport that is immediately available (used for testing
connected_channel without a client_channel */
-static void server_setup_transport(void *ts, grpc_transport *transport,
- grpc_mdctx *mdctx) {
+static void server_setup_transport(void *ts, grpc_transport *transport) {
grpc_end2end_test_fixture *f = ts;
static grpc_channel_filter const *extra_filters[] = {
&grpc_http_server_filter};
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
grpc_server_setup_transport(&exec_ctx, f->server, transport, extra_filters,
- GPR_ARRAY_SIZE(extra_filters), mdctx,
+ GPR_ARRAY_SIZE(extra_filters),
grpc_server_get_channel_args(f->server));
grpc_exec_ctx_finish(&exec_ctx);
}
@@ -74,17 +73,15 @@ typedef struct {
} sp_client_setup;
static void client_setup_transport(grpc_exec_ctx *exec_ctx, void *ts,
- grpc_transport *transport,
- grpc_mdctx *mdctx) {
+ grpc_transport *transport) {
sp_client_setup *cs = ts;
const grpc_channel_filter *filters[] = {&grpc_http_client_filter,
&grpc_compress_filter,
&grpc_connected_channel_filter};
size_t nfilters = sizeof(filters) / sizeof(*filters);
- grpc_channel *channel =
- grpc_channel_create_from_filters(exec_ctx, "socketpair-target", filters,
- nfilters, cs->client_args, mdctx, 1);
+ grpc_channel *channel = grpc_channel_create_from_filters(
+ exec_ctx, "socketpair-target", filters, nfilters, cs->client_args, 1);
cs->f->client = channel;
@@ -111,13 +108,12 @@ static void chttp2_init_client_socketpair(grpc_end2end_test_fixture *f,
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
grpc_endpoint_pair *sfd = f->fixture_data;
grpc_transport *transport;
- grpc_mdctx *mdctx = grpc_mdctx_create();
sp_client_setup cs;
cs.client_args = client_args;
cs.f = f;
- transport = grpc_create_chttp2_transport(&exec_ctx, client_args, sfd->client,
- mdctx, 1);
- client_setup_transport(&exec_ctx, &cs, transport, mdctx);
+ transport =
+ grpc_create_chttp2_transport(&exec_ctx, client_args, sfd->client, 1);
+ client_setup_transport(&exec_ctx, &cs, transport);
GPR_ASSERT(f->client);
grpc_chttp2_transport_start_reading(&exec_ctx, transport, NULL, 0);
grpc_exec_ctx_finish(&exec_ctx);
@@ -127,15 +123,14 @@ static void chttp2_init_server_socketpair(grpc_end2end_test_fixture *f,
grpc_channel_args *server_args) {
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
grpc_endpoint_pair *sfd = f->fixture_data;
- grpc_mdctx *mdctx = grpc_mdctx_create();
grpc_transport *transport;
GPR_ASSERT(!f->server);
f->server = grpc_server_create_from_filters(NULL, 0, server_args);
grpc_server_register_completion_queue(f->server, f->cq, NULL);
grpc_server_start(f->server);
- transport = grpc_create_chttp2_transport(&exec_ctx, server_args, sfd->server,
- mdctx, 0);
- server_setup_transport(f, transport, mdctx);
+ transport =
+ grpc_create_chttp2_transport(&exec_ctx, server_args, sfd->server, 0);
+ server_setup_transport(f, transport);
grpc_chttp2_transport_start_reading(&exec_ctx, transport, NULL, 0);
grpc_exec_ctx_finish(&exec_ctx);
}
diff --git a/test/core/end2end/fixtures/h2_uchannel.c b/test/core/end2end/fixtures/h2_uchannel.c
index d1f9d38b82..ee4a60c29a 100644
--- a/test/core/end2end/fixtures/h2_uchannel.c
+++ b/test/core/end2end/fixtures/h2_uchannel.c
@@ -66,8 +66,6 @@ typedef struct {
grpc_endpoint *tcp;
- grpc_mdctx *mdctx;
-
grpc_closure connected;
} connector;
@@ -79,7 +77,6 @@ static void connector_ref(grpc_connector *con) {
static void connector_unref(grpc_exec_ctx *exec_ctx, grpc_connector *con) {
connector *c = (connector *)con;
if (gpr_unref(&c->refs)) {
- grpc_mdctx_unref(c->mdctx);
gpr_free(c);
}
}
@@ -89,8 +86,8 @@ static void connected(grpc_exec_ctx *exec_ctx, void *arg, int success) {
grpc_closure *notify;
grpc_endpoint *tcp = c->tcp;
if (tcp != NULL) {
- c->result->transport = grpc_create_chttp2_transport(
- exec_ctx, c->args.channel_args, tcp, c->mdctx, 1);
+ c->result->transport =
+ grpc_create_chttp2_transport(exec_ctx, c->args.channel_args, tcp, 1);
grpc_chttp2_transport_start_reading(exec_ctx, c->result->transport, NULL,
0);
GPR_ASSERT(c->result->transport);
@@ -130,7 +127,6 @@ static const grpc_connector_vtable connector_vtable = {
typedef struct {
grpc_subchannel_factory base;
gpr_refcount refs;
- grpc_mdctx *mdctx;
grpc_channel_args *merge_args;
grpc_channel *master;
grpc_subchannel **sniffed_subchannel;
@@ -147,7 +143,6 @@ static void subchannel_factory_unref(grpc_exec_ctx *exec_ctx,
if (gpr_unref(&f->refs)) {
GRPC_CHANNEL_INTERNAL_UNREF(exec_ctx, f->master, "subchannel_factory");
grpc_channel_args_destroy(f->merge_args);
- grpc_mdctx_unref(f->mdctx);
gpr_free(f);
}
}
@@ -162,10 +157,7 @@ static grpc_subchannel *subchannel_factory_create_subchannel(
grpc_subchannel *s;
memset(c, 0, sizeof(*c));
c->base.vtable = &connector_vtable;
- c->mdctx = f->mdctx;
- grpc_mdctx_ref(c->mdctx);
gpr_ref_init(&c->refs, 1);
- args->mdctx = f->mdctx;
args->args = final_args;
args->master = f->master;
s = grpc_subchannel_create(&c->base, args);
@@ -188,22 +180,19 @@ grpc_channel *channel_create(const char *target, const grpc_channel_args *args,
const grpc_channel_filter *filters[MAX_FILTERS];
grpc_resolver *resolver;
subchannel_factory *f;
- grpc_mdctx *mdctx = grpc_mdctx_create();
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
size_t n = 0;
filters[n++] = &grpc_client_channel_filter;
GPR_ASSERT(n <= MAX_FILTERS);
- channel = grpc_channel_create_from_filters(&exec_ctx, target, filters, n,
- args, mdctx, 1);
+ channel =
+ grpc_channel_create_from_filters(&exec_ctx, target, filters, n, args, 1);
f = gpr_malloc(sizeof(*f));
f->sniffed_subchannel = sniffed_subchannel;
f->base.vtable = &test_subchannel_factory_vtable;
gpr_ref_init(&f->refs, 1);
- grpc_mdctx_ref(mdctx);
- f->mdctx = mdctx;
f->merge_args = grpc_channel_args_copy(args);
f->master = channel;
GRPC_CHANNEL_INTERNAL_REF(f->master, "test_subchannel_factory");
diff --git a/test/core/end2end/fixtures/proxy.c b/test/core/end2end/fixtures/proxy.c
index 1090ad667d..434e75dd15 100644
--- a/test/core/end2end/fixtures/proxy.c
+++ b/test/core/end2end/fixtures/proxy.c
@@ -146,7 +146,6 @@ void grpc_end2end_proxy_destroy(grpc_end2end_proxy *proxy) {
}
static void unrefpc(proxy_call *pc, const char *reason) {
- gpr_log(GPR_DEBUG, "PROXY UNREF %s", reason);
if (gpr_unref(&pc->refs)) {
grpc_call_destroy(pc->c2p);
grpc_call_destroy(pc->p2s);
@@ -158,10 +157,7 @@ static void unrefpc(proxy_call *pc, const char *reason) {
}
}
-static void refpc(proxy_call *pc, const char *reason) {
- gpr_log(GPR_DEBUG, "PROXY REF %s", reason);
- gpr_ref(&pc->refs);
-}
+static void refpc(proxy_call *pc, const char *reason) { gpr_ref(&pc->refs); }
static void on_c2p_sent_initial_metadata(void *arg, int success) {
proxy_call *pc = arg;
diff --git a/test/core/end2end/gen_build_yaml.py b/test/core/end2end/gen_build_yaml.py
index 38d3b2218a..33687b8cd4 100755
--- a/test/core/end2end/gen_build_yaml.py
+++ b/test/core/end2end/gen_build_yaml.py
@@ -37,8 +37,8 @@ import collections
import hashlib
-FixtureOptions = collections.namedtuple('FixtureOptions', 'fullstack includes_proxy dns_resolver secure platforms ci_mac')
-default_unsecure_fixture_options = FixtureOptions(True, False, True, False, ['windows', 'linux', 'mac', 'posix'], True)
+FixtureOptions = collections.namedtuple('FixtureOptions', 'fullstack includes_proxy dns_resolver secure platforms ci_mac tracing')
+default_unsecure_fixture_options = FixtureOptions(True, False, True, False, ['windows', 'linux', 'mac', 'posix'], True, False)
socketpair_unsecure_fixture_options = default_unsecure_fixture_options._replace(fullstack=False, dns_resolver=False)
default_secure_fixture_options = default_unsecure_fixture_options._replace(secure=True)
uds_fixture_options = default_unsecure_fixture_options._replace(dns_resolver=False, platforms=['linux', 'mac', 'posix'])
@@ -54,7 +54,7 @@ END2END_FIXTURES = {
'h2_proxy': default_unsecure_fixture_options._replace(includes_proxy=True, ci_mac=False),
'h2_sockpair_1byte': socketpair_unsecure_fixture_options._replace(ci_mac=False),
'h2_sockpair': socketpair_unsecure_fixture_options._replace(ci_mac=False),
- 'h2_sockpair+trace': socketpair_unsecure_fixture_options,
+ 'h2_sockpair+trace': socketpair_unsecure_fixture_options._replace(tracing=True),
'h2_ssl': default_secure_fixture_options,
'h2_ssl+poll': default_secure_fixture_options._replace(platforms=['linux']),
'h2_ssl_proxy': default_secure_fixture_options._replace(includes_proxy=True, ci_mac=False),
@@ -63,8 +63,8 @@ END2END_FIXTURES = {
'h2_uds': uds_fixture_options,
}
-TestOptions = collections.namedtuple('TestOptions', 'needs_fullstack needs_dns proxyable flaky secure')
-default_test_options = TestOptions(False, False, True, False, False)
+TestOptions = collections.namedtuple('TestOptions', 'needs_fullstack needs_dns proxyable flaky secure traceable')
+default_test_options = TestOptions(False, False, True, False, False, True)
connectivity_test_options = default_test_options._replace(needs_fullstack=True)
# maps test names to options
@@ -85,6 +85,7 @@ END2END_TESTS = {
'disappearing_server': connectivity_test_options,
'empty_batch': default_test_options,
'graceful_server_shutdown': default_test_options,
+ 'hpack_size': default_test_options._replace(proxyable=False, traceable=False),
'high_initial_seqno': default_test_options,
'invoke_large_request': default_test_options,
'large_metadata': default_test_options,
@@ -117,6 +118,9 @@ def compatible(f, t):
if not END2END_TESTS[t].proxyable:
if END2END_FIXTURES[f].includes_proxy:
return False
+ if not END2END_TESTS[t].traceable:
+ if END2END_FIXTURES[f].tracing:
+ return False
return True
diff --git a/test/core/end2end/tests/cancel_with_status.c b/test/core/end2end/tests/cancel_with_status.c
index eecfa83fa4..2005e5f881 100644
--- a/test/core/end2end/tests/cancel_with_status.c
+++ b/test/core/end2end/tests/cancel_with_status.c
@@ -166,7 +166,8 @@ static void simple_request_body(grpc_end2end_test_fixture f, size_t num_ops) {
cq_verifier_destroy(cqv);
}
-static void test_invoke_simple_request(grpc_end2end_test_config config, size_t num_ops) {
+static void test_invoke_simple_request(grpc_end2end_test_config config,
+ size_t num_ops) {
grpc_end2end_test_fixture f;
f = begin_test(config, "test_invoke_simple_request", NULL, NULL);
diff --git a/test/core/end2end/tests/hpack_size.c b/test/core/end2end/tests/hpack_size.c
new file mode 100644
index 0000000000..297ea8d542
--- /dev/null
+++ b/test/core/end2end/tests/hpack_size.c
@@ -0,0 +1,446 @@
+/*
+ *
+ * Copyright 2015, Google Inc.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ *
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following disclaimer
+ * in the documentation and/or other materials provided with the
+ * distribution.
+ * * Neither the name of Google Inc. nor the names of its
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#include "test/core/end2end/end2end_tests.h"
+
+#include <stdio.h>
+#include <string.h>
+
+#include <grpc/byte_buffer.h>
+#include <grpc/grpc.h>
+#include <grpc/support/alloc.h>
+#include <grpc/support/log.h>
+#include <grpc/support/string_util.h>
+#include <grpc/support/time.h>
+#include <grpc/support/useful.h>
+
+#include "src/core/support/string.h"
+#include "test/core/end2end/cq_verifier.h"
+
+static void *tag(gpr_intptr t) { return (void *)t; }
+
+const char *hobbits[][2] = {{"Adaldrida", "Brandybuck"},
+ {"Adamanta", "Took"},
+ {"Adalgrim", "Took"},
+ {"Adelard", "Took"},
+ {"Amaranth", "Brandybuck"},
+ {"Andwise", "Roper"},
+ {"Angelica", "Baggins"},
+ {"Asphodel", "Burrows"},
+ {"Balbo", "Baggins"},
+ {"Bandobras", "Took"},
+ {"Belba", "Bolger"},
+ {"Bell", "Gamgee"},
+ {"Belladonna", "Baggins"},
+ {"Berylla", "Baggins"},
+ {"Bilbo", "Baggins"},
+ {"Bilbo", "Gardner"},
+ {"Bill", "Butcher"},
+ {"Bingo", "Baggins"},
+ {"Bodo", "Proudfoot"},
+ {"Bowman", "Cotton"},
+ {"Bungo", "Baggins"},
+ {"Camellia", "Sackville"},
+ {"Carl", "Cotton"},
+ {"Celandine", "Brandybuck"},
+ {"Chica", "Baggins"},
+ {"Daddy", "Twofoot"},
+ {"Daisy", "Boffin"},
+ {"Diamond", "Took"},
+ {"Dinodas", "Brandybuck"},
+ {"Doderic", "Brandybuck"},
+ {"Dodinas", "Brandybuck"},
+ {"Donnamira", "Boffin"},
+ {"Dora", "Baggins"},
+ {"Drogo", "Baggins"},
+ {"Dudo", "Baggins"},
+ {"Eglantine", "Took"},
+ {"Elanor", "Fairbairn"},
+ {"Elfstan", "Fairbairn"},
+ {"Esmeralda", "Brandybuck"},
+ {"Estella", "Brandybuck"},
+ {"Everard", "Took"},
+ {"Falco", "Chubb-Baggins"},
+ {"Faramir", "Took"},
+ {"Farmer", "Maggot"},
+ {"Fastolph", "Bolger"},
+ {"Ferdibrand", "Took"},
+ {"Ferdinand", "Took"},
+ {"Ferumbras", "Took"},
+ {"Ferumbras", "Took"},
+ {"Filibert", "Bolger"},
+ {"Firiel", "Fairbairn"},
+ {"Flambard", "Took"},
+ {"Folco", "Boffin"},
+ {"Fortinbras", "Took"},
+ {"Fortinbras", "Took"},
+ {"Fosco", "Baggins"},
+ {"Fredegar", "Bolger"},
+ {"Frodo", "Baggins"},
+ {"Frodo", "Gardner"},
+ {"Gerontius", "Took"},
+ {"Gilly", "Baggins"},
+ {"Goldilocks", "Took"},
+ {"Gorbadoc", "Brandybuck"},
+ {"Gorbulas", "Brandybuck"},
+ {"Gorhendad", "Brandybuck"},
+ {"Gormadoc", "Brandybuck"},
+ {"Griffo", "Boffin"},
+ {"Halfast", "Gamgee"},
+ {"Halfred", "Gamgee"},
+ {"Halfred", "Greenhand"},
+ {"Hanna", "Brandybuck"},
+ {"Hamfast", "Gamgee"},
+ {"Hamfast", "Gardner"},
+ {"Hamson", "Gamgee"},
+ {"Harding", "Gardner"},
+ {"Hilda", "Brandybuck"},
+ {"Hildibrand", "Took"},
+ {"Hildifons", "Took"},
+ {"Hildigard", "Took"},
+ {"Hildigrim", "Took"},
+ {"Hob", "Gammidge"},
+ {"Hob", "Hayward"},
+ {"Hobson", "Gamgee"},
+ {"Holfast", "Gardner"},
+ {"Holman", "Cotton"},
+ {"Holman", "Greenhand"},
+ {"Hugo", "Boffin"},
+ {"Hugo", "Bracegirdle"},
+ {"Ilberic", "Brandybuck"},
+ {"Isembard", "Took"},
+ {"Isembold", "Took"},
+ {"Isengar", "Took"},
+ {"Isengrim", "Took"},
+ {"Isengrim", "Took"},
+ {"Isumbras", "Took"},
+ {"Isumbras", "Took"},
+ {"Jolly", "Cotton"},
+ {"Lalia", "Took"},
+ {"Largo", "Baggins"},
+ {"Laura", "Baggins"},
+ {"Lily", "Goodbody"},
+ {"Lily", "Cotton"},
+ {"Linda", "Proudfoot"},
+ {"Lobelia", "Sackville-Baggins"},
+ {"Longo", "Baggins"},
+ {"Lotho", "Sackville-Baggins"},
+ {"Madoc", "Brandybuck"},
+ {"Malva", "Brandybuck"},
+ {"Marigold", "Cotton"},
+ {"Marmadas", "Brandybuck"},
+ {"Marmadoc", "Brandybuck"},
+ {"Marroc", "Brandybuck"},
+ {"May", "Gamgee"},
+ {"Melilot", "Brandybuck"},
+ {"Menegilda", "Brandybuck"},
+ {"Mentha", "Brandybuck"},
+ {"Meriadoc", "Brandybuck"},
+ {"Merimac", "Brandybuck"},
+ {"Merimas", "Brandybuck"},
+ {"Merry", "Gardner"},
+ {"Milo", "Burrows"},
+ {"Mimosa", "Baggins"},
+ {"Minto", "Burrows"},
+ {"Mirabella", "Brandybuck"},
+ {"Moro", "Burrows"},
+ {"Mosco", "Burrows"},
+ {"Mungo", "Baggins"},
+ {"Myrtle", "Burrows"},
+ {"Odo", "Proudfoot"},
+ {"Odovacar", "Bolger"},
+ {"Olo", "Proudfoot"},
+ {"Orgulas", "Brandybuck"},
+ {"Otho", "Sackville-Baggins"},
+ {"Paladin", "Took"},
+ {"Pansy", "Bolger"},
+ {"Pearl", "Took"},
+ {"Peony", "Burrows"},
+ {"Peregrin", "Took"},
+ {"Pervinca", "Took"},
+ {"Pimpernel", "Took"},
+ {"Pippin", "Gardner"},
+ {"Polo", "Baggins"},
+ {"Ponto", "Baggins"},
+ {"Porto", "Baggins"},
+ {"Posco", "Baggins"},
+ {"Poppy", "Bolger"},
+ {"Primrose", "Gardner"},
+ {"Primula", "Baggins"},
+ {"Prisca", "Bolger"},
+ {"Reginard", "Took"},
+ {"Robin", "Smallburrow"},
+ {"Robin", "Gardner"},
+ {"Rorimac", "Brandybuck"},
+ {"Rosa", "Took"},
+ {"Rosamunda", "Bolger"},
+ {"Rose", "Gardner"},
+ {"Ruby", "Baggins"},
+ {"Ruby", "Gardner"},
+ {"Rudigar", "Bolger"},
+ {"Rufus", "Burrows"},
+ {"Sadoc", "Brandybuck"},
+ {"Salvia", "Bolger"},
+ {"Samwise", "Gamgee"},
+ {"Sancho", "Proudfoot"},
+ {"Saradas", "Brandybuck"},
+ {"Saradoc", "Brandybuck"},
+ {"Seredic", "Brandybuck"},
+ {"Sigismond", "Took"},
+ {"Smeagol", "Gollum"},
+ {"Tanta", "Baggins"},
+ {"Ted", "Sandyman"},
+ {"Tobold", "Hornblower"},
+ {"Togo", "Goodbody"},
+ {"Tolman", "Cotton"},
+ {"Tolman", "Gardner"},
+ {"Widow", "Rumble"},
+ {"Wilcome", "Cotton"},
+ {"Wilcome", "Cotton"},
+ {"Wilibald", "Bolger"},
+ {"Will", "Whitfoot"},
+ {"Wiseman", "Gamwich"}};
+
+const char *dragons[] = {"Ancalagon", "Glaurung", "Scatha",
+ "Smaug the Magnificent"};
+
+static grpc_end2end_test_fixture begin_test(grpc_end2end_test_config config,
+ const char *test_name,
+ grpc_channel_args *client_args,
+ grpc_channel_args *server_args) {
+ grpc_end2end_test_fixture f;
+ gpr_log(GPR_INFO, "%s/%s", test_name, config.name);
+ f = config.create_fixture(client_args, server_args);
+ config.init_client(&f, client_args);
+ config.init_server(&f, server_args);
+ return f;
+}
+
+static gpr_timespec n_seconds_time(int n) {
+ return GRPC_TIMEOUT_SECONDS_TO_DEADLINE(n);
+}
+
+static gpr_timespec five_seconds_time(void) { return n_seconds_time(5); }
+
+static void drain_cq(grpc_completion_queue *cq) {
+ grpc_event ev;
+ do {
+ ev = grpc_completion_queue_next(cq, five_seconds_time(), NULL);
+ } while (ev.type != GRPC_QUEUE_SHUTDOWN);
+}
+
+static void shutdown_server(grpc_end2end_test_fixture *f) {
+ if (!f->server) return;
+ grpc_server_shutdown_and_notify(f->server, f->cq, tag(1000));
+ GPR_ASSERT(grpc_completion_queue_pluck(
+ f->cq, tag(1000), GRPC_TIMEOUT_SECONDS_TO_DEADLINE(5), NULL)
+ .type == GRPC_OP_COMPLETE);
+ grpc_server_destroy(f->server);
+ f->server = NULL;
+}
+
+static void shutdown_client(grpc_end2end_test_fixture *f) {
+ if (!f->client) return;
+ grpc_channel_destroy(f->client);
+ f->client = NULL;
+}
+
+static void end_test(grpc_end2end_test_fixture *f) {
+ shutdown_server(f);
+ shutdown_client(f);
+
+ grpc_completion_queue_shutdown(f->cq);
+ drain_cq(f->cq);
+ grpc_completion_queue_destroy(f->cq);
+}
+
+static void simple_request_body(grpc_end2end_test_fixture f, size_t index) {
+ grpc_call *c;
+ grpc_call *s;
+ gpr_timespec deadline = five_seconds_time();
+ cq_verifier *cqv = cq_verifier_create(f.cq);
+ grpc_op ops[6];
+ grpc_op *op;
+ grpc_metadata_array initial_metadata_recv;
+ grpc_metadata_array trailing_metadata_recv;
+ grpc_metadata_array request_metadata_recv;
+ grpc_call_details call_details;
+ grpc_status_code status;
+ grpc_call_error error;
+ grpc_metadata extra_metadata[3];
+ char *details = NULL;
+ size_t details_capacity = 0;
+ int was_cancelled = 2;
+
+ memset(extra_metadata, 0, sizeof(extra_metadata));
+ extra_metadata[0].key = "hobbit-first-name";
+ extra_metadata[0].value = hobbits[index % GPR_ARRAY_SIZE(hobbits)][0];
+ extra_metadata[0].value_length = strlen(extra_metadata[0].value);
+ extra_metadata[1].key = "hobbit-second-name";
+ extra_metadata[1].value = hobbits[index % GPR_ARRAY_SIZE(hobbits)][1];
+ extra_metadata[1].value_length = strlen(extra_metadata[1].value);
+ extra_metadata[2].key = "dragon";
+ extra_metadata[2].value = dragons[index % GPR_ARRAY_SIZE(dragons)];
+ extra_metadata[2].value_length = strlen(extra_metadata[2].value);
+
+ c = grpc_channel_create_call(f.client, NULL, GRPC_PROPAGATE_DEFAULTS, f.cq,
+ "/foo", "foo.test.google.fr:1234", deadline,
+ NULL);
+ GPR_ASSERT(c);
+
+ grpc_metadata_array_init(&initial_metadata_recv);
+ grpc_metadata_array_init(&trailing_metadata_recv);
+ grpc_metadata_array_init(&request_metadata_recv);
+ grpc_call_details_init(&call_details);
+
+ op = ops;
+ op->op = GRPC_OP_SEND_INITIAL_METADATA;
+ op->data.send_initial_metadata.count = GPR_ARRAY_SIZE(extra_metadata);
+ op->data.send_initial_metadata.metadata = extra_metadata;
+ op->flags = 0;
+ op->reserved = NULL;
+ op++;
+ op->op = GRPC_OP_SEND_CLOSE_FROM_CLIENT;
+ op->flags = 0;
+ op->reserved = NULL;
+ op++;
+ op->op = GRPC_OP_RECV_INITIAL_METADATA;
+ op->data.recv_initial_metadata = &initial_metadata_recv;
+ op->flags = 0;
+ op->reserved = NULL;
+ op++;
+ op->op = GRPC_OP_RECV_STATUS_ON_CLIENT;
+ op->data.recv_status_on_client.trailing_metadata = &trailing_metadata_recv;
+ op->data.recv_status_on_client.status = &status;
+ op->data.recv_status_on_client.status_details = &details;
+ op->data.recv_status_on_client.status_details_capacity = &details_capacity;
+ op->flags = 0;
+ op->reserved = NULL;
+ op++;
+ error = grpc_call_start_batch(c, ops, (size_t)(op - ops), tag(1), NULL);
+ GPR_ASSERT(GRPC_CALL_OK == error);
+
+ error =
+ grpc_server_request_call(f.server, &s, &call_details,
+ &request_metadata_recv, f.cq, f.cq, tag(101));
+ GPR_ASSERT(GRPC_CALL_OK == error);
+ cq_expect_completion(cqv, tag(101), 1);
+ cq_verify(cqv);
+
+ op = ops;
+ op->op = GRPC_OP_SEND_INITIAL_METADATA;
+ op->data.send_initial_metadata.count = 0;
+ op->flags = 0;
+ op->reserved = NULL;
+ op++;
+ op->op = GRPC_OP_SEND_STATUS_FROM_SERVER;
+ op->data.send_status_from_server.trailing_metadata_count = 0;
+ op->data.send_status_from_server.status = GRPC_STATUS_UNIMPLEMENTED;
+ op->data.send_status_from_server.status_details = "xyz";
+ op->flags = 0;
+ op->reserved = NULL;
+ op++;
+ op->op = GRPC_OP_RECV_CLOSE_ON_SERVER;
+ op->data.recv_close_on_server.cancelled = &was_cancelled;
+ op->flags = 0;
+ op->reserved = NULL;
+ op++;
+ error = grpc_call_start_batch(s, ops, (size_t)(op - ops), tag(102), NULL);
+ GPR_ASSERT(GRPC_CALL_OK == error);
+
+ cq_expect_completion(cqv, tag(102), 1);
+ cq_expect_completion(cqv, tag(1), 1);
+ cq_verify(cqv);
+
+ GPR_ASSERT(status == GRPC_STATUS_UNIMPLEMENTED);
+ GPR_ASSERT(0 == strcmp(details, "xyz"));
+ GPR_ASSERT(0 == strcmp(call_details.method, "/foo"));
+ GPR_ASSERT(0 == strcmp(call_details.host, "foo.test.google.fr:1234"));
+ GPR_ASSERT(was_cancelled == 1);
+
+ gpr_free(details);
+ grpc_metadata_array_destroy(&initial_metadata_recv);
+ grpc_metadata_array_destroy(&trailing_metadata_recv);
+ grpc_metadata_array_destroy(&request_metadata_recv);
+ grpc_call_details_destroy(&call_details);
+
+ grpc_call_destroy(c);
+ grpc_call_destroy(s);
+
+ cq_verifier_destroy(cqv);
+}
+
+static void test_size(grpc_end2end_test_config config, int encode_size,
+ int decode_size) {
+ size_t i;
+ grpc_end2end_test_fixture f;
+ grpc_arg server_arg;
+ grpc_channel_args server_args;
+ grpc_arg client_arg;
+ grpc_channel_args client_args;
+ char *name;
+
+ server_arg.type = GRPC_ARG_INTEGER;
+ server_arg.key = GRPC_ARG_HTTP2_HPACK_TABLE_SIZE_DECODER;
+ server_arg.value.integer = decode_size;
+ server_args.num_args = 1;
+ server_args.args = &server_arg;
+
+ client_arg.type = GRPC_ARG_INTEGER;
+ client_arg.key = GRPC_ARG_HTTP2_HPACK_TABLE_SIZE_ENCODER;
+ client_arg.value.integer = encode_size;
+ client_args.num_args = 1;
+ client_args.args = &client_arg;
+
+ gpr_asprintf(&name, "test_size:e=%d:d=%d", encode_size, decode_size);
+ f = begin_test(config, name, encode_size != 4096 ? &client_args : NULL,
+ decode_size != 4096 ? &server_args : NULL);
+ for (i = 0; i < 4 * GPR_ARRAY_SIZE(hobbits); i++) {
+ simple_request_body(f, i);
+ }
+ end_test(&f);
+ config.tear_down_data(&f);
+ gpr_free(name);
+}
+
+void grpc_end2end_tests(grpc_end2end_test_config config) {
+ static const int interesting_sizes[] = {4096, 0, 100,
+ 1000, 32768, 4 * 1024 * 1024};
+ size_t i, j;
+
+ for (i = 0; i < GPR_ARRAY_SIZE(interesting_sizes); i++) {
+ for (j = 0; j < GPR_ARRAY_SIZE(interesting_sizes); j++) {
+ test_size(config, interesting_sizes[i], interesting_sizes[j]);
+ }
+ }
+}
diff --git a/test/core/end2end/tests/negative_deadline.c b/test/core/end2end/tests/negative_deadline.c
index abcc1ba358..8fe9e7bcc5 100644
--- a/test/core/end2end/tests/negative_deadline.c
+++ b/test/core/end2end/tests/negative_deadline.c
@@ -163,7 +163,8 @@ static void simple_request_body(grpc_end2end_test_fixture f, size_t num_ops) {
cq_verifier_destroy(cqv);
}
-static void test_invoke_simple_request(grpc_end2end_test_config config, size_t num_ops) {
+static void test_invoke_simple_request(grpc_end2end_test_config config,
+ size_t num_ops) {
grpc_end2end_test_fixture f;
f = begin_test(config, "test_invoke_simple_request", NULL, NULL);
diff --git a/test/core/fling/client.c b/test/core/fling/client.c
index a53411c2f5..99b30d6c4a 100644
--- a/test/core/fling/client.c
+++ b/test/core/fling/client.c
@@ -41,6 +41,7 @@
#include <grpc/support/log.h>
#include <grpc/support/time.h>
#include <grpc/support/useful.h>
+#include "src/core/profiling/timers.h"
#include "test/core/util/grpc_profiler.h"
#include "test/core/util/test_config.h"
@@ -89,6 +90,7 @@ static void init_ping_pong_request(void) {
}
static void step_ping_pong_request(void) {
+ GPR_TIMER_BEGIN("ping_pong", 1);
call = grpc_channel_create_call(channel, NULL, GRPC_PROPAGATE_DEFAULTS, cq,
"/Reflector/reflectUnary", "localhost",
gpr_inf_future(GPR_CLOCK_REALTIME), NULL);
@@ -99,6 +101,7 @@ static void step_ping_pong_request(void) {
grpc_call_destroy(call);
grpc_byte_buffer_destroy(response_payload_recv);
call = NULL;
+ GPR_TIMER_END("ping_pong", 1);
}
static void init_ping_pong_stream(void) {
@@ -122,10 +125,12 @@ static void init_ping_pong_stream(void) {
static void step_ping_pong_stream(void) {
grpc_call_error error;
+ GPR_TIMER_BEGIN("ping_pong", 1);
error = grpc_call_start_batch(call, stream_step_ops, 2, (void *)1, NULL);
GPR_ASSERT(GRPC_CALL_OK == error);
grpc_completion_queue_next(cq, gpr_inf_future(GPR_CLOCK_REALTIME), NULL);
grpc_byte_buffer_destroy(response_payload_recv);
+ GPR_TIMER_END("ping_pong", 1);
}
static double now(void) {
@@ -159,12 +164,14 @@ int main(int argc, char **argv) {
char *scenario_name = "ping-pong-request";
scenario sc = {NULL, NULL, NULL};
+ gpr_timers_set_log_filename("latency_trace.fling_client.txt");
+
+ grpc_init();
+
GPR_ASSERT(argc >= 1);
fake_argv[0] = argv[0];
grpc_test_init(1, fake_argv);
- grpc_init();
-
cl = gpr_cmdline_create("fling client");
gpr_cmdline_add_int(cl, "payload_size", "Size of the payload to send",
&payload_size);
diff --git a/test/core/fling/server.c b/test/core/fling/server.c
index 67631e5a07..ae218b4cc1 100644
--- a/test/core/fling/server.c
+++ b/test/core/fling/server.c
@@ -44,15 +44,16 @@
#include <unistd.h>
#endif
-#include "test/core/util/grpc_profiler.h"
-#include "test/core/util/test_config.h"
#include <grpc/support/alloc.h>
#include <grpc/support/cmdline.h>
#include <grpc/support/host_port.h>
#include <grpc/support/log.h>
#include <grpc/support/time.h>
-#include "test/core/util/port.h"
+#include "src/core/profiling/timers.h"
#include "test/core/end2end/data/ssl_test_data.h"
+#include "test/core/util/grpc_profiler.h"
+#include "test/core/util/port.h"
+#include "test/core/util/test_config.h"
static grpc_completion_queue *cq;
static grpc_server *server;
@@ -192,6 +193,8 @@ int main(int argc, char **argv) {
char *fake_argv[1];
+ gpr_timers_set_log_filename("latency_trace.fling_server.txt");
+
GPR_ASSERT(argc >= 1);
fake_argv[0] = argv[0];
grpc_test_init(1, fake_argv);
diff --git a/test/core/iomgr/fd_posix_test.c b/test/core/iomgr/fd_posix_test.c
index f592f63ba9..4be6957a83 100644
--- a/test/core/iomgr/fd_posix_test.c
+++ b/test/core/iomgr/fd_posix_test.c
@@ -121,7 +121,7 @@ static void session_shutdown_cb(grpc_exec_ctx *exec_ctx, void *arg, /*session */
int success) {
session *se = arg;
server *sv = se->sv;
- grpc_fd_orphan(exec_ctx, se->em_fd, NULL, "a");
+ grpc_fd_orphan(exec_ctx, se->em_fd, NULL, NULL, "a");
gpr_free(se);
/* Start to shutdown listen fd. */
grpc_fd_shutdown(exec_ctx, sv->em_fd);
@@ -177,7 +177,7 @@ static void listen_shutdown_cb(grpc_exec_ctx *exec_ctx, void *arg /*server */,
int success) {
server *sv = arg;
- grpc_fd_orphan(exec_ctx, sv->em_fd, NULL, "b");
+ grpc_fd_orphan(exec_ctx, sv->em_fd, NULL, NULL, "b");
gpr_mu_lock(GRPC_POLLSET_MU(&g_pollset));
sv->done = 1;
@@ -294,7 +294,7 @@ static void client_init(client *cl) {
static void client_session_shutdown_cb(grpc_exec_ctx *exec_ctx,
void *arg /*client */, int success) {
client *cl = arg;
- grpc_fd_orphan(exec_ctx, cl->em_fd, NULL, "c");
+ grpc_fd_orphan(exec_ctx, cl->em_fd, NULL, NULL, "c");
cl->done = 1;
grpc_pollset_kick(&g_pollset, NULL);
}
@@ -503,7 +503,7 @@ static void test_grpc_fd_change(void) {
GPR_ASSERT(b.cb_that_ran == second_read_callback);
gpr_mu_unlock(GRPC_POLLSET_MU(&g_pollset));
- grpc_fd_orphan(&exec_ctx, em_fd, NULL, "d");
+ grpc_fd_orphan(&exec_ctx, em_fd, NULL, NULL, "d");
grpc_exec_ctx_finish(&exec_ctx);
destroy_change_data(&a);
destroy_change_data(&b);
diff --git a/test/core/iomgr/tcp_posix_test.c b/test/core/iomgr/tcp_posix_test.c
index f676454b7f..9feac931a3 100644
--- a/test/core/iomgr/tcp_posix_test.c
+++ b/test/core/iomgr/tcp_posix_test.c
@@ -383,6 +383,76 @@ static void write_test(size_t num_bytes, size_t slice_size) {
grpc_exec_ctx_finish(&exec_ctx);
}
+void on_fd_released(grpc_exec_ctx *exec_ctx, void *arg, int success) {
+ int *done = arg;
+ *done = 1;
+ grpc_pollset_kick(&g_pollset, NULL);
+}
+
+/* Do a read_test, then release fd and try to read/write again. */
+static void release_fd_test(size_t num_bytes, size_t slice_size) {
+ int sv[2];
+ grpc_endpoint *ep;
+ struct read_socket_state state;
+ size_t written_bytes;
+ int fd;
+ gpr_timespec deadline = GRPC_TIMEOUT_SECONDS_TO_DEADLINE(20);
+ grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
+ grpc_closure fd_released_cb;
+ int fd_released_done = 0;
+ grpc_closure_init(&fd_released_cb, &on_fd_released, &fd_released_done);
+
+ gpr_log(GPR_INFO, "Release fd read_test of size %d, slice size %d", num_bytes,
+ slice_size);
+
+ create_sockets(sv);
+
+ ep = grpc_tcp_create(grpc_fd_create(sv[1], "read_test"), slice_size, "test");
+ grpc_endpoint_add_to_pollset(&exec_ctx, ep, &g_pollset);
+
+ written_bytes = fill_socket_partial(sv[0], num_bytes);
+ gpr_log(GPR_INFO, "Wrote %d bytes", written_bytes);
+
+ state.ep = ep;
+ state.read_bytes = 0;
+ state.target_read_bytes = written_bytes;
+ gpr_slice_buffer_init(&state.incoming);
+ grpc_closure_init(&state.read_cb, read_cb, &state);
+
+ grpc_endpoint_read(&exec_ctx, ep, &state.incoming, &state.read_cb);
+
+ gpr_mu_lock(GRPC_POLLSET_MU(&g_pollset));
+ while (state.read_bytes < state.target_read_bytes) {
+ grpc_pollset_worker worker;
+ grpc_pollset_work(&exec_ctx, &g_pollset, &worker,
+ gpr_now(GPR_CLOCK_MONOTONIC), deadline);
+ gpr_mu_unlock(GRPC_POLLSET_MU(&g_pollset));
+ grpc_exec_ctx_finish(&exec_ctx);
+ gpr_mu_lock(GRPC_POLLSET_MU(&g_pollset));
+ }
+ GPR_ASSERT(state.read_bytes == state.target_read_bytes);
+ gpr_mu_unlock(GRPC_POLLSET_MU(&g_pollset));
+
+ gpr_slice_buffer_destroy(&state.incoming);
+ grpc_tcp_destroy_and_release_fd(&exec_ctx, ep, &fd, &fd_released_cb);
+ gpr_mu_lock(GRPC_POLLSET_MU(&g_pollset));
+ while (!fd_released_done) {
+ grpc_pollset_worker worker;
+ grpc_pollset_work(&exec_ctx, &g_pollset, &worker,
+ gpr_now(GPR_CLOCK_MONOTONIC), deadline);
+ }
+ gpr_mu_unlock(GRPC_POLLSET_MU(&g_pollset));
+ GPR_ASSERT(fd_released_done == 1);
+ GPR_ASSERT(fd == sv[1]);
+ grpc_exec_ctx_finish(&exec_ctx);
+
+ written_bytes = fill_socket_partial(sv[0], num_bytes);
+ drain_socket_blocking(fd, written_bytes, written_bytes);
+ written_bytes = fill_socket_partial(fd, num_bytes);
+ drain_socket_blocking(sv[0], written_bytes, written_bytes);
+ close(fd);
+}
+
void run_tests(void) {
size_t i = 0;
@@ -402,6 +472,8 @@ void run_tests(void) {
for (i = 1; i < 1000; i = GPR_MAX(i + 1, i * 5 / 4)) {
write_test(40320, i);
}
+
+ release_fd_test(100, 8192);
}
static void clean_up(void) {}
diff --git a/test/core/network_benchmarks/low_level_ping_pong.c b/test/core/network_benchmarks/low_level_ping_pong.c
index 7a2d894481..dd1544c27b 100644
--- a/test/core/network_benchmarks/low_level_ping_pong.c
+++ b/test/core/network_benchmarks/low_level_ping_pong.c
@@ -139,7 +139,7 @@ static int poll_read_bytes(int fd, char *buf, size_t read_size, int spin) {
gpr_log(GPR_ERROR, "Read failed: %s", strerror(errno));
return -1;
}
- bytes_read += (size_t) err2;
+ bytes_read += (size_t)err2;
} while (bytes_read < read_size);
return 0;
}
@@ -174,11 +174,11 @@ static int epoll_read_bytes(struct thread_args *args, char *buf, int spin) {
GPR_ASSERT(ev.data.fd == args->fds.read_fd);
do {
do {
- err2 = read(args->fds.read_fd, buf + bytes_read,
- read_size - bytes_read);
+ err2 =
+ read(args->fds.read_fd, buf + bytes_read, read_size - bytes_read);
} while (err2 < 0 && errno == EINTR);
if (errno == EAGAIN) break;
- bytes_read += (size_t) err2;
+ bytes_read += (size_t)err2;
/* TODO(klempner): This should really be doing an extra call after we are
done to ensure we see an EAGAIN */
} while (bytes_read < read_size);
diff --git a/test/core/security/credentials_test.c b/test/core/security/credentials_test.c
index dcb35e5309..b2b7cfdb6e 100644
--- a/test/core/security/credentials_test.c
+++ b/test/core/security/credentials_test.c
@@ -126,6 +126,8 @@ static const char test_signed_jwt[] =
static const char test_service_url[] = "https://foo.com/foo.v1";
static const char other_test_service_url[] = "https://bar.com/bar.v1";
+static const char test_method[] = "ThisIsNotAMethod";
+
/* -- Utils. -- */
static char *test_json_key_str(void) {
@@ -352,9 +354,10 @@ static void test_google_iam_creds(void) {
grpc_call_credentials *creds = grpc_google_iam_credentials_create(
test_google_iam_authorization_token, test_google_iam_authority_selector,
NULL);
- grpc_call_credentials_get_request_metadata(&exec_ctx, creds, NULL,
- test_service_url,
- check_google_iam_metadata, creds);
+ grpc_auth_metadata_context auth_md_ctx = {test_service_url, test_method, NULL,
+ NULL};
+ grpc_call_credentials_get_request_metadata(
+ &exec_ctx, creds, NULL, auth_md_ctx, check_google_iam_metadata, creds);
grpc_exec_ctx_finish(&exec_ctx);
}
@@ -375,10 +378,11 @@ static void test_access_token_creds(void) {
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
grpc_call_credentials *creds =
grpc_access_token_credentials_create("blah", NULL);
+ grpc_auth_metadata_context auth_md_ctx = {test_service_url, test_method, NULL,
+ NULL};
GPR_ASSERT(strcmp(creds->type, GRPC_CALL_CREDENTIALS_TYPE_OAUTH2) == 0);
grpc_call_credentials_get_request_metadata(
- &exec_ctx, creds, NULL, test_service_url, check_access_token_metadata,
- creds);
+ &exec_ctx, creds, NULL, auth_md_ctx, check_access_token_metadata, creds);
grpc_exec_ctx_finish(&exec_ctx);
}
@@ -430,13 +434,16 @@ static void check_oauth2_google_iam_composite_metadata(
static void test_oauth2_google_iam_composite_creds(void) {
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
const grpc_call_credentials_array *creds_array;
+ grpc_auth_metadata_context auth_md_ctx = {test_service_url, test_method, NULL,
+ NULL};
grpc_call_credentials *oauth2_creds = grpc_md_only_test_credentials_create(
"authorization", test_oauth2_bearer_token, 0);
grpc_call_credentials *google_iam_creds = grpc_google_iam_credentials_create(
test_google_iam_authorization_token, test_google_iam_authority_selector,
NULL);
grpc_call_credentials *composite_creds =
- grpc_composite_call_credentials_create(oauth2_creds, google_iam_creds, NULL);
+ grpc_composite_call_credentials_create(oauth2_creds, google_iam_creds,
+ NULL);
grpc_call_credentials_unref(oauth2_creds);
grpc_call_credentials_unref(google_iam_creds);
GPR_ASSERT(
@@ -449,7 +456,7 @@ static void test_oauth2_google_iam_composite_creds(void) {
GPR_ASSERT(strcmp(creds_array->creds_array[1]->type,
GRPC_CALL_CREDENTIALS_TYPE_IAM) == 0);
grpc_call_credentials_get_request_metadata(
- &exec_ctx, composite_creds, NULL, test_service_url,
+ &exec_ctx, composite_creds, NULL, auth_md_ctx,
check_oauth2_google_iam_composite_metadata, composite_creds);
grpc_exec_ctx_finish(&exec_ctx);
}
@@ -481,7 +488,8 @@ static void test_channel_oauth2_google_iam_composite_creds(void) {
grpc_call_credentials *oauth2_creds =
grpc_access_token_credentials_create("blah", NULL);
grpc_channel_credentials *channel_oauth2_creds =
- grpc_composite_channel_credentials_create(channel_creds, oauth2_creds, NULL);
+ grpc_composite_channel_credentials_create(channel_creds, oauth2_creds,
+ NULL);
grpc_call_credentials *google_iam_creds = grpc_google_iam_credentials_create(
test_google_iam_authorization_token, test_google_iam_authority_selector,
NULL);
@@ -576,12 +584,14 @@ static void test_compute_engine_creds_success(void) {
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
grpc_call_credentials *compute_engine_creds =
grpc_google_compute_engine_credentials_create(NULL);
+ grpc_auth_metadata_context auth_md_ctx = {test_service_url, test_method, NULL,
+ NULL};
/* First request: http get should be called. */
grpc_httpcli_set_override(compute_engine_httpcli_get_success_override,
httpcli_post_should_not_be_called);
grpc_call_credentials_get_request_metadata(
- &exec_ctx, compute_engine_creds, NULL, test_service_url,
+ &exec_ctx, compute_engine_creds, NULL, auth_md_ctx,
on_oauth2_creds_get_metadata_success, (void *)test_user_data);
grpc_exec_ctx_flush(&exec_ctx);
@@ -589,7 +599,7 @@ static void test_compute_engine_creds_success(void) {
grpc_httpcli_set_override(httpcli_get_should_not_be_called,
httpcli_post_should_not_be_called);
grpc_call_credentials_get_request_metadata(
- &exec_ctx, compute_engine_creds, NULL, test_service_url,
+ &exec_ctx, compute_engine_creds, NULL, auth_md_ctx,
on_oauth2_creds_get_metadata_success, (void *)test_user_data);
grpc_exec_ctx_finish(&exec_ctx);
@@ -599,12 +609,14 @@ static void test_compute_engine_creds_success(void) {
static void test_compute_engine_creds_failure(void) {
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
+ grpc_auth_metadata_context auth_md_ctx = {test_service_url, test_method, NULL,
+ NULL};
grpc_call_credentials *compute_engine_creds =
grpc_google_compute_engine_credentials_create(NULL);
grpc_httpcli_set_override(compute_engine_httpcli_get_failure_override,
httpcli_post_should_not_be_called);
grpc_call_credentials_get_request_metadata(
- &exec_ctx, compute_engine_creds, NULL, test_service_url,
+ &exec_ctx, compute_engine_creds, NULL, auth_md_ctx,
on_oauth2_creds_get_metadata_failure, (void *)test_user_data);
grpc_call_credentials_unref(compute_engine_creds);
grpc_httpcli_set_override(NULL, NULL);
@@ -656,6 +668,8 @@ static int refresh_token_httpcli_post_failure(
static void test_refresh_token_creds_success(void) {
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
+ grpc_auth_metadata_context auth_md_ctx = {test_service_url, test_method, NULL,
+ NULL};
grpc_call_credentials *refresh_token_creds =
grpc_google_refresh_token_credentials_create(test_refresh_token_str,
NULL);
@@ -664,7 +678,7 @@ static void test_refresh_token_creds_success(void) {
grpc_httpcli_set_override(httpcli_get_should_not_be_called,
refresh_token_httpcli_post_success);
grpc_call_credentials_get_request_metadata(
- &exec_ctx, refresh_token_creds, NULL, test_service_url,
+ &exec_ctx, refresh_token_creds, NULL, auth_md_ctx,
on_oauth2_creds_get_metadata_success, (void *)test_user_data);
grpc_exec_ctx_flush(&exec_ctx);
@@ -672,7 +686,7 @@ static void test_refresh_token_creds_success(void) {
grpc_httpcli_set_override(httpcli_get_should_not_be_called,
httpcli_post_should_not_be_called);
grpc_call_credentials_get_request_metadata(
- &exec_ctx, refresh_token_creds, NULL, test_service_url,
+ &exec_ctx, refresh_token_creds, NULL, auth_md_ctx,
on_oauth2_creds_get_metadata_success, (void *)test_user_data);
grpc_exec_ctx_flush(&exec_ctx);
@@ -683,13 +697,15 @@ static void test_refresh_token_creds_success(void) {
static void test_refresh_token_creds_failure(void) {
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
+ grpc_auth_metadata_context auth_md_ctx = {test_service_url, test_method, NULL,
+ NULL};
grpc_call_credentials *refresh_token_creds =
grpc_google_refresh_token_credentials_create(test_refresh_token_str,
NULL);
grpc_httpcli_set_override(httpcli_get_should_not_be_called,
refresh_token_httpcli_post_failure);
grpc_call_credentials_get_request_metadata(
- &exec_ctx, refresh_token_creds, NULL, test_service_url,
+ &exec_ctx, refresh_token_creds, NULL, auth_md_ctx,
on_oauth2_creds_get_metadata_failure, (void *)test_user_data);
grpc_call_credentials_unref(refresh_token_creds);
grpc_httpcli_set_override(NULL, NULL);
@@ -772,6 +788,8 @@ static void on_jwt_creds_get_metadata_failure(grpc_exec_ctx *exec_ctx,
static void test_jwt_creds_success(void) {
char *json_key_string = test_json_key_str();
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
+ grpc_auth_metadata_context auth_md_ctx = {test_service_url, test_method, NULL,
+ NULL};
grpc_call_credentials *jwt_creds =
grpc_service_account_jwt_access_credentials_create(
json_key_string, grpc_max_auth_token_lifetime, NULL);
@@ -779,7 +797,7 @@ static void test_jwt_creds_success(void) {
/* First request: jwt_encode_and_sign should be called. */
grpc_jwt_encode_and_sign_set_override(encode_and_sign_jwt_success);
grpc_call_credentials_get_request_metadata(
- &exec_ctx, jwt_creds, NULL, test_service_url,
+ &exec_ctx, jwt_creds, NULL, auth_md_ctx,
on_jwt_creds_get_metadata_success, (void *)test_user_data);
grpc_exec_ctx_flush(&exec_ctx);
@@ -787,15 +805,16 @@ static void test_jwt_creds_success(void) {
grpc_jwt_encode_and_sign_set_override(
encode_and_sign_jwt_should_not_be_called);
grpc_call_credentials_get_request_metadata(
- &exec_ctx, jwt_creds, NULL, test_service_url,
+ &exec_ctx, jwt_creds, NULL, auth_md_ctx,
on_jwt_creds_get_metadata_success, (void *)test_user_data);
grpc_exec_ctx_flush(&exec_ctx);
/* Third request: Different service url so jwt_encode_and_sign should be
called again (no caching). */
+ auth_md_ctx.service_url = other_test_service_url;
grpc_jwt_encode_and_sign_set_override(encode_and_sign_jwt_success);
grpc_call_credentials_get_request_metadata(
- &exec_ctx, jwt_creds, NULL, other_test_service_url,
+ &exec_ctx, jwt_creds, NULL, auth_md_ctx,
on_jwt_creds_get_metadata_success, (void *)test_user_data);
grpc_exec_ctx_flush(&exec_ctx);
@@ -807,13 +826,15 @@ static void test_jwt_creds_success(void) {
static void test_jwt_creds_signing_failure(void) {
char *json_key_string = test_json_key_str();
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
+ grpc_auth_metadata_context auth_md_ctx = {test_service_url, test_method, NULL,
+ NULL};
grpc_call_credentials *jwt_creds =
grpc_service_account_jwt_access_credentials_create(
json_key_string, grpc_max_auth_token_lifetime, NULL);
grpc_jwt_encode_and_sign_set_override(encode_and_sign_jwt_failure);
grpc_call_credentials_get_request_metadata(
- &exec_ctx, jwt_creds, NULL, test_service_url,
+ &exec_ctx, jwt_creds, NULL, auth_md_ctx,
on_jwt_creds_get_metadata_failure, (void *)test_user_data);
gpr_free(json_key_string);
@@ -884,13 +905,17 @@ typedef struct {
static const plugin_metadata plugin_md[] = {{"foo", "bar"}, {"hi", "there"}};
-static void plugin_get_metadata_success(void *state, const char *service_url,
+static void plugin_get_metadata_success(void *state,
+ grpc_auth_metadata_context context,
grpc_credentials_plugin_metadata_cb cb,
void *user_data) {
size_t i;
grpc_metadata md[GPR_ARRAY_SIZE(plugin_md)];
plugin_state *s = (plugin_state *)state;
- GPR_ASSERT(strcmp(service_url, test_service_url) == 0);
+ GPR_ASSERT(strcmp(context.service_url, test_service_url) == 0);
+ GPR_ASSERT(strcmp(context.method_name, test_method) == 0);
+ GPR_ASSERT(context.channel_auth_context == NULL);
+ GPR_ASSERT(context.reserved == NULL);
*s = PLUGIN_GET_METADATA_CALLED_STATE;
for (i = 0; i < GPR_ARRAY_SIZE(plugin_md); i++) {
memset(&md[i], 0, sizeof(grpc_metadata));
@@ -901,11 +926,15 @@ static void plugin_get_metadata_success(void *state, const char *service_url,
cb(user_data, md, GPR_ARRAY_SIZE(md), GRPC_STATUS_OK, NULL);
}
-static void plugin_get_metadata_failure(void *state, const char *service_url,
+static void plugin_get_metadata_failure(void *state,
+ grpc_auth_metadata_context context,
grpc_credentials_plugin_metadata_cb cb,
void *user_data) {
plugin_state *s = (plugin_state *)state;
- GPR_ASSERT(strcmp(service_url, test_service_url) == 0);
+ GPR_ASSERT(strcmp(context.service_url, test_service_url) == 0);
+ GPR_ASSERT(strcmp(context.method_name, test_method) == 0);
+ GPR_ASSERT(context.channel_auth_context == NULL);
+ GPR_ASSERT(context.reserved == NULL);
*s = PLUGIN_GET_METADATA_CALLED_STATE;
cb(user_data, NULL, 0, GRPC_STATUS_UNAUTHENTICATED,
"Could not get metadata for plugin.");
@@ -943,6 +972,8 @@ static void test_metadata_plugin_success(void) {
plugin_state state = PLUGIN_INITIAL_STATE;
grpc_metadata_credentials_plugin plugin;
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
+ grpc_auth_metadata_context auth_md_ctx = {test_service_url, test_method, NULL,
+ NULL};
plugin.state = &state;
plugin.get_metadata = plugin_get_metadata_success;
@@ -951,8 +982,8 @@ static void test_metadata_plugin_success(void) {
creds = grpc_metadata_credentials_create_from_plugin(plugin, NULL);
GPR_ASSERT(state == PLUGIN_INITIAL_STATE);
grpc_call_credentials_get_request_metadata(
- &exec_ctx, creds, NULL, test_service_url,
- on_plugin_metadata_received_success, NULL);
+ &exec_ctx, creds, NULL, auth_md_ctx, on_plugin_metadata_received_success,
+ NULL);
GPR_ASSERT(state == PLUGIN_GET_METADATA_CALLED_STATE);
grpc_call_credentials_release(creds);
GPR_ASSERT(state == PLUGIN_DESTROY_CALLED_STATE);
@@ -964,6 +995,8 @@ static void test_metadata_plugin_failure(void) {
plugin_state state = PLUGIN_INITIAL_STATE;
grpc_metadata_credentials_plugin plugin;
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
+ grpc_auth_metadata_context auth_md_ctx = {test_service_url, test_method, NULL,
+ NULL};
plugin.state = &state;
plugin.get_metadata = plugin_get_metadata_failure;
@@ -972,8 +1005,8 @@ static void test_metadata_plugin_failure(void) {
creds = grpc_metadata_credentials_create_from_plugin(plugin, NULL);
GPR_ASSERT(state == PLUGIN_INITIAL_STATE);
grpc_call_credentials_get_request_metadata(
- &exec_ctx, creds, NULL, test_service_url,
- on_plugin_metadata_received_failure, NULL);
+ &exec_ctx, creds, NULL, auth_md_ctx, on_plugin_metadata_received_failure,
+ NULL);
GPR_ASSERT(state == PLUGIN_GET_METADATA_CALLED_STATE);
grpc_call_credentials_release(creds);
GPR_ASSERT(state == PLUGIN_DESTROY_CALLED_STATE);
diff --git a/test/core/security/oauth2_utils.c b/test/core/security/oauth2_utils.c
index fcfe8a6377..fb62bf4134 100644
--- a/test/core/security/oauth2_utils.c
+++ b/test/core/security/oauth2_utils.c
@@ -80,13 +80,16 @@ char *grpc_test_fetch_oauth2_token_with_credentials(
oauth2_request request;
grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
grpc_closure do_nothing_closure;
+ grpc_auth_metadata_context null_ctx = {"", "", NULL, NULL};
+
grpc_pollset_init(&request.pollset);
request.is_done = 0;
grpc_closure_init(&do_nothing_closure, do_nothing, NULL);
grpc_call_credentials_get_request_metadata(&exec_ctx, creds, &request.pollset,
- "", on_oauth2_response, &request);
+ null_ctx, on_oauth2_response,
+ &request);
grpc_exec_ctx_finish(&exec_ctx);
diff --git a/test/core/security/print_google_default_creds_token.c b/test/core/security/print_google_default_creds_token.c
index eb63724715..50fe61c996 100644
--- a/test/core/security/print_google_default_creds_token.c
+++ b/test/core/security/print_google_default_creds_token.c
@@ -74,10 +74,13 @@ int main(int argc, char **argv) {
synchronizer sync;
grpc_channel_credentials *creds = NULL;
char *service_url = "https://test.foo.google.com/Foo";
+ grpc_auth_metadata_context context;
gpr_cmdline *cl = gpr_cmdline_create("print_google_default_creds_token");
gpr_cmdline_add_string(cl, "service_url",
"Service URL for the token request.", &service_url);
gpr_cmdline_parse(cl, argc, argv);
+ memset(&context, 0, sizeof(context));
+ context.service_url = service_url;
grpc_init();
@@ -93,7 +96,7 @@ int main(int argc, char **argv) {
grpc_call_credentials_get_request_metadata(
&exec_ctx, ((grpc_composite_channel_credentials *)creds)->call_creds,
- &sync.pollset, service_url, on_metadata_response, &sync);
+ &sync.pollset, context, on_metadata_response, &sync);
gpr_mu_lock(GRPC_POLLSET_MU(&sync.pollset));
while (!sync.is_done) {
diff --git a/test/core/support/avl_test.c b/test/core/support/avl_test.c
new file mode 100644
index 0000000000..6530fe4269
--- /dev/null
+++ b/test/core/support/avl_test.c
@@ -0,0 +1,3671 @@
+/*
+ *
+ * Copyright 2015, Google Inc.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ *
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following disclaimer
+ * in the documentation and/or other materials provided with the
+ * distribution.
+ * * Neither the name of Google Inc. nor the names of its
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#include <grpc/support/avl.h>
+
+#include <stdio.h>
+#include <string.h>
+
+#include <grpc/support/alloc.h>
+#include <grpc/support/log.h>
+#include <grpc/support/useful.h>
+
+#include "test/core/util/test_config.h"
+
+static int *box(int x) {
+ int *b = gpr_malloc(sizeof(*b));
+ *b = x;
+ return b;
+}
+
+static long int_compare(void *int1, void *int2) {
+ return (*(int *)int1) - (*(int *)int2);
+}
+static void *int_copy(void *p) { return box(*(int *)p); }
+
+static const gpr_avl_vtable int_int_vtable = {gpr_free, int_copy, int_compare,
+ gpr_free, int_copy};
+
+static void check_get(gpr_avl avl, int key, int value) {
+ int *k = box(key);
+ GPR_ASSERT(*(int *)gpr_avl_get(avl, k) == value);
+ gpr_free(k);
+}
+
+static void check_negget(gpr_avl avl, int key) {
+ int *k = box(key);
+ GPR_ASSERT(gpr_avl_get(avl, k) == NULL);
+ gpr_free(k);
+}
+
+static gpr_avl remove_int(gpr_avl avl, int key) {
+ int *k = box(key);
+ avl = gpr_avl_remove(avl, k);
+ gpr_free(k);
+ return avl;
+}
+
+static void test_get(void) {
+ gpr_avl avl;
+ gpr_log(GPR_DEBUG, "test_get");
+ avl = gpr_avl_create(&int_int_vtable);
+ avl = gpr_avl_add(avl, box(1), box(11));
+ avl = gpr_avl_add(avl, box(2), box(22));
+ avl = gpr_avl_add(avl, box(3), box(33));
+ check_get(avl, 1, 11);
+ check_get(avl, 2, 22);
+ check_get(avl, 3, 33);
+ check_negget(avl, 4);
+ gpr_avl_unref(avl);
+}
+
+static void test_ll(void) {
+ gpr_avl avl;
+ gpr_log(GPR_DEBUG, "test_ll");
+ avl = gpr_avl_create(&int_int_vtable);
+ avl = gpr_avl_add(avl, box(5), box(1));
+ avl = gpr_avl_add(avl, box(4), box(2));
+ avl = gpr_avl_add(avl, box(3), box(3));
+ GPR_ASSERT(*(int *)avl.root->key == 4);
+ GPR_ASSERT(*(int *)avl.root->left->key == 3);
+ GPR_ASSERT(*(int *)avl.root->right->key == 5);
+ gpr_avl_unref(avl);
+}
+
+static void test_lr(void) {
+ gpr_avl avl;
+ gpr_log(GPR_DEBUG, "test_lr");
+ avl = gpr_avl_create(&int_int_vtable);
+ avl = gpr_avl_add(avl, box(5), box(1));
+ avl = gpr_avl_add(avl, box(3), box(2));
+ avl = gpr_avl_add(avl, box(4), box(3));
+ GPR_ASSERT(*(int *)avl.root->key == 4);
+ GPR_ASSERT(*(int *)avl.root->left->key == 3);
+ GPR_ASSERT(*(int *)avl.root->right->key == 5);
+ gpr_avl_unref(avl);
+}
+
+static void test_rr(void) {
+ gpr_avl avl;
+ gpr_log(GPR_DEBUG, "test_rr");
+ avl = gpr_avl_create(&int_int_vtable);
+ avl = gpr_avl_add(avl, box(3), box(1));
+ avl = gpr_avl_add(avl, box(4), box(2));
+ avl = gpr_avl_add(avl, box(5), box(3));
+ GPR_ASSERT(*(int *)avl.root->key == 4);
+ GPR_ASSERT(*(int *)avl.root->left->key == 3);
+ GPR_ASSERT(*(int *)avl.root->right->key == 5);
+ gpr_avl_unref(avl);
+}
+
+static void test_rl(void) {
+ gpr_avl avl;
+ gpr_log(GPR_DEBUG, "test_rl");
+ avl = gpr_avl_create(&int_int_vtable);
+ avl = gpr_avl_add(avl, box(3), box(1));
+ avl = gpr_avl_add(avl, box(5), box(2));
+ avl = gpr_avl_add(avl, box(4), box(3));
+ GPR_ASSERT(*(int *)avl.root->key == 4);
+ GPR_ASSERT(*(int *)avl.root->left->key == 3);
+ GPR_ASSERT(*(int *)avl.root->right->key == 5);
+ gpr_avl_unref(avl);
+}
+
+static void test_unbalanced(void) {
+ gpr_avl avl;
+ gpr_log(GPR_DEBUG, "test_unbalanced");
+ avl = gpr_avl_create(&int_int_vtable);
+ avl = gpr_avl_add(avl, box(5), box(1));
+ avl = gpr_avl_add(avl, box(4), box(2));
+ avl = gpr_avl_add(avl, box(3), box(3));
+ avl = gpr_avl_add(avl, box(2), box(4));
+ avl = gpr_avl_add(avl, box(1), box(5));
+ GPR_ASSERT(*(int *)avl.root->key == 4);
+ GPR_ASSERT(*(int *)avl.root->left->key == 2);
+ GPR_ASSERT(*(int *)avl.root->left->left->key == 1);
+ GPR_ASSERT(*(int *)avl.root->left->right->key == 3);
+ GPR_ASSERT(*(int *)avl.root->right->key == 5);
+ gpr_avl_unref(avl);
+}
+
+static void test_replace(void) {
+ gpr_avl avl;
+ gpr_log(GPR_DEBUG, "test_replace");
+ avl = gpr_avl_create(&int_int_vtable);
+ avl = gpr_avl_add(avl, box(1), box(1));
+ avl = gpr_avl_add(avl, box(1), box(2));
+ check_get(avl, 1, 2);
+ check_negget(avl, 2);
+ gpr_avl_unref(avl);
+}
+
+static void test_remove(void) {
+ gpr_avl avl;
+ gpr_avl avl3, avl4, avl5, avln;
+ gpr_log(GPR_DEBUG, "test_remove");
+ avl = gpr_avl_create(&int_int_vtable);
+ avl = gpr_avl_add(avl, box(3), box(1));
+ avl = gpr_avl_add(avl, box(4), box(2));
+ avl = gpr_avl_add(avl, box(5), box(3));
+
+ avl3 = remove_int(gpr_avl_ref(avl), 3);
+ avl4 = remove_int(gpr_avl_ref(avl), 4);
+ avl5 = remove_int(gpr_avl_ref(avl), 5);
+ avln = remove_int(gpr_avl_ref(avl), 1);
+
+ gpr_avl_unref(avl);
+
+ check_negget(avl3, 3);
+ check_get(avl3, 4, 2);
+ check_get(avl3, 5, 3);
+ gpr_avl_unref(avl3);
+
+ check_get(avl4, 3, 1);
+ check_negget(avl4, 4);
+ check_get(avl4, 5, 3);
+ gpr_avl_unref(avl4);
+
+ check_get(avl5, 3, 1);
+ check_get(avl5, 4, 2);
+ check_negget(avl5, 5);
+ gpr_avl_unref(avl5);
+
+ check_get(avln, 3, 1);
+ check_get(avln, 4, 2);
+ check_get(avln, 5, 3);
+ gpr_avl_unref(avln);
+}
+
+static void test_badcase1(void) {
+ gpr_avl avl;
+
+ gpr_log(GPR_DEBUG, "test_badcase1");
+
+ avl = gpr_avl_create(&int_int_vtable);
+ avl = gpr_avl_add(avl, box(88), box(1));
+ avl = remove_int(avl, 643);
+ avl = remove_int(avl, 983);
+ avl = gpr_avl_add(avl, box(985), box(4));
+ avl = gpr_avl_add(avl, box(640), box(5));
+ avl = gpr_avl_add(avl, box(41), box(6));
+ avl = gpr_avl_add(avl, box(112), box(7));
+ avl = gpr_avl_add(avl, box(342), box(8));
+ avl = remove_int(avl, 1013);
+ avl = gpr_avl_add(avl, box(434), box(10));
+ avl = gpr_avl_add(avl, box(520), box(11));
+ avl = gpr_avl_add(avl, box(231), box(12));
+ avl = gpr_avl_add(avl, box(852), box(13));
+ avl = remove_int(avl, 461);
+ avl = gpr_avl_add(avl, box(108), box(15));
+ avl = gpr_avl_add(avl, box(806), box(16));
+ avl = gpr_avl_add(avl, box(827), box(17));
+ avl = remove_int(avl, 796);
+ avl = gpr_avl_add(avl, box(340), box(19));
+ avl = gpr_avl_add(avl, box(498), box(20));
+ avl = gpr_avl_add(avl, box(203), box(21));
+ avl = gpr_avl_add(avl, box(751), box(22));
+ avl = gpr_avl_add(avl, box(150), box(23));
+ avl = remove_int(avl, 237);
+ avl = gpr_avl_add(avl, box(830), box(25));
+ avl = remove_int(avl, 1007);
+ avl = remove_int(avl, 394);
+ avl = gpr_avl_add(avl, box(65), box(28));
+ avl = remove_int(avl, 904);
+ avl = remove_int(avl, 123);
+ avl = gpr_avl_add(avl, box(238), box(31));
+ avl = gpr_avl_add(avl, box(184), box(32));
+ avl = remove_int(avl, 331);
+ avl = gpr_avl_add(avl, box(827), box(34));
+
+ check_get(avl, 830, 25);
+
+ gpr_avl_unref(avl);
+}
+
+static void test_badcase2(void) {
+ gpr_avl avl;
+
+ gpr_log(GPR_DEBUG, "test_badcase2");
+
+ avl = gpr_avl_create(&int_int_vtable);
+ avl = gpr_avl_add(avl, box(288), box(1));
+ avl = remove_int(avl, 415);
+ avl = gpr_avl_add(avl, box(953), box(3));
+ avl = gpr_avl_add(avl, box(101), box(4));
+ avl = gpr_avl_add(avl, box(516), box(5));
+ avl = gpr_avl_add(avl, box(547), box(6));
+ avl = gpr_avl_add(avl, box(467), box(7));
+ avl = gpr_avl_add(avl, box(793), box(8));
+ avl = remove_int(avl, 190);
+ avl = gpr_avl_add(avl, box(687), box(10));
+ avl = gpr_avl_add(avl, box(242), box(11));
+ avl = gpr_avl_add(avl, box(142), box(12));
+ avl = remove_int(avl, 705);
+ avl = remove_int(avl, 578);
+ avl = remove_int(avl, 767);
+ avl = remove_int(avl, 183);
+ avl = gpr_avl_add(avl, box(950), box(17));
+ avl = gpr_avl_add(avl, box(622), box(18));
+ avl = remove_int(avl, 513);
+ avl = remove_int(avl, 429);
+ avl = gpr_avl_add(avl, box(205), box(21));
+ avl = remove_int(avl, 663);
+ avl = remove_int(avl, 953);
+ avl = remove_int(avl, 892);
+ avl = gpr_avl_add(avl, box(236), box(25));
+ avl = remove_int(avl, 982);
+ avl = remove_int(avl, 201);
+ avl = remove_int(avl, 684);
+ avl = gpr_avl_add(avl, box(572), box(29));
+ avl = remove_int(avl, 817);
+ avl = gpr_avl_add(avl, box(970), box(31));
+ avl = remove_int(avl, 347);
+ avl = remove_int(avl, 574);
+ avl = gpr_avl_add(avl, box(752), box(34));
+ avl = gpr_avl_add(avl, box(670), box(35));
+ avl = gpr_avl_add(avl, box(69), box(36));
+ avl = remove_int(avl, 111);
+ avl = remove_int(avl, 523);
+ avl = gpr_avl_add(avl, box(141), box(39));
+ avl = remove_int(avl, 159);
+ avl = gpr_avl_add(avl, box(947), box(41));
+ avl = gpr_avl_add(avl, box(855), box(42));
+ avl = remove_int(avl, 218);
+ avl = remove_int(avl, 6);
+ avl = gpr_avl_add(avl, box(753), box(45));
+ avl = remove_int(avl, 82);
+ avl = remove_int(avl, 799);
+ avl = gpr_avl_add(avl, box(572), box(48));
+ avl = remove_int(avl, 376);
+ avl = remove_int(avl, 413);
+ avl = gpr_avl_add(avl, box(458), box(51));
+ avl = remove_int(avl, 897);
+ avl = gpr_avl_add(avl, box(191), box(53));
+ avl = gpr_avl_add(avl, box(609), box(54));
+ avl = remove_int(avl, 787);
+ avl = remove_int(avl, 710);
+ avl = remove_int(avl, 886);
+ avl = remove_int(avl, 835);
+ avl = remove_int(avl, 33);
+ avl = gpr_avl_add(avl, box(871), box(60));
+ avl = remove_int(avl, 641);
+ avl = gpr_avl_add(avl, box(462), box(62));
+ avl = remove_int(avl, 359);
+ avl = remove_int(avl, 767);
+ avl = gpr_avl_add(avl, box(310), box(65));
+ avl = remove_int(avl, 757);
+ avl = remove_int(avl, 639);
+ avl = remove_int(avl, 314);
+ avl = gpr_avl_add(avl, box(2), box(69));
+ avl = remove_int(avl, 138);
+ avl = gpr_avl_add(avl, box(669), box(71));
+ avl = remove_int(avl, 477);
+ avl = gpr_avl_add(avl, box(366), box(73));
+ avl = gpr_avl_add(avl, box(612), box(74));
+ avl = gpr_avl_add(avl, box(106), box(75));
+ avl = remove_int(avl, 161);
+ avl = gpr_avl_add(avl, box(388), box(77));
+ avl = gpr_avl_add(avl, box(141), box(78));
+ avl = remove_int(avl, 633);
+ avl = remove_int(avl, 459);
+ avl = gpr_avl_add(avl, box(40), box(81));
+ avl = remove_int(avl, 689);
+ avl = gpr_avl_add(avl, box(823), box(83));
+ avl = remove_int(avl, 485);
+ avl = gpr_avl_add(avl, box(903), box(85));
+ avl = gpr_avl_add(avl, box(592), box(86));
+ avl = remove_int(avl, 448);
+ avl = gpr_avl_add(avl, box(56), box(88));
+ avl = remove_int(avl, 333);
+ avl = gpr_avl_add(avl, box(189), box(90));
+ avl = gpr_avl_add(avl, box(103), box(91));
+ avl = remove_int(avl, 164);
+ avl = remove_int(avl, 974);
+ avl = gpr_avl_add(avl, box(215), box(94));
+ avl = remove_int(avl, 189);
+ avl = remove_int(avl, 504);
+ avl = gpr_avl_add(avl, box(868), box(97));
+ avl = remove_int(avl, 909);
+ avl = remove_int(avl, 148);
+ avl = remove_int(avl, 469);
+ avl = gpr_avl_add(avl, box(994), box(101));
+ avl = gpr_avl_add(avl, box(576), box(102));
+ avl = remove_int(avl, 82);
+ avl = remove_int(avl, 209);
+ avl = gpr_avl_add(avl, box(276), box(105));
+ avl = remove_int(avl, 856);
+ avl = gpr_avl_add(avl, box(750), box(107));
+ avl = remove_int(avl, 871);
+ avl = gpr_avl_add(avl, box(301), box(109));
+ avl = remove_int(avl, 260);
+ avl = remove_int(avl, 737);
+ avl = remove_int(avl, 719);
+ avl = gpr_avl_add(avl, box(933), box(113));
+ avl = gpr_avl_add(avl, box(225), box(114));
+ avl = gpr_avl_add(avl, box(975), box(115));
+ avl = gpr_avl_add(avl, box(86), box(116));
+ avl = remove_int(avl, 732);
+ avl = gpr_avl_add(avl, box(340), box(118));
+ avl = gpr_avl_add(avl, box(271), box(119));
+ avl = remove_int(avl, 206);
+ avl = gpr_avl_add(avl, box(949), box(121));
+ avl = gpr_avl_add(avl, box(927), box(122));
+ avl = gpr_avl_add(avl, box(34), box(123));
+ avl = gpr_avl_add(avl, box(351), box(124));
+ avl = remove_int(avl, 836);
+ avl = gpr_avl_add(avl, box(825), box(126));
+ avl = gpr_avl_add(avl, box(352), box(127));
+ avl = remove_int(avl, 107);
+ avl = remove_int(avl, 101);
+ avl = gpr_avl_add(avl, box(320), box(130));
+ avl = gpr_avl_add(avl, box(3), box(131));
+ avl = remove_int(avl, 998);
+ avl = remove_int(avl, 44);
+ avl = gpr_avl_add(avl, box(525), box(134));
+ avl = gpr_avl_add(avl, box(864), box(135));
+ avl = gpr_avl_add(avl, box(863), box(136));
+ avl = remove_int(avl, 770);
+ avl = gpr_avl_add(avl, box(440), box(138));
+ avl = remove_int(avl, 516);
+ avl = gpr_avl_add(avl, box(116), box(140));
+ avl = remove_int(avl, 380);
+ avl = gpr_avl_add(avl, box(878), box(142));
+ avl = remove_int(avl, 439);
+ avl = gpr_avl_add(avl, box(994), box(144));
+ avl = remove_int(avl, 294);
+ avl = remove_int(avl, 593);
+ avl = gpr_avl_add(avl, box(696), box(147));
+ avl = remove_int(avl, 8);
+ avl = gpr_avl_add(avl, box(881), box(149));
+ avl = remove_int(avl, 32);
+ avl = remove_int(avl, 242);
+ avl = gpr_avl_add(avl, box(487), box(152));
+ avl = gpr_avl_add(avl, box(637), box(153));
+ avl = gpr_avl_add(avl, box(793), box(154));
+ avl = gpr_avl_add(avl, box(696), box(155));
+ avl = remove_int(avl, 458);
+ avl = gpr_avl_add(avl, box(828), box(157));
+ avl = remove_int(avl, 784);
+ avl = remove_int(avl, 274);
+ avl = gpr_avl_add(avl, box(783), box(160));
+ avl = remove_int(avl, 21);
+ avl = gpr_avl_add(avl, box(866), box(162));
+ avl = remove_int(avl, 919);
+ avl = gpr_avl_add(avl, box(435), box(164));
+ avl = remove_int(avl, 385);
+ avl = gpr_avl_add(avl, box(475), box(166));
+ avl = remove_int(avl, 339);
+ avl = gpr_avl_add(avl, box(615), box(168));
+ avl = remove_int(avl, 866);
+ avl = remove_int(avl, 82);
+ avl = remove_int(avl, 271);
+ avl = gpr_avl_add(avl, box(590), box(172));
+ avl = gpr_avl_add(avl, box(852), box(173));
+ avl = remove_int(avl, 318);
+ avl = remove_int(avl, 82);
+ avl = gpr_avl_add(avl, box(672), box(176));
+ avl = remove_int(avl, 430);
+ avl = gpr_avl_add(avl, box(821), box(178));
+ avl = gpr_avl_add(avl, box(365), box(179));
+ avl = remove_int(avl, 78);
+ avl = gpr_avl_add(avl, box(700), box(181));
+ avl = gpr_avl_add(avl, box(353), box(182));
+ avl = remove_int(avl, 492);
+ avl = gpr_avl_add(avl, box(991), box(184));
+ avl = remove_int(avl, 330);
+ avl = gpr_avl_add(avl, box(873), box(186));
+ avl = remove_int(avl, 589);
+ avl = gpr_avl_add(avl, box(676), box(188));
+ avl = gpr_avl_add(avl, box(790), box(189));
+ avl = remove_int(avl, 521);
+ avl = remove_int(avl, 47);
+ avl = gpr_avl_add(avl, box(976), box(192));
+ avl = gpr_avl_add(avl, box(683), box(193));
+ avl = remove_int(avl, 803);
+ avl = remove_int(avl, 1006);
+ avl = gpr_avl_add(avl, box(775), box(196));
+ avl = gpr_avl_add(avl, box(411), box(197));
+ avl = gpr_avl_add(avl, box(697), box(198));
+ avl = remove_int(avl, 50);
+ avl = gpr_avl_add(avl, box(213), box(200));
+ avl = remove_int(avl, 714);
+ avl = gpr_avl_add(avl, box(981), box(202));
+ avl = gpr_avl_add(avl, box(502), box(203));
+ avl = gpr_avl_add(avl, box(697), box(204));
+ avl = gpr_avl_add(avl, box(603), box(205));
+ avl = gpr_avl_add(avl, box(117), box(206));
+ avl = remove_int(avl, 363);
+ avl = gpr_avl_add(avl, box(104), box(208));
+ avl = remove_int(avl, 842);
+ avl = gpr_avl_add(avl, box(48), box(210));
+ avl = remove_int(avl, 764);
+ avl = gpr_avl_add(avl, box(482), box(212));
+ avl = gpr_avl_add(avl, box(928), box(213));
+ avl = gpr_avl_add(avl, box(30), box(214));
+ avl = gpr_avl_add(avl, box(820), box(215));
+ avl = gpr_avl_add(avl, box(334), box(216));
+ avl = remove_int(avl, 306);
+ avl = gpr_avl_add(avl, box(789), box(218));
+ avl = remove_int(avl, 924);
+ avl = gpr_avl_add(avl, box(53), box(220));
+ avl = remove_int(avl, 657);
+ avl = gpr_avl_add(avl, box(130), box(222));
+ avl = gpr_avl_add(avl, box(239), box(223));
+ avl = remove_int(avl, 20);
+ avl = gpr_avl_add(avl, box(117), box(225));
+ avl = remove_int(avl, 882);
+ avl = remove_int(avl, 891);
+ avl = gpr_avl_add(avl, box(9), box(228));
+ avl = gpr_avl_add(avl, box(496), box(229));
+ avl = gpr_avl_add(avl, box(750), box(230));
+ avl = gpr_avl_add(avl, box(283), box(231));
+ avl = gpr_avl_add(avl, box(802), box(232));
+ avl = remove_int(avl, 352);
+ avl = gpr_avl_add(avl, box(374), box(234));
+ avl = gpr_avl_add(avl, box(6), box(235));
+ avl = gpr_avl_add(avl, box(756), box(236));
+ avl = gpr_avl_add(avl, box(597), box(237));
+ avl = gpr_avl_add(avl, box(661), box(238));
+ avl = remove_int(avl, 96);
+ avl = gpr_avl_add(avl, box(894), box(240));
+ avl = remove_int(avl, 749);
+ avl = gpr_avl_add(avl, box(71), box(242));
+ avl = remove_int(avl, 68);
+ avl = gpr_avl_add(avl, box(388), box(244));
+ avl = remove_int(avl, 119);
+ avl = remove_int(avl, 856);
+ avl = gpr_avl_add(avl, box(176), box(247));
+ avl = gpr_avl_add(avl, box(993), box(248));
+ avl = remove_int(avl, 178);
+ avl = remove_int(avl, 781);
+ avl = remove_int(avl, 771);
+ avl = remove_int(avl, 848);
+ avl = remove_int(avl, 376);
+ avl = remove_int(avl, 157);
+ avl = remove_int(avl, 142);
+ avl = remove_int(avl, 686);
+ avl = gpr_avl_add(avl, box(779), box(257));
+ avl = gpr_avl_add(avl, box(484), box(258));
+ avl = remove_int(avl, 837);
+ avl = gpr_avl_add(avl, box(388), box(260));
+ avl = remove_int(avl, 987);
+ avl = gpr_avl_add(avl, box(336), box(262));
+ avl = remove_int(avl, 855);
+ avl = gpr_avl_add(avl, box(668), box(264));
+ avl = remove_int(avl, 648);
+ avl = gpr_avl_add(avl, box(193), box(266));
+ avl = remove_int(avl, 939);
+ avl = gpr_avl_add(avl, box(740), box(268));
+ avl = gpr_avl_add(avl, box(503), box(269));
+ avl = gpr_avl_add(avl, box(765), box(270));
+ avl = remove_int(avl, 924);
+ avl = remove_int(avl, 513);
+ avl = gpr_avl_add(avl, box(161), box(273));
+ avl = gpr_avl_add(avl, box(502), box(274));
+ avl = gpr_avl_add(avl, box(846), box(275));
+ avl = remove_int(avl, 931);
+ avl = gpr_avl_add(avl, box(87), box(277));
+ avl = gpr_avl_add(avl, box(949), box(278));
+ avl = gpr_avl_add(avl, box(548), box(279));
+ avl = gpr_avl_add(avl, box(951), box(280));
+ avl = remove_int(avl, 1018);
+ avl = remove_int(avl, 568);
+ avl = gpr_avl_add(avl, box(138), box(283));
+ avl = gpr_avl_add(avl, box(202), box(284));
+ avl = gpr_avl_add(avl, box(157), box(285));
+ avl = gpr_avl_add(avl, box(264), box(286));
+ avl = gpr_avl_add(avl, box(370), box(287));
+ avl = remove_int(avl, 736);
+ avl = remove_int(avl, 751);
+ avl = remove_int(avl, 506);
+ avl = remove_int(avl, 81);
+ avl = remove_int(avl, 358);
+ avl = remove_int(avl, 657);
+ avl = remove_int(avl, 86);
+ avl = gpr_avl_add(avl, box(876), box(295));
+ avl = remove_int(avl, 354);
+ avl = gpr_avl_add(avl, box(134), box(297));
+ avl = remove_int(avl, 781);
+ avl = remove_int(avl, 183);
+ avl = gpr_avl_add(avl, box(914), box(300));
+ avl = remove_int(avl, 926);
+ avl = remove_int(avl, 398);
+ avl = remove_int(avl, 932);
+ avl = remove_int(avl, 804);
+ avl = remove_int(avl, 326);
+ avl = gpr_avl_add(avl, box(208), box(306));
+ avl = gpr_avl_add(avl, box(699), box(307));
+ avl = remove_int(avl, 576);
+ avl = remove_int(avl, 850);
+ avl = remove_int(avl, 514);
+ avl = remove_int(avl, 676);
+ avl = remove_int(avl, 549);
+ avl = remove_int(avl, 767);
+ avl = gpr_avl_add(avl, box(58), box(314));
+ avl = gpr_avl_add(avl, box(265), box(315));
+ avl = gpr_avl_add(avl, box(268), box(316));
+ avl = gpr_avl_add(avl, box(103), box(317));
+ avl = gpr_avl_add(avl, box(440), box(318));
+ avl = remove_int(avl, 777);
+ avl = gpr_avl_add(avl, box(670), box(320));
+ avl = remove_int(avl, 506);
+ avl = remove_int(avl, 487);
+ avl = gpr_avl_add(avl, box(421), box(323));
+ avl = remove_int(avl, 514);
+ avl = gpr_avl_add(avl, box(701), box(325));
+ avl = remove_int(avl, 949);
+ avl = remove_int(avl, 872);
+ avl = remove_int(avl, 139);
+ avl = gpr_avl_add(avl, box(781), box(329));
+ avl = gpr_avl_add(avl, box(543), box(330));
+ avl = gpr_avl_add(avl, box(147), box(331));
+ avl = remove_int(avl, 190);
+ avl = gpr_avl_add(avl, box(453), box(333));
+ avl = remove_int(avl, 262);
+ avl = remove_int(avl, 850);
+ avl = remove_int(avl, 286);
+ avl = remove_int(avl, 787);
+ avl = gpr_avl_add(avl, box(514), box(338));
+ avl = remove_int(avl, 812);
+ avl = gpr_avl_add(avl, box(431), box(340));
+ avl = gpr_avl_add(avl, box(8), box(341));
+ avl = remove_int(avl, 843);
+ avl = gpr_avl_add(avl, box(831), box(343));
+ avl = remove_int(avl, 472);
+ avl = remove_int(avl, 157);
+ avl = gpr_avl_add(avl, box(612), box(346));
+ avl = gpr_avl_add(avl, box(802), box(347));
+ avl = remove_int(avl, 554);
+ avl = gpr_avl_add(avl, box(409), box(349));
+ avl = gpr_avl_add(avl, box(439), box(350));
+ avl = gpr_avl_add(avl, box(725), box(351));
+ avl = gpr_avl_add(avl, box(568), box(352));
+ avl = remove_int(avl, 475);
+ avl = remove_int(avl, 672);
+ avl = remove_int(avl, 62);
+ avl = remove_int(avl, 753);
+ avl = gpr_avl_add(avl, box(435), box(357));
+ avl = gpr_avl_add(avl, box(950), box(358));
+ avl = gpr_avl_add(avl, box(532), box(359));
+ avl = gpr_avl_add(avl, box(832), box(360));
+ avl = remove_int(avl, 390);
+ avl = gpr_avl_add(avl, box(993), box(362));
+ avl = remove_int(avl, 198);
+ avl = remove_int(avl, 401);
+ avl = gpr_avl_add(avl, box(316), box(365));
+ avl = remove_int(avl, 843);
+ avl = gpr_avl_add(avl, box(541), box(367));
+ avl = gpr_avl_add(avl, box(505), box(368));
+ avl = remove_int(avl, 445);
+ avl = remove_int(avl, 256);
+ avl = gpr_avl_add(avl, box(232), box(371));
+ avl = remove_int(avl, 577);
+ avl = remove_int(avl, 558);
+ avl = gpr_avl_add(avl, box(910), box(374));
+ avl = remove_int(avl, 902);
+ avl = remove_int(avl, 755);
+ avl = remove_int(avl, 114);
+ avl = remove_int(avl, 438);
+ avl = remove_int(avl, 224);
+ avl = gpr_avl_add(avl, box(920), box(380));
+ avl = gpr_avl_add(avl, box(655), box(381));
+ avl = remove_int(avl, 557);
+ avl = remove_int(avl, 102);
+ avl = remove_int(avl, 165);
+ avl = gpr_avl_add(avl, box(191), box(385));
+ avl = remove_int(avl, 30);
+ avl = gpr_avl_add(avl, box(406), box(387));
+ avl = gpr_avl_add(avl, box(66), box(388));
+ avl = gpr_avl_add(avl, box(87), box(389));
+ avl = remove_int(avl, 7);
+ avl = remove_int(avl, 671);
+ avl = gpr_avl_add(avl, box(234), box(392));
+ avl = remove_int(avl, 463);
+ avl = gpr_avl_add(avl, box(75), box(394));
+ avl = gpr_avl_add(avl, box(487), box(395));
+ avl = remove_int(avl, 203);
+ avl = gpr_avl_add(avl, box(711), box(397));
+ avl = remove_int(avl, 291);
+ avl = remove_int(avl, 798);
+ avl = remove_int(avl, 337);
+ avl = gpr_avl_add(avl, box(877), box(401));
+ avl = gpr_avl_add(avl, box(388), box(402));
+ avl = remove_int(avl, 975);
+ avl = gpr_avl_add(avl, box(200), box(404));
+ avl = gpr_avl_add(avl, box(408), box(405));
+ avl = gpr_avl_add(avl, box(3), box(406));
+ avl = gpr_avl_add(avl, box(971), box(407));
+ avl = remove_int(avl, 841);
+ avl = remove_int(avl, 910);
+ avl = remove_int(avl, 74);
+ avl = remove_int(avl, 888);
+ avl = gpr_avl_add(avl, box(492), box(412));
+ avl = remove_int(avl, 14);
+ avl = remove_int(avl, 364);
+ avl = gpr_avl_add(avl, box(215), box(415));
+ avl = remove_int(avl, 778);
+ avl = remove_int(avl, 45);
+ avl = gpr_avl_add(avl, box(328), box(418));
+ avl = gpr_avl_add(avl, box(597), box(419));
+ avl = remove_int(avl, 34);
+ avl = gpr_avl_add(avl, box(736), box(421));
+ avl = remove_int(avl, 37);
+ avl = gpr_avl_add(avl, box(275), box(423));
+ avl = gpr_avl_add(avl, box(70), box(424));
+ avl = gpr_avl_add(avl, box(771), box(425));
+ avl = remove_int(avl, 536);
+ avl = remove_int(avl, 421);
+ avl = gpr_avl_add(avl, box(186), box(428));
+ avl = gpr_avl_add(avl, box(788), box(429));
+ avl = gpr_avl_add(avl, box(224), box(430));
+ avl = remove_int(avl, 228);
+ avl = gpr_avl_add(avl, box(48), box(432));
+ avl = gpr_avl_add(avl, box(120), box(433));
+ avl = gpr_avl_add(avl, box(269), box(434));
+ avl = gpr_avl_add(avl, box(904), box(435));
+ avl = remove_int(avl, 699);
+ avl = gpr_avl_add(avl, box(340), box(437));
+ avl = remove_int(avl, 276);
+ avl = gpr_avl_add(avl, box(591), box(439));
+ avl = gpr_avl_add(avl, box(778), box(440));
+ avl = remove_int(avl, 490);
+ avl = remove_int(avl, 973);
+ avl = gpr_avl_add(avl, box(294), box(443));
+ avl = gpr_avl_add(avl, box(323), box(444));
+ avl = remove_int(avl, 685);
+ avl = gpr_avl_add(avl, box(38), box(446));
+ avl = gpr_avl_add(avl, box(525), box(447));
+ avl = remove_int(avl, 162);
+ avl = gpr_avl_add(avl, box(462), box(449));
+ avl = gpr_avl_add(avl, box(340), box(450));
+ avl = remove_int(avl, 734);
+ avl = remove_int(avl, 959);
+ avl = gpr_avl_add(avl, box(752), box(453));
+ avl = gpr_avl_add(avl, box(667), box(454));
+ avl = remove_int(avl, 558);
+ avl = remove_int(avl, 657);
+ avl = gpr_avl_add(avl, box(711), box(457));
+ avl = remove_int(avl, 937);
+ avl = gpr_avl_add(avl, box(741), box(459));
+ avl = gpr_avl_add(avl, box(40), box(460));
+ avl = remove_int(avl, 784);
+ avl = gpr_avl_add(avl, box(292), box(462));
+ avl = remove_int(avl, 164);
+ avl = remove_int(avl, 931);
+ avl = remove_int(avl, 886);
+ avl = gpr_avl_add(avl, box(968), box(466));
+ avl = remove_int(avl, 263);
+ avl = gpr_avl_add(avl, box(647), box(468));
+ avl = gpr_avl_add(avl, box(92), box(469));
+ avl = remove_int(avl, 310);
+ avl = gpr_avl_add(avl, box(711), box(471));
+ avl = gpr_avl_add(avl, box(675), box(472));
+ avl = remove_int(avl, 549);
+ avl = gpr_avl_add(avl, box(380), box(474));
+ avl = remove_int(avl, 825);
+ avl = gpr_avl_add(avl, box(668), box(476));
+ avl = remove_int(avl, 498);
+ avl = gpr_avl_add(avl, box(870), box(478));
+ avl = gpr_avl_add(avl, box(391), box(479));
+ avl = gpr_avl_add(avl, box(264), box(480));
+ avl = remove_int(avl, 1);
+ avl = remove_int(avl, 849);
+ avl = remove_int(avl, 88);
+ avl = remove_int(avl, 255);
+ avl = remove_int(avl, 763);
+ avl = remove_int(avl, 831);
+ avl = gpr_avl_add(avl, box(508), box(487));
+ avl = remove_int(avl, 849);
+ avl = remove_int(avl, 47);
+ avl = gpr_avl_add(avl, box(299), box(490));
+ avl = remove_int(avl, 625);
+ avl = remove_int(avl, 433);
+ avl = remove_int(avl, 904);
+ avl = remove_int(avl, 761);
+ avl = gpr_avl_add(avl, box(33), box(495));
+ avl = gpr_avl_add(avl, box(524), box(496));
+ avl = remove_int(avl, 210);
+ avl = remove_int(avl, 299);
+ avl = gpr_avl_add(avl, box(823), box(499));
+ avl = remove_int(avl, 479);
+ avl = remove_int(avl, 96);
+ avl = remove_int(avl, 1013);
+ avl = gpr_avl_add(avl, box(768), box(503));
+ avl = remove_int(avl, 638);
+ avl = remove_int(avl, 20);
+ avl = gpr_avl_add(avl, box(663), box(506));
+ avl = remove_int(avl, 882);
+ avl = gpr_avl_add(avl, box(745), box(508));
+ avl = remove_int(avl, 352);
+ avl = gpr_avl_add(avl, box(10), box(510));
+ avl = remove_int(avl, 484);
+ avl = gpr_avl_add(avl, box(420), box(512));
+ avl = gpr_avl_add(avl, box(884), box(513));
+ avl = gpr_avl_add(avl, box(993), box(514));
+ avl = gpr_avl_add(avl, box(251), box(515));
+ avl = remove_int(avl, 222);
+ avl = gpr_avl_add(avl, box(734), box(517));
+ avl = gpr_avl_add(avl, box(952), box(518));
+ avl = remove_int(avl, 26);
+ avl = remove_int(avl, 270);
+ avl = remove_int(avl, 481);
+ avl = remove_int(avl, 693);
+ avl = remove_int(avl, 1006);
+ avl = gpr_avl_add(avl, box(77), box(524));
+ avl = remove_int(avl, 897);
+ avl = gpr_avl_add(avl, box(719), box(526));
+ avl = gpr_avl_add(avl, box(622), box(527));
+ avl = remove_int(avl, 28);
+ avl = remove_int(avl, 836);
+ avl = remove_int(avl, 142);
+ avl = gpr_avl_add(avl, box(445), box(531));
+ avl = gpr_avl_add(avl, box(410), box(532));
+ avl = remove_int(avl, 575);
+ avl = gpr_avl_add(avl, box(634), box(534));
+ avl = gpr_avl_add(avl, box(906), box(535));
+ avl = remove_int(avl, 649);
+ avl = gpr_avl_add(avl, box(813), box(537));
+ avl = remove_int(avl, 702);
+ avl = remove_int(avl, 732);
+ avl = gpr_avl_add(avl, box(105), box(540));
+ avl = gpr_avl_add(avl, box(867), box(541));
+ avl = remove_int(avl, 964);
+ avl = remove_int(avl, 941);
+ avl = gpr_avl_add(avl, box(947), box(544));
+ avl = remove_int(avl, 990);
+ avl = gpr_avl_add(avl, box(816), box(546));
+ avl = remove_int(avl, 429);
+ avl = remove_int(avl, 567);
+ avl = remove_int(avl, 541);
+ avl = remove_int(avl, 583);
+ avl = gpr_avl_add(avl, box(57), box(551));
+ avl = gpr_avl_add(avl, box(786), box(552));
+ avl = gpr_avl_add(avl, box(526), box(553));
+ avl = remove_int(avl, 642);
+ avl = remove_int(avl, 220);
+ avl = remove_int(avl, 840);
+ avl = remove_int(avl, 548);
+ avl = gpr_avl_add(avl, box(528), box(558));
+ avl = gpr_avl_add(avl, box(749), box(559));
+ avl = gpr_avl_add(avl, box(194), box(560));
+ avl = remove_int(avl, 517);
+ avl = gpr_avl_add(avl, box(102), box(562));
+ avl = remove_int(avl, 189);
+ avl = gpr_avl_add(avl, box(927), box(564));
+ avl = remove_int(avl, 846);
+ avl = remove_int(avl, 130);
+ avl = gpr_avl_add(avl, box(694), box(567));
+ avl = remove_int(avl, 750);
+ avl = gpr_avl_add(avl, box(357), box(569));
+ avl = remove_int(avl, 431);
+ avl = remove_int(avl, 91);
+ avl = gpr_avl_add(avl, box(640), box(572));
+ avl = remove_int(avl, 4);
+ avl = gpr_avl_add(avl, box(81), box(574));
+ avl = gpr_avl_add(avl, box(595), box(575));
+ avl = remove_int(avl, 444);
+ avl = remove_int(avl, 262);
+ avl = remove_int(avl, 11);
+ avl = gpr_avl_add(avl, box(192), box(579));
+ avl = gpr_avl_add(avl, box(158), box(580));
+ avl = remove_int(avl, 401);
+ avl = remove_int(avl, 918);
+ avl = gpr_avl_add(avl, box(180), box(583));
+ avl = remove_int(avl, 268);
+ avl = gpr_avl_add(avl, box(1012), box(585));
+ avl = gpr_avl_add(avl, box(90), box(586));
+ avl = gpr_avl_add(avl, box(946), box(587));
+ avl = remove_int(avl, 719);
+ avl = gpr_avl_add(avl, box(874), box(589));
+ avl = gpr_avl_add(avl, box(679), box(590));
+ avl = remove_int(avl, 53);
+ avl = remove_int(avl, 534);
+ avl = gpr_avl_add(avl, box(646), box(593));
+ avl = gpr_avl_add(avl, box(767), box(594));
+ avl = gpr_avl_add(avl, box(460), box(595));
+ avl = gpr_avl_add(avl, box(852), box(596));
+ avl = gpr_avl_add(avl, box(189), box(597));
+ avl = remove_int(avl, 932);
+ avl = remove_int(avl, 366);
+ avl = remove_int(avl, 907);
+ avl = gpr_avl_add(avl, box(875), box(601));
+ avl = gpr_avl_add(avl, box(434), box(602));
+ avl = gpr_avl_add(avl, box(704), box(603));
+ avl = gpr_avl_add(avl, box(724), box(604));
+ avl = gpr_avl_add(avl, box(930), box(605));
+ avl = gpr_avl_add(avl, box(1000), box(606));
+ avl = remove_int(avl, 479);
+ avl = gpr_avl_add(avl, box(275), box(608));
+ avl = remove_int(avl, 32);
+ avl = gpr_avl_add(avl, box(939), box(610));
+ avl = remove_int(avl, 943);
+ avl = remove_int(avl, 329);
+ avl = gpr_avl_add(avl, box(490), box(613));
+ avl = remove_int(avl, 477);
+ avl = remove_int(avl, 414);
+ avl = remove_int(avl, 187);
+ avl = remove_int(avl, 334);
+ avl = gpr_avl_add(avl, box(40), box(618));
+ avl = remove_int(avl, 751);
+ avl = gpr_avl_add(avl, box(568), box(620));
+ avl = gpr_avl_add(avl, box(120), box(621));
+ avl = gpr_avl_add(avl, box(617), box(622));
+ avl = gpr_avl_add(avl, box(32), box(623));
+ avl = remove_int(avl, 701);
+ avl = gpr_avl_add(avl, box(910), box(625));
+ avl = remove_int(avl, 557);
+ avl = remove_int(avl, 361);
+ avl = remove_int(avl, 937);
+ avl = remove_int(avl, 100);
+ avl = remove_int(avl, 684);
+ avl = gpr_avl_add(avl, box(751), box(631));
+ avl = remove_int(avl, 781);
+ avl = remove_int(avl, 469);
+ avl = remove_int(avl, 75);
+ avl = remove_int(avl, 561);
+ avl = gpr_avl_add(avl, box(854), box(636));
+ avl = remove_int(avl, 164);
+ avl = remove_int(avl, 258);
+ avl = remove_int(avl, 315);
+ avl = remove_int(avl, 261);
+ avl = gpr_avl_add(avl, box(552), box(641));
+ avl = gpr_avl_add(avl, box(6), box(642));
+ avl = gpr_avl_add(avl, box(680), box(643));
+ avl = remove_int(avl, 741);
+ avl = remove_int(avl, 309);
+ avl = remove_int(avl, 272);
+ avl = gpr_avl_add(avl, box(249), box(647));
+ avl = remove_int(avl, 97);
+ avl = remove_int(avl, 850);
+ avl = gpr_avl_add(avl, box(915), box(650));
+ avl = gpr_avl_add(avl, box(816), box(651));
+ avl = gpr_avl_add(avl, box(45), box(652));
+ avl = gpr_avl_add(avl, box(168), box(653));
+ avl = remove_int(avl, 153);
+ avl = remove_int(avl, 239);
+ avl = gpr_avl_add(avl, box(684), box(656));
+ avl = gpr_avl_add(avl, box(208), box(657));
+ avl = gpr_avl_add(avl, box(681), box(658));
+ avl = gpr_avl_add(avl, box(609), box(659));
+ avl = gpr_avl_add(avl, box(645), box(660));
+ avl = remove_int(avl, 799);
+ avl = gpr_avl_add(avl, box(955), box(662));
+ avl = gpr_avl_add(avl, box(946), box(663));
+ avl = gpr_avl_add(avl, box(744), box(664));
+ avl = gpr_avl_add(avl, box(201), box(665));
+ avl = gpr_avl_add(avl, box(136), box(666));
+ avl = remove_int(avl, 357);
+ avl = gpr_avl_add(avl, box(974), box(668));
+ avl = remove_int(avl, 485);
+ avl = gpr_avl_add(avl, box(1009), box(670));
+ avl = gpr_avl_add(avl, box(517), box(671));
+ avl = remove_int(avl, 491);
+ avl = gpr_avl_add(avl, box(336), box(673));
+ avl = gpr_avl_add(avl, box(589), box(674));
+ avl = remove_int(avl, 546);
+ avl = remove_int(avl, 840);
+ avl = remove_int(avl, 104);
+ avl = remove_int(avl, 347);
+ avl = gpr_avl_add(avl, box(801), box(679));
+ avl = remove_int(avl, 799);
+ avl = remove_int(avl, 702);
+ avl = remove_int(avl, 996);
+ avl = remove_int(avl, 93);
+ avl = gpr_avl_add(avl, box(561), box(684));
+ avl = gpr_avl_add(avl, box(25), box(685));
+ avl = remove_int(avl, 278);
+ avl = gpr_avl_add(avl, box(191), box(687));
+ avl = remove_int(avl, 243);
+ avl = remove_int(avl, 918);
+ avl = remove_int(avl, 449);
+ avl = gpr_avl_add(avl, box(19), box(691));
+ avl = gpr_avl_add(avl, box(762), box(692));
+ avl = gpr_avl_add(avl, box(13), box(693));
+ avl = gpr_avl_add(avl, box(151), box(694));
+ avl = gpr_avl_add(avl, box(152), box(695));
+ avl = gpr_avl_add(avl, box(793), box(696));
+ avl = remove_int(avl, 862);
+ avl = remove_int(avl, 890);
+ avl = gpr_avl_add(avl, box(687), box(699));
+ avl = gpr_avl_add(avl, box(509), box(700));
+ avl = gpr_avl_add(avl, box(973), box(701));
+ avl = remove_int(avl, 230);
+ avl = gpr_avl_add(avl, box(532), box(703));
+ avl = remove_int(avl, 668);
+ avl = gpr_avl_add(avl, box(281), box(705));
+ avl = gpr_avl_add(avl, box(867), box(706));
+ avl = gpr_avl_add(avl, box(359), box(707));
+ avl = remove_int(avl, 425);
+ avl = gpr_avl_add(avl, box(691), box(709));
+ avl = gpr_avl_add(avl, box(163), box(710));
+ avl = gpr_avl_add(avl, box(502), box(711));
+ avl = remove_int(avl, 674);
+ avl = gpr_avl_add(avl, box(697), box(713));
+ avl = remove_int(avl, 271);
+ avl = gpr_avl_add(avl, box(968), box(715));
+ avl = gpr_avl_add(avl, box(48), box(716));
+ avl = remove_int(avl, 543);
+ avl = gpr_avl_add(avl, box(35), box(718));
+ avl = gpr_avl_add(avl, box(751), box(719));
+ avl = gpr_avl_add(avl, box(478), box(720));
+ avl = remove_int(avl, 797);
+ avl = remove_int(avl, 309);
+ avl = gpr_avl_add(avl, box(927), box(723));
+ avl = remove_int(avl, 504);
+ avl = gpr_avl_add(avl, box(286), box(725));
+ avl = gpr_avl_add(avl, box(413), box(726));
+ avl = gpr_avl_add(avl, box(599), box(727));
+ avl = remove_int(avl, 105);
+ avl = remove_int(avl, 605);
+ avl = gpr_avl_add(avl, box(632), box(730));
+ avl = gpr_avl_add(avl, box(133), box(731));
+ avl = remove_int(avl, 443);
+ avl = gpr_avl_add(avl, box(958), box(733));
+ avl = gpr_avl_add(avl, box(729), box(734));
+ avl = remove_int(avl, 158);
+ avl = gpr_avl_add(avl, box(694), box(736));
+ avl = gpr_avl_add(avl, box(505), box(737));
+ avl = remove_int(avl, 63);
+ avl = remove_int(avl, 714);
+ avl = gpr_avl_add(avl, box(1002), box(740));
+ avl = remove_int(avl, 211);
+ avl = gpr_avl_add(avl, box(765), box(742));
+ avl = gpr_avl_add(avl, box(455), box(743));
+ avl = remove_int(avl, 59);
+ avl = remove_int(avl, 224);
+ avl = gpr_avl_add(avl, box(586), box(746));
+ avl = gpr_avl_add(avl, box(348), box(747));
+ avl = remove_int(avl, 10);
+ avl = remove_int(avl, 484);
+ avl = gpr_avl_add(avl, box(968), box(750));
+ avl = gpr_avl_add(avl, box(923), box(751));
+ avl = remove_int(avl, 573);
+ avl = remove_int(avl, 617);
+ avl = gpr_avl_add(avl, box(812), box(754));
+ avl = gpr_avl_add(avl, box(179), box(755));
+ avl = remove_int(avl, 284);
+ avl = remove_int(avl, 157);
+ avl = remove_int(avl, 177);
+ avl = remove_int(avl, 896);
+ avl = gpr_avl_add(avl, box(649), box(760));
+ avl = gpr_avl_add(avl, box(927), box(761));
+ avl = gpr_avl_add(avl, box(454), box(762));
+ avl = gpr_avl_add(avl, box(217), box(763));
+ avl = remove_int(avl, 534);
+ avl = gpr_avl_add(avl, box(180), box(765));
+ avl = gpr_avl_add(avl, box(319), box(766));
+ avl = remove_int(avl, 92);
+ avl = gpr_avl_add(avl, box(483), box(768));
+ avl = remove_int(avl, 504);
+ avl = remove_int(avl, 1017);
+ avl = remove_int(avl, 37);
+ avl = remove_int(avl, 50);
+ avl = gpr_avl_add(avl, box(302), box(773));
+ avl = remove_int(avl, 807);
+ avl = gpr_avl_add(avl, box(463), box(775));
+ avl = gpr_avl_add(avl, box(271), box(776));
+ avl = gpr_avl_add(avl, box(644), box(777));
+ avl = remove_int(avl, 618);
+ avl = gpr_avl_add(avl, box(166), box(779));
+ avl = gpr_avl_add(avl, box(538), box(780));
+ avl = remove_int(avl, 606);
+ avl = gpr_avl_add(avl, box(425), box(782));
+ avl = remove_int(avl, 725);
+ avl = remove_int(avl, 383);
+ avl = gpr_avl_add(avl, box(155), box(785));
+ avl = remove_int(avl, 889);
+ avl = gpr_avl_add(avl, box(653), box(787));
+ avl = remove_int(avl, 386);
+ avl = gpr_avl_add(avl, box(142), box(789));
+ avl = remove_int(avl, 107);
+ avl = remove_int(avl, 603);
+ avl = remove_int(avl, 971);
+ avl = gpr_avl_add(avl, box(80), box(793));
+ avl = gpr_avl_add(avl, box(61), box(794));
+ avl = gpr_avl_add(avl, box(693), box(795));
+ avl = gpr_avl_add(avl, box(592), box(796));
+ avl = gpr_avl_add(avl, box(433), box(797));
+ avl = gpr_avl_add(avl, box(973), box(798));
+ avl = remove_int(avl, 901);
+ avl = remove_int(avl, 340);
+ avl = remove_int(avl, 709);
+ avl = gpr_avl_add(avl, box(224), box(802));
+ avl = remove_int(avl, 120);
+ avl = remove_int(avl, 271);
+ avl = gpr_avl_add(avl, box(780), box(805));
+ avl = gpr_avl_add(avl, box(867), box(806));
+ avl = gpr_avl_add(avl, box(756), box(807));
+ avl = gpr_avl_add(avl, box(583), box(808));
+ avl = gpr_avl_add(avl, box(356), box(809));
+ avl = gpr_avl_add(avl, box(58), box(810));
+ avl = remove_int(avl, 219);
+ avl = gpr_avl_add(avl, box(301), box(812));
+ avl = remove_int(avl, 643);
+ avl = remove_int(avl, 787);
+ avl = remove_int(avl, 583);
+ avl = remove_int(avl, 552);
+ avl = remove_int(avl, 308);
+ avl = remove_int(avl, 608);
+ avl = remove_int(avl, 363);
+ avl = remove_int(avl, 690);
+ avl = gpr_avl_add(avl, box(233), box(821));
+ avl = gpr_avl_add(avl, box(479), box(822));
+ avl = gpr_avl_add(avl, box(323), box(823));
+ avl = gpr_avl_add(avl, box(802), box(824));
+ avl = remove_int(avl, 682);
+ avl = remove_int(avl, 705);
+ avl = remove_int(avl, 487);
+ avl = gpr_avl_add(avl, box(530), box(828));
+ avl = gpr_avl_add(avl, box(232), box(829));
+ avl = remove_int(avl, 627);
+ avl = gpr_avl_add(avl, box(396), box(831));
+ avl = gpr_avl_add(avl, box(61), box(832));
+ avl = gpr_avl_add(avl, box(932), box(833));
+ avl = gpr_avl_add(avl, box(108), box(834));
+ avl = gpr_avl_add(avl, box(524), box(835));
+ avl = remove_int(avl, 390);
+ avl = remove_int(avl, 307);
+ avl = gpr_avl_add(avl, box(722), box(838));
+ avl = gpr_avl_add(avl, box(907), box(839));
+ avl = remove_int(avl, 286);
+ avl = remove_int(avl, 337);
+ avl = remove_int(avl, 443);
+ avl = gpr_avl_add(avl, box(973), box(843));
+ avl = remove_int(avl, 930);
+ avl = remove_int(avl, 242);
+ avl = gpr_avl_add(avl, box(997), box(846));
+ avl = gpr_avl_add(avl, box(689), box(847));
+ avl = remove_int(avl, 318);
+ avl = gpr_avl_add(avl, box(703), box(849));
+ avl = gpr_avl_add(avl, box(868), box(850));
+ avl = gpr_avl_add(avl, box(200), box(851));
+ avl = gpr_avl_add(avl, box(960), box(852));
+ avl = gpr_avl_add(avl, box(80), box(853));
+ avl = remove_int(avl, 113);
+ avl = gpr_avl_add(avl, box(135), box(855));
+ avl = remove_int(avl, 529);
+ avl = gpr_avl_add(avl, box(366), box(857));
+ avl = remove_int(avl, 272);
+ avl = gpr_avl_add(avl, box(921), box(859));
+ avl = remove_int(avl, 497);
+ avl = gpr_avl_add(avl, box(712), box(861));
+ avl = remove_int(avl, 777);
+ avl = remove_int(avl, 505);
+ avl = remove_int(avl, 974);
+ avl = remove_int(avl, 497);
+ avl = gpr_avl_add(avl, box(388), box(866));
+ avl = gpr_avl_add(avl, box(29), box(867));
+ avl = gpr_avl_add(avl, box(180), box(868));
+ avl = gpr_avl_add(avl, box(983), box(869));
+ avl = gpr_avl_add(avl, box(72), box(870));
+ avl = gpr_avl_add(avl, box(693), box(871));
+ avl = gpr_avl_add(avl, box(567), box(872));
+ avl = remove_int(avl, 549);
+ avl = remove_int(avl, 351);
+ avl = gpr_avl_add(avl, box(1019), box(875));
+ avl = remove_int(avl, 585);
+ avl = remove_int(avl, 294);
+ avl = remove_int(avl, 61);
+ avl = gpr_avl_add(avl, box(409), box(879));
+ avl = gpr_avl_add(avl, box(984), box(880));
+ avl = gpr_avl_add(avl, box(830), box(881));
+ avl = remove_int(avl, 579);
+ avl = gpr_avl_add(avl, box(672), box(883));
+ avl = remove_int(avl, 968);
+
+ gpr_avl_unref(avl);
+}
+
+static void test_badcase3(void) {
+ gpr_avl avl;
+
+ gpr_log(GPR_DEBUG, "test_badcase3");
+
+ avl = gpr_avl_create(&int_int_vtable);
+ avl = remove_int(avl, 624);
+ avl = gpr_avl_add(avl, box(59), box(2));
+ avl = gpr_avl_add(avl, box(494), box(3));
+ avl = gpr_avl_add(avl, box(226), box(4));
+ avl = remove_int(avl, 524);
+ avl = gpr_avl_add(avl, box(540), box(6));
+ avl = remove_int(avl, 1008);
+ avl = gpr_avl_add(avl, box(502), box(8));
+ avl = remove_int(avl, 267);
+ avl = remove_int(avl, 764);
+ avl = remove_int(avl, 443);
+ avl = gpr_avl_add(avl, box(8), box(12));
+ avl = remove_int(avl, 291);
+ avl = remove_int(avl, 796);
+ avl = remove_int(avl, 1002);
+ avl = gpr_avl_add(avl, box(778), box(16));
+ avl = remove_int(avl, 621);
+ avl = remove_int(avl, 891);
+ avl = remove_int(avl, 880);
+ avl = gpr_avl_add(avl, box(197), box(20));
+ avl = gpr_avl_add(avl, box(441), box(21));
+ avl = gpr_avl_add(avl, box(719), box(22));
+ avl = remove_int(avl, 109);
+ avl = gpr_avl_add(avl, box(458), box(24));
+ avl = remove_int(avl, 86);
+ avl = gpr_avl_add(avl, box(897), box(26));
+ avl = gpr_avl_add(avl, box(997), box(27));
+ avl = remove_int(avl, 235);
+ avl = remove_int(avl, 425);
+ avl = remove_int(avl, 186);
+ avl = gpr_avl_add(avl, box(887), box(31));
+ avl = gpr_avl_add(avl, box(1005), box(32));
+ avl = gpr_avl_add(avl, box(778), box(33));
+ avl = gpr_avl_add(avl, box(575), box(34));
+ avl = remove_int(avl, 966);
+ avl = remove_int(avl, 1015);
+ avl = gpr_avl_add(avl, box(486), box(37));
+ avl = gpr_avl_add(avl, box(809), box(38));
+ avl = gpr_avl_add(avl, box(907), box(39));
+ avl = gpr_avl_add(avl, box(971), box(40));
+ avl = remove_int(avl, 441);
+ avl = remove_int(avl, 498);
+ avl = gpr_avl_add(avl, box(727), box(43));
+ avl = remove_int(avl, 679);
+ avl = remove_int(avl, 740);
+ avl = remove_int(avl, 532);
+ avl = gpr_avl_add(avl, box(805), box(47));
+ avl = remove_int(avl, 64);
+ avl = gpr_avl_add(avl, box(362), box(49));
+ avl = gpr_avl_add(avl, box(170), box(50));
+ avl = gpr_avl_add(avl, box(389), box(51));
+ avl = gpr_avl_add(avl, box(689), box(52));
+ avl = remove_int(avl, 871);
+ avl = gpr_avl_add(avl, box(447), box(54));
+ avl = remove_int(avl, 718);
+ avl = gpr_avl_add(avl, box(724), box(56));
+ avl = remove_int(avl, 215);
+ avl = gpr_avl_add(avl, box(550), box(58));
+ avl = remove_int(avl, 932);
+ avl = gpr_avl_add(avl, box(47), box(60));
+ avl = remove_int(avl, 46);
+ avl = remove_int(avl, 229);
+ avl = gpr_avl_add(avl, box(68), box(63));
+ avl = gpr_avl_add(avl, box(387), box(64));
+ avl = remove_int(avl, 933);
+ avl = remove_int(avl, 736);
+ avl = remove_int(avl, 719);
+ avl = gpr_avl_add(avl, box(150), box(68));
+ avl = remove_int(avl, 875);
+ avl = remove_int(avl, 298);
+ avl = gpr_avl_add(avl, box(991), box(71));
+ avl = remove_int(avl, 705);
+ avl = gpr_avl_add(avl, box(197), box(73));
+ avl = gpr_avl_add(avl, box(101), box(74));
+ avl = remove_int(avl, 436);
+ avl = gpr_avl_add(avl, box(755), box(76));
+ avl = gpr_avl_add(avl, box(727), box(77));
+ avl = remove_int(avl, 309);
+ avl = remove_int(avl, 253);
+ avl = gpr_avl_add(avl, box(203), box(80));
+ avl = remove_int(avl, 231);
+ avl = gpr_avl_add(avl, box(461), box(82));
+ avl = remove_int(avl, 316);
+ avl = remove_int(avl, 493);
+ avl = gpr_avl_add(avl, box(184), box(85));
+ avl = remove_int(avl, 737);
+ avl = gpr_avl_add(avl, box(790), box(87));
+ avl = gpr_avl_add(avl, box(335), box(88));
+ avl = remove_int(avl, 649);
+ avl = gpr_avl_add(avl, box(69), box(90));
+ avl = remove_int(avl, 585);
+ avl = remove_int(avl, 543);
+ avl = gpr_avl_add(avl, box(784), box(93));
+ avl = gpr_avl_add(avl, box(60), box(94));
+ avl = gpr_avl_add(avl, box(525), box(95));
+ avl = gpr_avl_add(avl, box(177), box(96));
+ avl = gpr_avl_add(avl, box(178), box(97));
+ avl = gpr_avl_add(avl, box(683), box(98));
+ avl = gpr_avl_add(avl, box(226), box(99));
+ avl = gpr_avl_add(avl, box(662), box(100));
+ avl = remove_int(avl, 944);
+ avl = gpr_avl_add(avl, box(562), box(102));
+ avl = gpr_avl_add(avl, box(793), box(103));
+ avl = remove_int(avl, 673);
+ avl = gpr_avl_add(avl, box(310), box(105));
+ avl = remove_int(avl, 479);
+ avl = remove_int(avl, 543);
+ avl = remove_int(avl, 159);
+ avl = remove_int(avl, 850);
+ avl = gpr_avl_add(avl, box(318), box(110));
+ avl = gpr_avl_add(avl, box(483), box(111));
+ avl = gpr_avl_add(avl, box(84), box(112));
+ avl = remove_int(avl, 109);
+ avl = gpr_avl_add(avl, box(132), box(114));
+ avl = gpr_avl_add(avl, box(920), box(115));
+ avl = remove_int(avl, 746);
+ avl = gpr_avl_add(avl, box(145), box(117));
+ avl = gpr_avl_add(avl, box(526), box(118));
+ avl = remove_int(avl, 158);
+ avl = gpr_avl_add(avl, box(332), box(120));
+ avl = gpr_avl_add(avl, box(918), box(121));
+ avl = remove_int(avl, 339);
+ avl = gpr_avl_add(avl, box(809), box(123));
+ avl = gpr_avl_add(avl, box(742), box(124));
+ avl = gpr_avl_add(avl, box(718), box(125));
+ avl = remove_int(avl, 988);
+ avl = remove_int(avl, 531);
+ avl = remove_int(avl, 840);
+ avl = gpr_avl_add(avl, box(816), box(129));
+ avl = gpr_avl_add(avl, box(976), box(130));
+ avl = remove_int(avl, 743);
+ avl = remove_int(avl, 528);
+ avl = remove_int(avl, 982);
+ avl = gpr_avl_add(avl, box(803), box(134));
+ avl = gpr_avl_add(avl, box(205), box(135));
+ avl = gpr_avl_add(avl, box(584), box(136));
+ avl = remove_int(avl, 923);
+ avl = remove_int(avl, 538);
+ avl = remove_int(avl, 398);
+ avl = remove_int(avl, 320);
+ avl = remove_int(avl, 292);
+ avl = gpr_avl_add(avl, box(270), box(142));
+ avl = gpr_avl_add(avl, box(333), box(143));
+ avl = remove_int(avl, 439);
+ avl = gpr_avl_add(avl, box(35), box(145));
+ avl = gpr_avl_add(avl, box(837), box(146));
+ avl = remove_int(avl, 65);
+ avl = remove_int(avl, 642);
+ avl = remove_int(avl, 371);
+ avl = remove_int(avl, 140);
+ avl = remove_int(avl, 533);
+ avl = remove_int(avl, 676);
+ avl = gpr_avl_add(avl, box(624), box(153));
+ avl = gpr_avl_add(avl, box(116), box(154));
+ avl = gpr_avl_add(avl, box(446), box(155));
+ avl = remove_int(avl, 91);
+ avl = remove_int(avl, 721);
+ avl = remove_int(avl, 537);
+ avl = gpr_avl_add(avl, box(448), box(159));
+ avl = remove_int(avl, 155);
+ avl = remove_int(avl, 344);
+ avl = remove_int(avl, 237);
+ avl = gpr_avl_add(avl, box(309), box(163));
+ avl = gpr_avl_add(avl, box(434), box(164));
+ avl = gpr_avl_add(avl, box(277), box(165));
+ avl = remove_int(avl, 233);
+ avl = gpr_avl_add(avl, box(275), box(167));
+ avl = gpr_avl_add(avl, box(218), box(168));
+ avl = gpr_avl_add(avl, box(76), box(169));
+ avl = gpr_avl_add(avl, box(898), box(170));
+ avl = remove_int(avl, 771);
+ avl = gpr_avl_add(avl, box(237), box(172));
+ avl = remove_int(avl, 327);
+ avl = gpr_avl_add(avl, box(499), box(174));
+ avl = remove_int(avl, 727);
+ avl = remove_int(avl, 234);
+ avl = remove_int(avl, 623);
+ avl = remove_int(avl, 458);
+ avl = remove_int(avl, 326);
+ avl = remove_int(avl, 589);
+ avl = gpr_avl_add(avl, box(442), box(181));
+ avl = remove_int(avl, 389);
+ avl = gpr_avl_add(avl, box(708), box(183));
+ avl = gpr_avl_add(avl, box(594), box(184));
+ avl = gpr_avl_add(avl, box(942), box(185));
+ avl = gpr_avl_add(avl, box(282), box(186));
+ avl = remove_int(avl, 434);
+ avl = remove_int(avl, 134);
+ avl = remove_int(avl, 270);
+ avl = remove_int(avl, 512);
+ avl = remove_int(avl, 265);
+ avl = remove_int(avl, 21);
+ avl = remove_int(avl, 193);
+ avl = remove_int(avl, 797);
+ avl = remove_int(avl, 347);
+ avl = gpr_avl_add(avl, box(99), box(196));
+ avl = gpr_avl_add(avl, box(161), box(197));
+ avl = remove_int(avl, 484);
+ avl = gpr_avl_add(avl, box(72), box(199));
+ avl = remove_int(avl, 629);
+ avl = gpr_avl_add(avl, box(522), box(201));
+ avl = remove_int(avl, 679);
+ avl = gpr_avl_add(avl, box(407), box(203));
+ avl = remove_int(avl, 693);
+ avl = gpr_avl_add(avl, box(424), box(205));
+ avl = gpr_avl_add(avl, box(651), box(206));
+ avl = gpr_avl_add(avl, box(927), box(207));
+ avl = remove_int(avl, 553);
+ avl = gpr_avl_add(avl, box(128), box(209));
+ avl = gpr_avl_add(avl, box(616), box(210));
+ avl = gpr_avl_add(avl, box(690), box(211));
+ avl = remove_int(avl, 241);
+ avl = remove_int(avl, 179);
+ avl = gpr_avl_add(avl, box(697), box(214));
+ avl = remove_int(avl, 779);
+ avl = gpr_avl_add(avl, box(241), box(216));
+ avl = remove_int(avl, 190);
+ avl = remove_int(avl, 210);
+ avl = gpr_avl_add(avl, box(711), box(219));
+ avl = remove_int(avl, 251);
+ avl = remove_int(avl, 61);
+ avl = gpr_avl_add(avl, box(800), box(222));
+ avl = remove_int(avl, 551);
+ avl = gpr_avl_add(avl, box(61), box(224));
+ avl = gpr_avl_add(avl, box(656), box(225));
+ avl = remove_int(avl, 130);
+ avl = remove_int(avl, 368);
+ avl = remove_int(avl, 150);
+ avl = remove_int(avl, 73);
+ avl = gpr_avl_add(avl, box(799), box(230));
+ avl = gpr_avl_add(avl, box(125), box(231));
+ avl = remove_int(avl, 107);
+ avl = gpr_avl_add(avl, box(938), box(233));
+ avl = gpr_avl_add(avl, box(914), box(234));
+ avl = gpr_avl_add(avl, box(197), box(235));
+ avl = remove_int(avl, 736);
+ avl = gpr_avl_add(avl, box(20), box(237));
+ avl = remove_int(avl, 224);
+ avl = remove_int(avl, 841);
+ avl = gpr_avl_add(avl, box(226), box(240));
+ avl = remove_int(avl, 963);
+ avl = remove_int(avl, 796);
+ avl = remove_int(avl, 728);
+ avl = gpr_avl_add(avl, box(855), box(244));
+ avl = gpr_avl_add(avl, box(769), box(245));
+ avl = gpr_avl_add(avl, box(631), box(246));
+ avl = remove_int(avl, 648);
+ avl = gpr_avl_add(avl, box(187), box(248));
+ avl = gpr_avl_add(avl, box(31), box(249));
+ avl = remove_int(avl, 163);
+ avl = gpr_avl_add(avl, box(218), box(251));
+ avl = gpr_avl_add(avl, box(488), box(252));
+ avl = gpr_avl_add(avl, box(387), box(253));
+ avl = gpr_avl_add(avl, box(809), box(254));
+ avl = gpr_avl_add(avl, box(997), box(255));
+ avl = remove_int(avl, 678);
+ avl = gpr_avl_add(avl, box(368), box(257));
+ avl = gpr_avl_add(avl, box(220), box(258));
+ avl = gpr_avl_add(avl, box(373), box(259));
+ avl = remove_int(avl, 874);
+ avl = remove_int(avl, 682);
+ avl = remove_int(avl, 1014);
+ avl = remove_int(avl, 195);
+ avl = gpr_avl_add(avl, box(868), box(264));
+ avl = remove_int(avl, 254);
+ avl = remove_int(avl, 456);
+ avl = gpr_avl_add(avl, box(906), box(267));
+ avl = remove_int(avl, 711);
+ avl = gpr_avl_add(avl, box(632), box(269));
+ avl = remove_int(avl, 474);
+ avl = gpr_avl_add(avl, box(508), box(271));
+ avl = gpr_avl_add(avl, box(518), box(272));
+ avl = remove_int(avl, 579);
+ avl = remove_int(avl, 948);
+ avl = gpr_avl_add(avl, box(789), box(275));
+ avl = gpr_avl_add(avl, box(48), box(276));
+ avl = gpr_avl_add(avl, box(256), box(277));
+ avl = gpr_avl_add(avl, box(754), box(278));
+ avl = remove_int(avl, 215);
+ avl = gpr_avl_add(avl, box(679), box(280));
+ avl = gpr_avl_add(avl, box(606), box(281));
+ avl = remove_int(avl, 941);
+ avl = remove_int(avl, 31);
+ avl = gpr_avl_add(avl, box(758), box(284));
+ avl = remove_int(avl, 101);
+ avl = gpr_avl_add(avl, box(244), box(286));
+ avl = gpr_avl_add(avl, box(337), box(287));
+ avl = gpr_avl_add(avl, box(461), box(288));
+ avl = remove_int(avl, 476);
+ avl = gpr_avl_add(avl, box(845), box(290));
+ avl = remove_int(avl, 160);
+ avl = gpr_avl_add(avl, box(690), box(292));
+ avl = remove_int(avl, 931);
+ avl = gpr_avl_add(avl, box(869), box(294));
+ avl = gpr_avl_add(avl, box(1019), box(295));
+ avl = remove_int(avl, 591);
+ avl = remove_int(avl, 635);
+ avl = remove_int(avl, 67);
+ avl = gpr_avl_add(avl, box(113), box(299));
+ avl = remove_int(avl, 305);
+ avl = gpr_avl_add(avl, box(10), box(301));
+ avl = remove_int(avl, 823);
+ avl = remove_int(avl, 288);
+ avl = remove_int(avl, 239);
+ avl = gpr_avl_add(avl, box(646), box(305));
+ avl = gpr_avl_add(avl, box(1006), box(306));
+ avl = gpr_avl_add(avl, box(954), box(307));
+ avl = gpr_avl_add(avl, box(199), box(308));
+ avl = gpr_avl_add(avl, box(69), box(309));
+ avl = gpr_avl_add(avl, box(984), box(310));
+ avl = remove_int(avl, 568);
+ avl = remove_int(avl, 666);
+ avl = remove_int(avl, 37);
+ avl = gpr_avl_add(avl, box(845), box(314));
+ avl = remove_int(avl, 535);
+ avl = remove_int(avl, 365);
+ avl = remove_int(avl, 676);
+ avl = remove_int(avl, 892);
+ avl = remove_int(avl, 425);
+ avl = remove_int(avl, 704);
+ avl = remove_int(avl, 168);
+ avl = gpr_avl_add(avl, box(853), box(322));
+ avl = gpr_avl_add(avl, box(335), box(323));
+ avl = gpr_avl_add(avl, box(961), box(324));
+ avl = gpr_avl_add(avl, box(73), box(325));
+ avl = remove_int(avl, 469);
+ avl = gpr_avl_add(avl, box(449), box(327));
+ avl = remove_int(avl, 821);
+ avl = gpr_avl_add(avl, box(845), box(329));
+ avl = remove_int(avl, 637);
+ avl = gpr_avl_add(avl, box(769), box(331));
+ avl = gpr_avl_add(avl, box(901), box(332));
+ avl = remove_int(avl, 142);
+ avl = remove_int(avl, 361);
+ avl = remove_int(avl, 876);
+ avl = gpr_avl_add(avl, box(614), box(336));
+ avl = gpr_avl_add(avl, box(729), box(337));
+ avl = remove_int(avl, 120);
+ avl = remove_int(avl, 473);
+ avl = remove_int(avl, 445);
+ avl = gpr_avl_add(avl, box(978), box(341));
+ avl = gpr_avl_add(avl, box(164), box(342));
+ avl = gpr_avl_add(avl, box(1), box(343));
+ avl = remove_int(avl, 890);
+ avl = gpr_avl_add(avl, box(605), box(345));
+ avl = gpr_avl_add(avl, box(178), box(346));
+ avl = gpr_avl_add(avl, box(481), box(347));
+ avl = gpr_avl_add(avl, box(772), box(348));
+ avl = remove_int(avl, 824);
+ avl = remove_int(avl, 167);
+ avl = remove_int(avl, 151);
+ avl = gpr_avl_add(avl, box(698), box(352));
+ avl = gpr_avl_add(avl, box(202), box(353));
+ avl = gpr_avl_add(avl, box(921), box(354));
+ avl = gpr_avl_add(avl, box(875), box(355));
+ avl = remove_int(avl, 197);
+ avl = remove_int(avl, 232);
+ avl = gpr_avl_add(avl, box(209), box(358));
+ avl = remove_int(avl, 324);
+ avl = remove_int(avl, 56);
+ avl = remove_int(avl, 579);
+ avl = remove_int(avl, 255);
+ avl = remove_int(avl, 290);
+ avl = gpr_avl_add(avl, box(661), box(364));
+ avl = gpr_avl_add(avl, box(113), box(365));
+ avl = remove_int(avl, 767);
+ avl = gpr_avl_add(avl, box(586), box(367));
+ avl = gpr_avl_add(avl, box(121), box(368));
+ avl = remove_int(avl, 235);
+ avl = remove_int(avl, 439);
+ avl = remove_int(avl, 360);
+ avl = gpr_avl_add(avl, box(916), box(372));
+ avl = remove_int(avl, 999);
+ avl = gpr_avl_add(avl, box(825), box(374));
+ avl = gpr_avl_add(avl, box(177), box(375));
+ avl = remove_int(avl, 204);
+ avl = remove_int(avl, 92);
+ avl = gpr_avl_add(avl, box(794), box(378));
+ avl = gpr_avl_add(avl, box(463), box(379));
+ avl = gpr_avl_add(avl, box(472), box(380));
+ avl = remove_int(avl, 235);
+ avl = gpr_avl_add(avl, box(840), box(382));
+ avl = remove_int(avl, 657);
+ avl = gpr_avl_add(avl, box(586), box(384));
+ avl = gpr_avl_add(avl, box(979), box(385));
+ avl = remove_int(avl, 979);
+ avl = gpr_avl_add(avl, box(639), box(387));
+ avl = remove_int(avl, 907);
+ avl = remove_int(avl, 973);
+ avl = gpr_avl_add(avl, box(913), box(390));
+ avl = gpr_avl_add(avl, box(566), box(391));
+ avl = gpr_avl_add(avl, box(883), box(392));
+ avl = gpr_avl_add(avl, box(552), box(393));
+ avl = gpr_avl_add(avl, box(16), box(394));
+ avl = remove_int(avl, 60);
+ avl = gpr_avl_add(avl, box(567), box(396));
+ avl = gpr_avl_add(avl, box(705), box(397));
+ avl = gpr_avl_add(avl, box(94), box(398));
+ avl = remove_int(avl, 321);
+ avl = gpr_avl_add(avl, box(207), box(400));
+ avl = gpr_avl_add(avl, box(682), box(401));
+ avl = gpr_avl_add(avl, box(592), box(402));
+ avl = gpr_avl_add(avl, box(10), box(403));
+ avl = remove_int(avl, 911);
+ avl = remove_int(avl, 161);
+ avl = gpr_avl_add(avl, box(86), box(406));
+ avl = remove_int(avl, 893);
+ avl = remove_int(avl, 362);
+ avl = gpr_avl_add(avl, box(599), box(409));
+ avl = remove_int(avl, 413);
+ avl = gpr_avl_add(avl, box(867), box(411));
+ avl = remove_int(avl, 955);
+ avl = gpr_avl_add(avl, box(341), box(413));
+ avl = gpr_avl_add(avl, box(887), box(414));
+ avl = remove_int(avl, 706);
+ avl = gpr_avl_add(avl, box(939), box(416));
+ avl = remove_int(avl, 233);
+ avl = remove_int(avl, 662);
+ avl = remove_int(avl, 984);
+ avl = remove_int(avl, 203);
+ avl = gpr_avl_add(avl, box(326), box(421));
+ avl = remove_int(avl, 848);
+ avl = gpr_avl_add(avl, box(235), box(423));
+ avl = remove_int(avl, 617);
+ avl = gpr_avl_add(avl, box(565), box(425));
+ avl = remove_int(avl, 469);
+ avl = gpr_avl_add(avl, box(988), box(427));
+ avl = remove_int(avl, 957);
+ avl = gpr_avl_add(avl, box(426), box(429));
+ avl = remove_int(avl, 967);
+ avl = gpr_avl_add(avl, box(890), box(431));
+ avl = gpr_avl_add(avl, box(473), box(432));
+ avl = remove_int(avl, 367);
+ avl = remove_int(avl, 344);
+ avl = remove_int(avl, 660);
+ avl = remove_int(avl, 448);
+ avl = remove_int(avl, 837);
+ avl = remove_int(avl, 158);
+ avl = gpr_avl_add(avl, box(459), box(439));
+ avl = remove_int(avl, 882);
+ avl = remove_int(avl, 782);
+ avl = gpr_avl_add(avl, box(408), box(442));
+ avl = gpr_avl_add(avl, box(728), box(443));
+ avl = remove_int(avl, 27);
+ avl = gpr_avl_add(avl, box(137), box(445));
+ avl = gpr_avl_add(avl, box(239), box(446));
+ avl = remove_int(avl, 854);
+ avl = gpr_avl_add(avl, box(104), box(448));
+ avl = gpr_avl_add(avl, box(823), box(449));
+ avl = gpr_avl_add(avl, box(524), box(450));
+ avl = gpr_avl_add(avl, box(995), box(451));
+ avl = remove_int(avl, 422);
+ avl = remove_int(avl, 220);
+ avl = gpr_avl_add(avl, box(856), box(454));
+ avl = remove_int(avl, 332);
+ avl = gpr_avl_add(avl, box(679), box(456));
+ avl = remove_int(avl, 18);
+ avl = gpr_avl_add(avl, box(837), box(458));
+ avl = remove_int(avl, 405);
+ avl = remove_int(avl, 877);
+ avl = remove_int(avl, 835);
+ avl = gpr_avl_add(avl, box(547), box(462));
+ avl = remove_int(avl, 805);
+ avl = remove_int(avl, 862);
+ avl = gpr_avl_add(avl, box(75), box(465));
+ avl = remove_int(avl, 41);
+ avl = gpr_avl_add(avl, box(310), box(467));
+ avl = remove_int(avl, 855);
+ avl = gpr_avl_add(avl, box(20), box(469));
+ avl = remove_int(avl, 186);
+ avl = remove_int(avl, 378);
+ avl = remove_int(avl, 442);
+ avl = remove_int(avl, 930);
+ avl = gpr_avl_add(avl, box(118), box(474));
+ avl = gpr_avl_add(avl, box(96), box(475));
+ avl = remove_int(avl, 854);
+ avl = gpr_avl_add(avl, box(65), box(477));
+ avl = gpr_avl_add(avl, box(573), box(478));
+ avl = gpr_avl_add(avl, box(4), box(479));
+ avl = gpr_avl_add(avl, box(451), box(480));
+ avl = gpr_avl_add(avl, box(774), box(481));
+ avl = gpr_avl_add(avl, box(126), box(482));
+ avl = remove_int(avl, 956);
+ avl = remove_int(avl, 591);
+ avl = remove_int(avl, 644);
+ avl = gpr_avl_add(avl, box(304), box(486));
+ avl = remove_int(avl, 620);
+ avl = remove_int(avl, 394);
+ avl = gpr_avl_add(avl, box(1002), box(489));
+ avl = gpr_avl_add(avl, box(837), box(490));
+ avl = remove_int(avl, 485);
+ avl = gpr_avl_add(avl, box(1005), box(492));
+ avl = remove_int(avl, 21);
+ avl = gpr_avl_add(avl, box(396), box(494));
+ avl = remove_int(avl, 966);
+ avl = gpr_avl_add(avl, box(105), box(496));
+ avl = gpr_avl_add(avl, box(316), box(497));
+ avl = remove_int(avl, 776);
+ avl = gpr_avl_add(avl, box(188), box(499));
+ avl = remove_int(avl, 200);
+ avl = gpr_avl_add(avl, box(98), box(501));
+ avl = gpr_avl_add(avl, box(831), box(502));
+ avl = gpr_avl_add(avl, box(227), box(503));
+ avl = gpr_avl_add(avl, box(220), box(504));
+ avl = remove_int(avl, 715);
+ avl = remove_int(avl, 279);
+ avl = gpr_avl_add(avl, box(701), box(507));
+ avl = gpr_avl_add(avl, box(726), box(508));
+ avl = gpr_avl_add(avl, box(815), box(509));
+ avl = gpr_avl_add(avl, box(749), box(510));
+ avl = remove_int(avl, 946);
+ avl = remove_int(avl, 449);
+ avl = remove_int(avl, 62);
+ avl = remove_int(avl, 487);
+ avl = gpr_avl_add(avl, box(545), box(515));
+ avl = remove_int(avl, 59);
+ avl = gpr_avl_add(avl, box(168), box(517));
+ avl = remove_int(avl, 337);
+ avl = gpr_avl_add(avl, box(69), box(519));
+ avl = remove_int(avl, 600);
+ avl = gpr_avl_add(avl, box(591), box(521));
+ avl = gpr_avl_add(avl, box(960), box(522));
+ avl = gpr_avl_add(avl, box(116), box(523));
+ avl = remove_int(avl, 991);
+ avl = gpr_avl_add(avl, box(760), box(525));
+ avl = gpr_avl_add(avl, box(664), box(526));
+ avl = gpr_avl_add(avl, box(547), box(527));
+ avl = remove_int(avl, 922);
+ avl = gpr_avl_add(avl, box(290), box(529));
+ avl = gpr_avl_add(avl, box(859), box(530));
+ avl = gpr_avl_add(avl, box(49), box(531));
+ avl = remove_int(avl, 455);
+ avl = remove_int(avl, 786);
+ avl = gpr_avl_add(avl, box(613), box(534));
+ avl = gpr_avl_add(avl, box(326), box(535));
+ avl = remove_int(avl, 615);
+ avl = gpr_avl_add(avl, box(45), box(537));
+ avl = gpr_avl_add(avl, box(162), box(538));
+ avl = gpr_avl_add(avl, box(189), box(539));
+ avl = remove_int(avl, 68);
+ avl = remove_int(avl, 846);
+ avl = gpr_avl_add(avl, box(608), box(542));
+ avl = remove_int(avl, 821);
+ avl = gpr_avl_add(avl, box(978), box(544));
+ avl = gpr_avl_add(avl, box(892), box(545));
+ avl = remove_int(avl, 924);
+ avl = gpr_avl_add(avl, box(708), box(547));
+ avl = remove_int(avl, 135);
+ avl = remove_int(avl, 124);
+ avl = gpr_avl_add(avl, box(301), box(550));
+ avl = gpr_avl_add(avl, box(939), box(551));
+ avl = gpr_avl_add(avl, box(344), box(552));
+ avl = remove_int(avl, 443);
+ avl = remove_int(avl, 122);
+ avl = gpr_avl_add(avl, box(636), box(555));
+ avl = remove_int(avl, 558);
+ avl = gpr_avl_add(avl, box(923), box(557));
+ avl = remove_int(avl, 827);
+ avl = gpr_avl_add(avl, box(649), box(559));
+ avl = gpr_avl_add(avl, box(808), box(560));
+ avl = remove_int(avl, 570);
+ avl = remove_int(avl, 434);
+ avl = gpr_avl_add(avl, box(40), box(563));
+ avl = gpr_avl_add(avl, box(725), box(564));
+ avl = remove_int(avl, 295);
+ avl = remove_int(avl, 615);
+ avl = remove_int(avl, 919);
+ avl = remove_int(avl, 170);
+ avl = remove_int(avl, 442);
+ avl = remove_int(avl, 971);
+ avl = gpr_avl_add(avl, box(483), box(571));
+ avl = gpr_avl_add(avl, box(512), box(572));
+ avl = remove_int(avl, 648);
+ avl = remove_int(avl, 78);
+ avl = remove_int(avl, 72);
+ avl = remove_int(avl, 790);
+ avl = remove_int(avl, 571);
+ avl = gpr_avl_add(avl, box(898), box(578));
+ avl = remove_int(avl, 770);
+ avl = remove_int(avl, 776);
+ avl = gpr_avl_add(avl, box(602), box(581));
+ avl = remove_int(avl, 251);
+ avl = gpr_avl_add(avl, box(303), box(583));
+ avl = remove_int(avl, 837);
+ avl = gpr_avl_add(avl, box(714), box(585));
+ avl = remove_int(avl, 800);
+ avl = gpr_avl_add(avl, box(266), box(587));
+ avl = gpr_avl_add(avl, box(555), box(588));
+ avl = remove_int(avl, 604);
+ avl = remove_int(avl, 163);
+ avl = remove_int(avl, 497);
+ avl = gpr_avl_add(avl, box(296), box(592));
+ avl = remove_int(avl, 129);
+ avl = gpr_avl_add(avl, box(656), box(594));
+ avl = remove_int(avl, 769);
+ avl = remove_int(avl, 941);
+ avl = gpr_avl_add(avl, box(775), box(597));
+ avl = gpr_avl_add(avl, box(846), box(598));
+ avl = remove_int(avl, 591);
+ avl = remove_int(avl, 801);
+ avl = remove_int(avl, 419);
+ avl = remove_int(avl, 455);
+ avl = gpr_avl_add(avl, box(866), box(603));
+ avl = gpr_avl_add(avl, box(575), box(604));
+ avl = gpr_avl_add(avl, box(620), box(605));
+ avl = remove_int(avl, 100);
+ avl = remove_int(avl, 667);
+ avl = gpr_avl_add(avl, box(138), box(608));
+ avl = gpr_avl_add(avl, box(566), box(609));
+ avl = gpr_avl_add(avl, box(673), box(610));
+ avl = gpr_avl_add(avl, box(178), box(611));
+ avl = remove_int(avl, 659);
+ avl = gpr_avl_add(avl, box(759), box(613));
+ avl = gpr_avl_add(avl, box(1008), box(614));
+ avl = remove_int(avl, 116);
+ avl = gpr_avl_add(avl, box(608), box(616));
+ avl = gpr_avl_add(avl, box(339), box(617));
+ avl = gpr_avl_add(avl, box(197), box(618));
+ avl = remove_int(avl, 25);
+ avl = remove_int(avl, 628);
+ avl = gpr_avl_add(avl, box(487), box(621));
+ avl = remove_int(avl, 739);
+ avl = remove_int(avl, 100);
+ avl = remove_int(avl, 928);
+ avl = gpr_avl_add(avl, box(647), box(625));
+ avl = remove_int(avl, 978);
+ avl = remove_int(avl, 143);
+ avl = remove_int(avl, 755);
+ avl = gpr_avl_add(avl, box(71), box(629));
+ avl = remove_int(avl, 205);
+ avl = gpr_avl_add(avl, box(501), box(631));
+ avl = remove_int(avl, 723);
+ avl = remove_int(avl, 852);
+ avl = remove_int(avl, 1021);
+ avl = remove_int(avl, 670);
+ avl = remove_int(avl, 500);
+ avl = gpr_avl_add(avl, box(330), box(637));
+ avl = remove_int(avl, 264);
+ avl = gpr_avl_add(avl, box(69), box(639));
+ avl = remove_int(avl, 73);
+ avl = gpr_avl_add(avl, box(745), box(641));
+ avl = remove_int(avl, 518);
+ avl = remove_int(avl, 641);
+ avl = remove_int(avl, 768);
+ avl = gpr_avl_add(avl, box(988), box(645));
+ avl = gpr_avl_add(avl, box(899), box(646));
+ avl = remove_int(avl, 763);
+ avl = remove_int(avl, 281);
+ avl = remove_int(avl, 496);
+ avl = gpr_avl_add(avl, box(445), box(650));
+ avl = remove_int(avl, 905);
+ avl = gpr_avl_add(avl, box(275), box(652));
+ avl = gpr_avl_add(avl, box(137), box(653));
+ avl = remove_int(avl, 642);
+ avl = gpr_avl_add(avl, box(708), box(655));
+ avl = remove_int(avl, 922);
+ avl = gpr_avl_add(avl, box(743), box(657));
+ avl = remove_int(avl, 295);
+ avl = remove_int(avl, 665);
+ avl = remove_int(avl, 48);
+ avl = gpr_avl_add(avl, box(1012), box(661));
+ avl = remove_int(avl, 71);
+ avl = remove_int(avl, 523);
+ avl = gpr_avl_add(avl, box(319), box(664));
+ avl = remove_int(avl, 632);
+ avl = gpr_avl_add(avl, box(137), box(666));
+ avl = gpr_avl_add(avl, box(686), box(667));
+ avl = gpr_avl_add(avl, box(724), box(668));
+ avl = gpr_avl_add(avl, box(952), box(669));
+ avl = gpr_avl_add(avl, box(5), box(670));
+ avl = remove_int(avl, 35);
+ avl = gpr_avl_add(avl, box(43), box(672));
+ avl = gpr_avl_add(avl, box(320), box(673));
+ avl = gpr_avl_add(avl, box(115), box(674));
+ avl = remove_int(avl, 377);
+ avl = remove_int(avl, 591);
+ avl = remove_int(avl, 87);
+ avl = remove_int(avl, 93);
+ avl = gpr_avl_add(avl, box(1016), box(679));
+ avl = gpr_avl_add(avl, box(605), box(680));
+ avl = gpr_avl_add(avl, box(152), box(681));
+ avl = gpr_avl_add(avl, box(113), box(682));
+ avl = remove_int(avl, 131);
+ avl = remove_int(avl, 637);
+ avl = gpr_avl_add(avl, box(156), box(685));
+ avl = remove_int(avl, 696);
+ avl = gpr_avl_add(avl, box(546), box(687));
+ avl = remove_int(avl, 970);
+ avl = remove_int(avl, 53);
+ avl = remove_int(avl, 827);
+ avl = remove_int(avl, 224);
+ avl = remove_int(avl, 796);
+ avl = remove_int(avl, 34);
+ avl = remove_int(avl, 922);
+ avl = remove_int(avl, 277);
+ avl = remove_int(avl, 650);
+ avl = remove_int(avl, 222);
+ avl = remove_int(avl, 244);
+ avl = remove_int(avl, 576);
+ avl = remove_int(avl, 413);
+ avl = gpr_avl_add(avl, box(500), box(701));
+ avl = remove_int(avl, 924);
+ avl = gpr_avl_add(avl, box(825), box(703));
+ avl = remove_int(avl, 888);
+ avl = remove_int(avl, 931);
+ avl = gpr_avl_add(avl, box(285), box(706));
+ avl = remove_int(avl, 62);
+ avl = remove_int(avl, 444);
+ avl = remove_int(avl, 946);
+ avl = gpr_avl_add(avl, box(122), box(710));
+ avl = gpr_avl_add(avl, box(846), box(711));
+ avl = remove_int(avl, 628);
+ avl = gpr_avl_add(avl, box(511), box(713));
+ avl = gpr_avl_add(avl, box(398), box(714));
+ avl = remove_int(avl, 730);
+ avl = gpr_avl_add(avl, box(797), box(716));
+ avl = remove_int(avl, 897);
+ avl = remove_int(avl, 228);
+ avl = remove_int(avl, 544);
+ avl = remove_int(avl, 552);
+ avl = remove_int(avl, 783);
+ avl = remove_int(avl, 583);
+ avl = remove_int(avl, 894);
+ avl = remove_int(avl, 942);
+ avl = gpr_avl_add(avl, box(346), box(725));
+ avl = gpr_avl_add(avl, box(1015), box(726));
+ avl = remove_int(avl, 813);
+ avl = gpr_avl_add(avl, box(213), box(728));
+ avl = remove_int(avl, 468);
+ avl = remove_int(avl, 365);
+ avl = remove_int(avl, 399);
+ avl = gpr_avl_add(avl, box(380), box(732));
+ avl = remove_int(avl, 835);
+ avl = remove_int(avl, 970);
+ avl = gpr_avl_add(avl, box(700), box(735));
+ avl = gpr_avl_add(avl, box(807), box(736));
+ avl = remove_int(avl, 312);
+ avl = remove_int(avl, 282);
+ avl = remove_int(avl, 370);
+ avl = remove_int(avl, 999);
+ avl = remove_int(avl, 241);
+ avl = remove_int(avl, 884);
+ avl = gpr_avl_add(avl, box(587), box(743));
+ avl = gpr_avl_add(avl, box(332), box(744));
+ avl = remove_int(avl, 686);
+ avl = remove_int(avl, 206);
+ avl = remove_int(avl, 835);
+ avl = gpr_avl_add(avl, box(334), box(748));
+ avl = remove_int(avl, 171);
+ avl = gpr_avl_add(avl, box(1002), box(750));
+ avl = gpr_avl_add(avl, box(779), box(751));
+ avl = gpr_avl_add(avl, box(307), box(752));
+ avl = gpr_avl_add(avl, box(127), box(753));
+ avl = gpr_avl_add(avl, box(251), box(754));
+ avl = remove_int(avl, 790);
+ avl = remove_int(avl, 189);
+ avl = remove_int(avl, 193);
+ avl = remove_int(avl, 38);
+ avl = remove_int(avl, 124);
+ avl = gpr_avl_add(avl, box(812), box(760));
+ avl = remove_int(avl, 43);
+ avl = gpr_avl_add(avl, box(871), box(762));
+ avl = gpr_avl_add(avl, box(580), box(763));
+ avl = remove_int(avl, 501);
+ avl = remove_int(avl, 462);
+ avl = remove_int(avl, 599);
+ avl = gpr_avl_add(avl, box(240), box(767));
+ avl = gpr_avl_add(avl, box(285), box(768));
+ avl = gpr_avl_add(avl, box(472), box(769));
+ avl = remove_int(avl, 865);
+ avl = remove_int(avl, 763);
+ avl = remove_int(avl, 245);
+ avl = remove_int(avl, 80);
+ avl = remove_int(avl, 713);
+ avl = remove_int(avl, 654);
+ avl = remove_int(avl, 1014);
+ avl = gpr_avl_add(avl, box(495), box(777));
+ avl = gpr_avl_add(avl, box(552), box(778));
+ avl = remove_int(avl, 19);
+ avl = remove_int(avl, 803);
+ avl = gpr_avl_add(avl, box(508), box(781));
+ avl = remove_int(avl, 699);
+ avl = remove_int(avl, 260);
+ avl = remove_int(avl, 92);
+ avl = remove_int(avl, 497);
+ avl = gpr_avl_add(avl, box(970), box(786));
+ avl = remove_int(avl, 987);
+ avl = remove_int(avl, 168);
+ avl = remove_int(avl, 476);
+ avl = remove_int(avl, 248);
+ avl = gpr_avl_add(avl, box(358), box(791));
+ avl = remove_int(avl, 804);
+ avl = remove_int(avl, 77);
+ avl = remove_int(avl, 905);
+ avl = remove_int(avl, 362);
+ avl = gpr_avl_add(avl, box(578), box(796));
+ avl = remove_int(avl, 38);
+ avl = remove_int(avl, 595);
+ avl = gpr_avl_add(avl, box(213), box(799));
+ avl = remove_int(avl, 7);
+ avl = remove_int(avl, 620);
+ avl = gpr_avl_add(avl, box(946), box(802));
+ avl = remove_int(avl, 145);
+ avl = gpr_avl_add(avl, box(628), box(804));
+ avl = remove_int(avl, 972);
+ avl = gpr_avl_add(avl, box(728), box(806));
+ avl = remove_int(avl, 91);
+ avl = gpr_avl_add(avl, box(136), box(808));
+ avl = gpr_avl_add(avl, box(841), box(809));
+ avl = gpr_avl_add(avl, box(265), box(810));
+ avl = gpr_avl_add(avl, box(701), box(811));
+ avl = gpr_avl_add(avl, box(27), box(812));
+ avl = remove_int(avl, 72);
+ avl = remove_int(avl, 14);
+ avl = gpr_avl_add(avl, box(286), box(815));
+ avl = remove_int(avl, 996);
+ avl = remove_int(avl, 998);
+ avl = gpr_avl_add(avl, box(466), box(818));
+ avl = remove_int(avl, 1009);
+ avl = remove_int(avl, 741);
+ avl = remove_int(avl, 947);
+ avl = remove_int(avl, 241);
+ avl = remove_int(avl, 954);
+ avl = remove_int(avl, 183);
+ avl = remove_int(avl, 395);
+ avl = remove_int(avl, 951);
+ avl = gpr_avl_add(avl, box(267), box(827));
+ avl = remove_int(avl, 812);
+ avl = gpr_avl_add(avl, box(577), box(829));
+ avl = remove_int(avl, 624);
+ avl = remove_int(avl, 847);
+ avl = remove_int(avl, 745);
+ avl = gpr_avl_add(avl, box(491), box(833));
+ avl = gpr_avl_add(avl, box(941), box(834));
+ avl = remove_int(avl, 258);
+ avl = gpr_avl_add(avl, box(410), box(836));
+ avl = gpr_avl_add(avl, box(80), box(837));
+ avl = gpr_avl_add(avl, box(196), box(838));
+ avl = gpr_avl_add(avl, box(5), box(839));
+ avl = remove_int(avl, 782);
+ avl = gpr_avl_add(avl, box(827), box(841));
+ avl = remove_int(avl, 472);
+ avl = remove_int(avl, 664);
+ avl = gpr_avl_add(avl, box(409), box(844));
+ avl = gpr_avl_add(avl, box(62), box(845));
+ avl = remove_int(avl, 56);
+ avl = remove_int(avl, 606);
+ avl = remove_int(avl, 707);
+ avl = remove_int(avl, 989);
+ avl = remove_int(avl, 549);
+ avl = remove_int(avl, 259);
+ avl = gpr_avl_add(avl, box(405), box(852));
+ avl = remove_int(avl, 587);
+ avl = remove_int(avl, 350);
+ avl = gpr_avl_add(avl, box(980), box(855));
+ avl = gpr_avl_add(avl, box(992), box(856));
+ avl = gpr_avl_add(avl, box(818), box(857));
+ avl = remove_int(avl, 853);
+ avl = remove_int(avl, 701);
+ avl = gpr_avl_add(avl, box(675), box(860));
+ avl = remove_int(avl, 248);
+ avl = remove_int(avl, 649);
+ avl = gpr_avl_add(avl, box(508), box(863));
+ avl = remove_int(avl, 927);
+ avl = gpr_avl_add(avl, box(957), box(865));
+ avl = gpr_avl_add(avl, box(698), box(866));
+ avl = gpr_avl_add(avl, box(388), box(867));
+ avl = gpr_avl_add(avl, box(532), box(868));
+ avl = gpr_avl_add(avl, box(681), box(869));
+ avl = remove_int(avl, 544);
+ avl = remove_int(avl, 991);
+ avl = remove_int(avl, 397);
+ avl = gpr_avl_add(avl, box(954), box(873));
+ avl = gpr_avl_add(avl, box(219), box(874));
+ avl = gpr_avl_add(avl, box(465), box(875));
+ avl = remove_int(avl, 371);
+ avl = gpr_avl_add(avl, box(601), box(877));
+ avl = gpr_avl_add(avl, box(543), box(878));
+ avl = remove_int(avl, 329);
+ avl = gpr_avl_add(avl, box(560), box(880));
+ avl = remove_int(avl, 898);
+ avl = gpr_avl_add(avl, box(455), box(882));
+ avl = remove_int(avl, 313);
+ avl = gpr_avl_add(avl, box(215), box(884));
+ avl = remove_int(avl, 846);
+ avl = gpr_avl_add(avl, box(608), box(886));
+ avl = remove_int(avl, 248);
+ avl = gpr_avl_add(avl, box(575), box(888));
+ avl = remove_int(avl, 207);
+ avl = remove_int(avl, 810);
+ avl = remove_int(avl, 665);
+ avl = remove_int(avl, 361);
+ avl = gpr_avl_add(avl, box(154), box(893));
+ avl = gpr_avl_add(avl, box(329), box(894));
+ avl = gpr_avl_add(avl, box(326), box(895));
+ avl = remove_int(avl, 746);
+ avl = remove_int(avl, 99);
+ avl = gpr_avl_add(avl, box(464), box(898));
+ avl = gpr_avl_add(avl, box(141), box(899));
+ avl = remove_int(avl, 383);
+ avl = gpr_avl_add(avl, box(414), box(901));
+ avl = gpr_avl_add(avl, box(777), box(902));
+ avl = remove_int(avl, 972);
+ avl = remove_int(avl, 841);
+ avl = remove_int(avl, 100);
+ avl = gpr_avl_add(avl, box(828), box(906));
+ avl = remove_int(avl, 785);
+ avl = gpr_avl_add(avl, box(1008), box(908));
+ avl = gpr_avl_add(avl, box(46), box(909));
+ avl = remove_int(avl, 399);
+ avl = gpr_avl_add(avl, box(178), box(911));
+ avl = gpr_avl_add(avl, box(573), box(912));
+ avl = remove_int(avl, 299);
+ avl = gpr_avl_add(avl, box(690), box(914));
+ avl = gpr_avl_add(avl, box(692), box(915));
+ avl = remove_int(avl, 404);
+ avl = remove_int(avl, 16);
+ avl = remove_int(avl, 746);
+ avl = remove_int(avl, 486);
+ avl = remove_int(avl, 119);
+ avl = gpr_avl_add(avl, box(167), box(921));
+ avl = remove_int(avl, 328);
+ avl = gpr_avl_add(avl, box(89), box(923));
+ avl = remove_int(avl, 867);
+ avl = remove_int(avl, 626);
+ avl = remove_int(avl, 507);
+ avl = gpr_avl_add(avl, box(365), box(927));
+ avl = gpr_avl_add(avl, box(58), box(928));
+ avl = gpr_avl_add(avl, box(70), box(929));
+ avl = remove_int(avl, 81);
+ avl = remove_int(avl, 797);
+ avl = gpr_avl_add(avl, box(846), box(932));
+ avl = remove_int(avl, 642);
+ avl = gpr_avl_add(avl, box(777), box(934));
+ avl = remove_int(avl, 107);
+ avl = gpr_avl_add(avl, box(691), box(936));
+ avl = gpr_avl_add(avl, box(820), box(937));
+ avl = gpr_avl_add(avl, box(202), box(938));
+ avl = gpr_avl_add(avl, box(308), box(939));
+ avl = gpr_avl_add(avl, box(20), box(940));
+ avl = remove_int(avl, 289);
+ avl = gpr_avl_add(avl, box(714), box(942));
+ avl = gpr_avl_add(avl, box(584), box(943));
+ avl = remove_int(avl, 294);
+ avl = gpr_avl_add(avl, box(496), box(945));
+ avl = gpr_avl_add(avl, box(394), box(946));
+ avl = gpr_avl_add(avl, box(860), box(947));
+ avl = gpr_avl_add(avl, box(58), box(948));
+ avl = remove_int(avl, 784);
+ avl = remove_int(avl, 584);
+ avl = remove_int(avl, 708);
+ avl = gpr_avl_add(avl, box(142), box(952));
+ avl = gpr_avl_add(avl, box(247), box(953));
+ avl = gpr_avl_add(avl, box(389), box(954));
+ avl = remove_int(avl, 390);
+ avl = gpr_avl_add(avl, box(465), box(956));
+ avl = gpr_avl_add(avl, box(936), box(957));
+ avl = gpr_avl_add(avl, box(309), box(958));
+ avl = remove_int(avl, 928);
+ avl = remove_int(avl, 128);
+ avl = remove_int(avl, 979);
+ avl = remove_int(avl, 670);
+ avl = remove_int(avl, 738);
+ avl = remove_int(avl, 271);
+ avl = remove_int(avl, 540);
+ avl = gpr_avl_add(avl, box(365), box(966));
+ avl = remove_int(avl, 82);
+ avl = gpr_avl_add(avl, box(728), box(968));
+ avl = remove_int(avl, 852);
+ avl = gpr_avl_add(avl, box(884), box(970));
+ avl = gpr_avl_add(avl, box(502), box(971));
+ avl = remove_int(avl, 898);
+ avl = remove_int(avl, 481);
+ avl = gpr_avl_add(avl, box(911), box(974));
+ avl = remove_int(avl, 787);
+ avl = remove_int(avl, 785);
+ avl = remove_int(avl, 537);
+ avl = remove_int(avl, 535);
+ avl = remove_int(avl, 136);
+ avl = remove_int(avl, 749);
+ avl = remove_int(avl, 637);
+ avl = remove_int(avl, 900);
+ avl = gpr_avl_add(avl, box(598), box(983));
+ avl = remove_int(avl, 25);
+ avl = remove_int(avl, 697);
+ avl = gpr_avl_add(avl, box(645), box(986));
+ avl = gpr_avl_add(avl, box(211), box(987));
+ avl = gpr_avl_add(avl, box(589), box(988));
+ avl = remove_int(avl, 702);
+ avl = gpr_avl_add(avl, box(53), box(990));
+ avl = remove_int(avl, 492);
+ avl = remove_int(avl, 185);
+ avl = remove_int(avl, 246);
+ avl = remove_int(avl, 257);
+ avl = remove_int(avl, 502);
+ avl = remove_int(avl, 34);
+ avl = gpr_avl_add(avl, box(74), box(997));
+ avl = gpr_avl_add(avl, box(834), box(998));
+ avl = gpr_avl_add(avl, box(514), box(999));
+ avl = gpr_avl_add(avl, box(75), box(1000));
+ avl = remove_int(avl, 745);
+ avl = gpr_avl_add(avl, box(362), box(1002));
+ avl = remove_int(avl, 215);
+ avl = gpr_avl_add(avl, box(624), box(1004));
+ avl = remove_int(avl, 404);
+ avl = remove_int(avl, 359);
+ avl = remove_int(avl, 491);
+ avl = gpr_avl_add(avl, box(903), box(1008));
+ avl = gpr_avl_add(avl, box(240), box(1009));
+ avl = remove_int(avl, 95);
+ avl = gpr_avl_add(avl, box(119), box(1011));
+ avl = gpr_avl_add(avl, box(857), box(1012));
+ avl = remove_int(avl, 39);
+ avl = remove_int(avl, 866);
+ avl = gpr_avl_add(avl, box(503), box(1015));
+ avl = gpr_avl_add(avl, box(740), box(1016));
+ avl = remove_int(avl, 637);
+ avl = remove_int(avl, 156);
+ avl = remove_int(avl, 6);
+ avl = remove_int(avl, 745);
+ avl = remove_int(avl, 433);
+ avl = remove_int(avl, 283);
+ avl = gpr_avl_add(avl, box(625), box(1023));
+ avl = remove_int(avl, 638);
+ avl = gpr_avl_add(avl, box(299), box(1025));
+ avl = gpr_avl_add(avl, box(584), box(1026));
+ avl = remove_int(avl, 863);
+ avl = gpr_avl_add(avl, box(612), box(1028));
+ avl = gpr_avl_add(avl, box(62), box(1029));
+ avl = gpr_avl_add(avl, box(432), box(1030));
+ avl = remove_int(avl, 371);
+ avl = remove_int(avl, 790);
+ avl = remove_int(avl, 227);
+ avl = remove_int(avl, 836);
+ avl = gpr_avl_add(avl, box(703), box(1035));
+ avl = gpr_avl_add(avl, box(644), box(1036));
+ avl = remove_int(avl, 638);
+ avl = gpr_avl_add(avl, box(13), box(1038));
+ avl = remove_int(avl, 66);
+ avl = remove_int(avl, 82);
+ avl = gpr_avl_add(avl, box(362), box(1041));
+ avl = gpr_avl_add(avl, box(783), box(1042));
+ avl = remove_int(avl, 60);
+ avl = gpr_avl_add(avl, box(80), box(1044));
+ avl = gpr_avl_add(avl, box(825), box(1045));
+ avl = gpr_avl_add(avl, box(688), box(1046));
+ avl = gpr_avl_add(avl, box(662), box(1047));
+ avl = remove_int(avl, 156);
+ avl = remove_int(avl, 376);
+ avl = remove_int(avl, 99);
+ avl = gpr_avl_add(avl, box(526), box(1051));
+ avl = gpr_avl_add(avl, box(168), box(1052));
+ avl = remove_int(avl, 646);
+ avl = remove_int(avl, 380);
+ avl = remove_int(avl, 833);
+ avl = gpr_avl_add(avl, box(53), box(1056));
+ avl = remove_int(avl, 105);
+ avl = gpr_avl_add(avl, box(373), box(1058));
+ avl = gpr_avl_add(avl, box(184), box(1059));
+ avl = remove_int(avl, 288);
+ avl = gpr_avl_add(avl, box(966), box(1061));
+ avl = remove_int(avl, 158);
+ avl = gpr_avl_add(avl, box(406), box(1063));
+ avl = remove_int(avl, 470);
+ avl = gpr_avl_add(avl, box(283), box(1065));
+ avl = gpr_avl_add(avl, box(838), box(1066));
+ avl = gpr_avl_add(avl, box(288), box(1067));
+ avl = gpr_avl_add(avl, box(950), box(1068));
+ avl = gpr_avl_add(avl, box(163), box(1069));
+ avl = remove_int(avl, 623);
+ avl = remove_int(avl, 769);
+ avl = gpr_avl_add(avl, box(144), box(1072));
+ avl = gpr_avl_add(avl, box(489), box(1073));
+ avl = remove_int(avl, 15);
+ avl = gpr_avl_add(avl, box(971), box(1075));
+ avl = remove_int(avl, 660);
+ avl = gpr_avl_add(avl, box(255), box(1077));
+ avl = remove_int(avl, 494);
+ avl = gpr_avl_add(avl, box(109), box(1079));
+ avl = gpr_avl_add(avl, box(420), box(1080));
+ avl = gpr_avl_add(avl, box(509), box(1081));
+ avl = remove_int(avl, 178);
+ avl = gpr_avl_add(avl, box(216), box(1083));
+ avl = gpr_avl_add(avl, box(707), box(1084));
+ avl = gpr_avl_add(avl, box(411), box(1085));
+ avl = gpr_avl_add(avl, box(352), box(1086));
+ avl = remove_int(avl, 983);
+ avl = gpr_avl_add(avl, box(6), box(1088));
+ avl = gpr_avl_add(avl, box(1014), box(1089));
+ avl = remove_int(avl, 98);
+ avl = remove_int(avl, 325);
+ avl = gpr_avl_add(avl, box(851), box(1092));
+ avl = remove_int(avl, 553);
+ avl = gpr_avl_add(avl, box(218), box(1094));
+ avl = gpr_avl_add(avl, box(261), box(1095));
+ avl = remove_int(avl, 31);
+ avl = gpr_avl_add(avl, box(872), box(1097));
+ avl = remove_int(avl, 543);
+ avl = remove_int(avl, 314);
+ avl = remove_int(avl, 443);
+ avl = gpr_avl_add(avl, box(533), box(1101));
+ avl = remove_int(avl, 881);
+ avl = remove_int(avl, 269);
+ avl = remove_int(avl, 940);
+ avl = remove_int(avl, 909);
+ avl = remove_int(avl, 197);
+ avl = remove_int(avl, 773);
+ avl = remove_int(avl, 790);
+ avl = remove_int(avl, 345);
+ avl = gpr_avl_add(avl, box(965), box(1110));
+ avl = remove_int(avl, 622);
+ avl = gpr_avl_add(avl, box(352), box(1112));
+ avl = remove_int(avl, 182);
+ avl = gpr_avl_add(avl, box(534), box(1114));
+ avl = gpr_avl_add(avl, box(97), box(1115));
+ avl = gpr_avl_add(avl, box(198), box(1116));
+ avl = remove_int(avl, 750);
+ avl = gpr_avl_add(avl, box(98), box(1118));
+ avl = remove_int(avl, 943);
+ avl = gpr_avl_add(avl, box(254), box(1120));
+ avl = gpr_avl_add(avl, box(30), box(1121));
+ avl = remove_int(avl, 14);
+ avl = remove_int(avl, 475);
+ avl = remove_int(avl, 82);
+ avl = gpr_avl_add(avl, box(789), box(1125));
+ avl = gpr_avl_add(avl, box(402), box(1126));
+ avl = remove_int(avl, 1019);
+ avl = gpr_avl_add(avl, box(858), box(1128));
+ avl = gpr_avl_add(avl, box(625), box(1129));
+ avl = remove_int(avl, 675);
+ avl = remove_int(avl, 323);
+ avl = gpr_avl_add(avl, box(329), box(1132));
+ avl = remove_int(avl, 929);
+ avl = remove_int(avl, 44);
+ avl = gpr_avl_add(avl, box(443), box(1135));
+ avl = gpr_avl_add(avl, box(653), box(1136));
+ avl = gpr_avl_add(avl, box(750), box(1137));
+ avl = gpr_avl_add(avl, box(252), box(1138));
+ avl = gpr_avl_add(avl, box(449), box(1139));
+ avl = remove_int(avl, 1022);
+ avl = remove_int(avl, 357);
+ avl = remove_int(avl, 602);
+ avl = remove_int(avl, 131);
+ avl = gpr_avl_add(avl, box(531), box(1144));
+ avl = remove_int(avl, 806);
+ avl = gpr_avl_add(avl, box(455), box(1146));
+ avl = remove_int(avl, 31);
+ avl = gpr_avl_add(avl, box(154), box(1148));
+ avl = gpr_avl_add(avl, box(189), box(1149));
+ avl = remove_int(avl, 786);
+ avl = gpr_avl_add(avl, box(496), box(1151));
+ avl = gpr_avl_add(avl, box(81), box(1152));
+ avl = gpr_avl_add(avl, box(59), box(1153));
+ avl = remove_int(avl, 424);
+ avl = remove_int(avl, 668);
+ avl = gpr_avl_add(avl, box(723), box(1156));
+ avl = gpr_avl_add(avl, box(822), box(1157));
+ avl = gpr_avl_add(avl, box(354), box(1158));
+ avl = remove_int(avl, 738);
+ avl = gpr_avl_add(avl, box(686), box(1160));
+ avl = gpr_avl_add(avl, box(43), box(1161));
+ avl = gpr_avl_add(avl, box(625), box(1162));
+ avl = gpr_avl_add(avl, box(902), box(1163));
+ avl = gpr_avl_add(avl, box(12), box(1164));
+ avl = gpr_avl_add(avl, box(977), box(1165));
+ avl = gpr_avl_add(avl, box(699), box(1166));
+ avl = gpr_avl_add(avl, box(189), box(1167));
+ avl = remove_int(avl, 672);
+ avl = remove_int(avl, 90);
+ avl = remove_int(avl, 757);
+ avl = remove_int(avl, 494);
+ avl = gpr_avl_add(avl, box(759), box(1172));
+ avl = remove_int(avl, 758);
+ avl = remove_int(avl, 222);
+ avl = gpr_avl_add(avl, box(975), box(1175));
+ avl = remove_int(avl, 993);
+ avl = gpr_avl_add(avl, box(2), box(1177));
+ avl = gpr_avl_add(avl, box(70), box(1178));
+ avl = remove_int(avl, 350);
+ avl = remove_int(avl, 972);
+ avl = remove_int(avl, 880);
+ avl = gpr_avl_add(avl, box(753), box(1182));
+ avl = remove_int(avl, 404);
+ avl = gpr_avl_add(avl, box(294), box(1184));
+ avl = remove_int(avl, 474);
+ avl = gpr_avl_add(avl, box(228), box(1186));
+ avl = gpr_avl_add(avl, box(484), box(1187));
+ avl = remove_int(avl, 238);
+ avl = remove_int(avl, 53);
+ avl = remove_int(avl, 691);
+ avl = gpr_avl_add(avl, box(345), box(1191));
+ avl = remove_int(avl, 0);
+ avl = gpr_avl_add(avl, box(230), box(1193));
+ avl = remove_int(avl, 227);
+ avl = remove_int(avl, 152);
+ avl = gpr_avl_add(avl, box(884), box(1196));
+ avl = remove_int(avl, 823);
+ avl = remove_int(avl, 53);
+ avl = gpr_avl_add(avl, box(1015), box(1199));
+ avl = gpr_avl_add(avl, box(697), box(1200));
+ avl = gpr_avl_add(avl, box(376), box(1201));
+ avl = remove_int(avl, 411);
+ avl = gpr_avl_add(avl, box(888), box(1203));
+ avl = remove_int(avl, 55);
+ avl = gpr_avl_add(avl, box(85), box(1205));
+ avl = remove_int(avl, 947);
+ avl = remove_int(avl, 382);
+ avl = remove_int(avl, 777);
+ avl = gpr_avl_add(avl, box(1017), box(1209));
+ avl = gpr_avl_add(avl, box(169), box(1210));
+ avl = gpr_avl_add(avl, box(156), box(1211));
+ avl = remove_int(avl, 153);
+ avl = remove_int(avl, 642);
+ avl = remove_int(avl, 158);
+ avl = gpr_avl_add(avl, box(554), box(1215));
+ avl = gpr_avl_add(avl, box(76), box(1216));
+ avl = gpr_avl_add(avl, box(756), box(1217));
+ avl = remove_int(avl, 767);
+ avl = remove_int(avl, 112);
+ avl = remove_int(avl, 539);
+ avl = remove_int(avl, 544);
+ avl = remove_int(avl, 628);
+ avl = remove_int(avl, 385);
+ avl = remove_int(avl, 514);
+ avl = remove_int(avl, 362);
+ avl = gpr_avl_add(avl, box(523), box(1226));
+ avl = gpr_avl_add(avl, box(712), box(1227));
+ avl = gpr_avl_add(avl, box(474), box(1228));
+ avl = gpr_avl_add(avl, box(882), box(1229));
+ avl = gpr_avl_add(avl, box(965), box(1230));
+ avl = remove_int(avl, 464);
+ avl = gpr_avl_add(avl, box(319), box(1232));
+ avl = gpr_avl_add(avl, box(504), box(1233));
+ avl = remove_int(avl, 818);
+ avl = gpr_avl_add(avl, box(884), box(1235));
+ avl = gpr_avl_add(avl, box(813), box(1236));
+ avl = gpr_avl_add(avl, box(795), box(1237));
+ avl = remove_int(avl, 306);
+ avl = gpr_avl_add(avl, box(799), box(1239));
+ avl = remove_int(avl, 534);
+ avl = gpr_avl_add(avl, box(480), box(1241));
+ avl = gpr_avl_add(avl, box(656), box(1242));
+ avl = gpr_avl_add(avl, box(709), box(1243));
+ avl = gpr_avl_add(avl, box(500), box(1244));
+ avl = remove_int(avl, 740);
+ avl = gpr_avl_add(avl, box(980), box(1246));
+ avl = gpr_avl_add(avl, box(458), box(1247));
+ avl = remove_int(avl, 377);
+ avl = remove_int(avl, 338);
+ avl = gpr_avl_add(avl, box(554), box(1250));
+ avl = gpr_avl_add(avl, box(504), box(1251));
+ avl = gpr_avl_add(avl, box(603), box(1252));
+ avl = gpr_avl_add(avl, box(761), box(1253));
+ avl = remove_int(avl, 431);
+ avl = gpr_avl_add(avl, box(707), box(1255));
+ avl = gpr_avl_add(avl, box(673), box(1256));
+ avl = remove_int(avl, 998);
+ avl = remove_int(avl, 332);
+ avl = remove_int(avl, 413);
+ avl = remove_int(avl, 227);
+ avl = remove_int(avl, 249);
+ avl = remove_int(avl, 309);
+ avl = remove_int(avl, 459);
+ avl = gpr_avl_add(avl, box(645), box(1264));
+ avl = remove_int(avl, 858);
+ avl = remove_int(avl, 997);
+ avl = gpr_avl_add(avl, box(519), box(1267));
+ avl = remove_int(avl, 614);
+ avl = remove_int(avl, 462);
+ avl = remove_int(avl, 792);
+ avl = gpr_avl_add(avl, box(987), box(1271));
+ avl = gpr_avl_add(avl, box(309), box(1272));
+ avl = remove_int(avl, 747);
+ avl = gpr_avl_add(avl, box(621), box(1274));
+ avl = gpr_avl_add(avl, box(450), box(1275));
+ avl = remove_int(avl, 265);
+ avl = remove_int(avl, 8);
+ avl = remove_int(avl, 383);
+ avl = gpr_avl_add(avl, box(238), box(1279));
+ avl = remove_int(avl, 241);
+ avl = gpr_avl_add(avl, box(180), box(1281));
+ avl = gpr_avl_add(avl, box(411), box(1282));
+ avl = gpr_avl_add(avl, box(791), box(1283));
+ avl = gpr_avl_add(avl, box(955), box(1284));
+ avl = remove_int(avl, 24);
+ avl = remove_int(avl, 375);
+ avl = gpr_avl_add(avl, box(140), box(1287));
+ avl = remove_int(avl, 949);
+ avl = gpr_avl_add(avl, box(301), box(1289));
+ avl = gpr_avl_add(avl, box(0), box(1290));
+ avl = remove_int(avl, 371);
+ avl = remove_int(avl, 427);
+ avl = remove_int(avl, 841);
+ avl = remove_int(avl, 847);
+ avl = gpr_avl_add(avl, box(814), box(1295));
+ avl = gpr_avl_add(avl, box(127), box(1296));
+ avl = gpr_avl_add(avl, box(279), box(1297));
+ avl = remove_int(avl, 669);
+ avl = remove_int(avl, 541);
+ avl = remove_int(avl, 275);
+ avl = remove_int(avl, 299);
+ avl = remove_int(avl, 552);
+ avl = gpr_avl_add(avl, box(310), box(1303));
+ avl = gpr_avl_add(avl, box(304), box(1304));
+ avl = gpr_avl_add(avl, box(1), box(1305));
+ avl = gpr_avl_add(avl, box(339), box(1306));
+ avl = remove_int(avl, 570);
+ avl = remove_int(avl, 752);
+ avl = remove_int(avl, 552);
+ avl = remove_int(avl, 442);
+ avl = remove_int(avl, 639);
+ avl = gpr_avl_add(avl, box(313), box(1312));
+ avl = remove_int(avl, 85);
+ avl = gpr_avl_add(avl, box(964), box(1314));
+ avl = gpr_avl_add(avl, box(559), box(1315));
+ avl = remove_int(avl, 167);
+ avl = gpr_avl_add(avl, box(866), box(1317));
+ avl = remove_int(avl, 275);
+ avl = gpr_avl_add(avl, box(173), box(1319));
+ avl = gpr_avl_add(avl, box(765), box(1320));
+ avl = remove_int(avl, 883);
+ avl = gpr_avl_add(avl, box(547), box(1322));
+ avl = gpr_avl_add(avl, box(847), box(1323));
+ avl = remove_int(avl, 817);
+ avl = remove_int(avl, 850);
+ avl = remove_int(avl, 718);
+ avl = gpr_avl_add(avl, box(806), box(1327));
+ avl = gpr_avl_add(avl, box(360), box(1328));
+ avl = remove_int(avl, 991);
+ avl = gpr_avl_add(avl, box(493), box(1330));
+ avl = remove_int(avl, 516);
+ avl = gpr_avl_add(avl, box(361), box(1332));
+ avl = remove_int(avl, 355);
+ avl = gpr_avl_add(avl, box(512), box(1334));
+ avl = gpr_avl_add(avl, box(191), box(1335));
+ avl = remove_int(avl, 703);
+ avl = gpr_avl_add(avl, box(333), box(1337));
+ avl = remove_int(avl, 481);
+ avl = gpr_avl_add(avl, box(501), box(1339));
+ avl = remove_int(avl, 532);
+ avl = remove_int(avl, 510);
+ avl = gpr_avl_add(avl, box(793), box(1342));
+ avl = gpr_avl_add(avl, box(234), box(1343));
+ avl = remove_int(avl, 159);
+ avl = remove_int(avl, 429);
+ avl = remove_int(avl, 728);
+ avl = remove_int(avl, 288);
+ avl = gpr_avl_add(avl, box(281), box(1348));
+ avl = gpr_avl_add(avl, box(702), box(1349));
+ avl = gpr_avl_add(avl, box(149), box(1350));
+ avl = remove_int(avl, 22);
+ avl = remove_int(avl, 944);
+ avl = remove_int(avl, 55);
+ avl = remove_int(avl, 512);
+ avl = remove_int(avl, 676);
+ avl = remove_int(avl, 884);
+ avl = gpr_avl_add(avl, box(246), box(1357));
+ avl = gpr_avl_add(avl, box(455), box(1358));
+ avl = remove_int(avl, 782);
+ avl = remove_int(avl, 682);
+ avl = gpr_avl_add(avl, box(243), box(1361));
+ avl = gpr_avl_add(avl, box(109), box(1362));
+ avl = gpr_avl_add(avl, box(452), box(1363));
+ avl = remove_int(avl, 151);
+ avl = gpr_avl_add(avl, box(159), box(1365));
+ avl = remove_int(avl, 1023);
+ avl = gpr_avl_add(avl, box(129), box(1367));
+ avl = gpr_avl_add(avl, box(537), box(1368));
+ avl = remove_int(avl, 321);
+ avl = gpr_avl_add(avl, box(740), box(1370));
+ avl = remove_int(avl, 45);
+ avl = remove_int(avl, 136);
+ avl = gpr_avl_add(avl, box(229), box(1373));
+ avl = remove_int(avl, 772);
+ avl = gpr_avl_add(avl, box(181), box(1375));
+ avl = remove_int(avl, 175);
+ avl = gpr_avl_add(avl, box(817), box(1377));
+ avl = remove_int(avl, 956);
+ avl = gpr_avl_add(avl, box(675), box(1379));
+ avl = gpr_avl_add(avl, box(375), box(1380));
+ avl = remove_int(avl, 384);
+ avl = gpr_avl_add(avl, box(1016), box(1382));
+ avl = remove_int(avl, 295);
+ avl = remove_int(avl, 697);
+ avl = remove_int(avl, 554);
+ avl = remove_int(avl, 590);
+ avl = remove_int(avl, 1014);
+ avl = gpr_avl_add(avl, box(890), box(1388));
+ avl = gpr_avl_add(avl, box(293), box(1389));
+ avl = remove_int(avl, 207);
+ avl = remove_int(avl, 46);
+ avl = gpr_avl_add(avl, box(899), box(1392));
+ avl = gpr_avl_add(avl, box(666), box(1393));
+ avl = gpr_avl_add(avl, box(85), box(1394));
+ avl = gpr_avl_add(avl, box(914), box(1395));
+ avl = gpr_avl_add(avl, box(128), box(1396));
+ avl = gpr_avl_add(avl, box(835), box(1397));
+ avl = gpr_avl_add(avl, box(787), box(1398));
+ avl = gpr_avl_add(avl, box(649), box(1399));
+ avl = gpr_avl_add(avl, box(723), box(1400));
+ avl = remove_int(avl, 874);
+ avl = gpr_avl_add(avl, box(778), box(1402));
+ avl = gpr_avl_add(avl, box(1015), box(1403));
+ avl = gpr_avl_add(avl, box(59), box(1404));
+ avl = gpr_avl_add(avl, box(259), box(1405));
+ avl = gpr_avl_add(avl, box(758), box(1406));
+ avl = remove_int(avl, 648);
+ avl = gpr_avl_add(avl, box(145), box(1408));
+ avl = gpr_avl_add(avl, box(440), box(1409));
+ avl = remove_int(avl, 608);
+ avl = remove_int(avl, 690);
+ avl = gpr_avl_add(avl, box(605), box(1412));
+ avl = remove_int(avl, 856);
+ avl = remove_int(avl, 608);
+ avl = gpr_avl_add(avl, box(829), box(1415));
+ avl = gpr_avl_add(avl, box(660), box(1416));
+ avl = remove_int(avl, 596);
+ avl = gpr_avl_add(avl, box(519), box(1418));
+ avl = gpr_avl_add(avl, box(35), box(1419));
+ avl = gpr_avl_add(avl, box(871), box(1420));
+ avl = remove_int(avl, 845);
+ avl = gpr_avl_add(avl, box(600), box(1422));
+ avl = gpr_avl_add(avl, box(215), box(1423));
+ avl = remove_int(avl, 761);
+ avl = gpr_avl_add(avl, box(975), box(1425));
+ avl = remove_int(avl, 987);
+ avl = gpr_avl_add(avl, box(58), box(1427));
+ avl = remove_int(avl, 119);
+ avl = gpr_avl_add(avl, box(937), box(1429));
+ avl = gpr_avl_add(avl, box(372), box(1430));
+ avl = gpr_avl_add(avl, box(11), box(1431));
+ avl = gpr_avl_add(avl, box(398), box(1432));
+ avl = gpr_avl_add(avl, box(423), box(1433));
+ avl = remove_int(avl, 171);
+ avl = gpr_avl_add(avl, box(473), box(1435));
+ avl = remove_int(avl, 752);
+ avl = remove_int(avl, 625);
+ avl = remove_int(avl, 764);
+ avl = remove_int(avl, 49);
+ avl = gpr_avl_add(avl, box(472), box(1440));
+ avl = remove_int(avl, 847);
+ avl = remove_int(avl, 642);
+ avl = remove_int(avl, 1004);
+ avl = remove_int(avl, 795);
+ avl = remove_int(avl, 465);
+ avl = gpr_avl_add(avl, box(636), box(1446));
+ avl = remove_int(avl, 152);
+ avl = gpr_avl_add(avl, box(61), box(1448));
+ avl = remove_int(avl, 929);
+ avl = remove_int(avl, 9);
+ avl = gpr_avl_add(avl, box(251), box(1451));
+ avl = gpr_avl_add(avl, box(672), box(1452));
+ avl = gpr_avl_add(avl, box(66), box(1453));
+ avl = remove_int(avl, 693);
+ avl = remove_int(avl, 914);
+ avl = remove_int(avl, 116);
+ avl = remove_int(avl, 577);
+ avl = gpr_avl_add(avl, box(618), box(1458));
+ avl = gpr_avl_add(avl, box(495), box(1459));
+ avl = remove_int(avl, 450);
+ avl = gpr_avl_add(avl, box(533), box(1461));
+ avl = gpr_avl_add(avl, box(414), box(1462));
+ avl = remove_int(avl, 74);
+ avl = remove_int(avl, 236);
+ avl = gpr_avl_add(avl, box(707), box(1465));
+ avl = gpr_avl_add(avl, box(357), box(1466));
+ avl = gpr_avl_add(avl, box(1007), box(1467));
+ avl = gpr_avl_add(avl, box(811), box(1468));
+ avl = gpr_avl_add(avl, box(418), box(1469));
+ avl = gpr_avl_add(avl, box(164), box(1470));
+ avl = gpr_avl_add(avl, box(622), box(1471));
+ avl = remove_int(avl, 22);
+ avl = remove_int(avl, 14);
+ avl = remove_int(avl, 732);
+ avl = remove_int(avl, 7);
+ avl = remove_int(avl, 447);
+ avl = gpr_avl_add(avl, box(221), box(1477));
+ avl = gpr_avl_add(avl, box(202), box(1478));
+ avl = gpr_avl_add(avl, box(312), box(1479));
+ avl = remove_int(avl, 274);
+ avl = gpr_avl_add(avl, box(684), box(1481));
+ avl = gpr_avl_add(avl, box(954), box(1482));
+ avl = gpr_avl_add(avl, box(637), box(1483));
+ avl = remove_int(avl, 716);
+ avl = gpr_avl_add(avl, box(198), box(1485));
+ avl = remove_int(avl, 340);
+ avl = remove_int(avl, 137);
+ avl = remove_int(avl, 995);
+ avl = remove_int(avl, 1004);
+ avl = gpr_avl_add(avl, box(661), box(1490));
+ avl = gpr_avl_add(avl, box(862), box(1491));
+ avl = remove_int(avl, 527);
+ avl = gpr_avl_add(avl, box(945), box(1493));
+ avl = remove_int(avl, 355);
+ avl = remove_int(avl, 144);
+ avl = gpr_avl_add(avl, box(229), box(1496));
+ avl = gpr_avl_add(avl, box(237), box(1497));
+ avl = remove_int(avl, 471);
+ avl = remove_int(avl, 901);
+ avl = gpr_avl_add(avl, box(905), box(1500));
+ avl = remove_int(avl, 19);
+ avl = remove_int(avl, 896);
+ avl = remove_int(avl, 585);
+ avl = remove_int(avl, 308);
+ avl = gpr_avl_add(avl, box(547), box(1505));
+ avl = gpr_avl_add(avl, box(552), box(1506));
+ avl = gpr_avl_add(avl, box(30), box(1507));
+ avl = gpr_avl_add(avl, box(445), box(1508));
+ avl = remove_int(avl, 785);
+ avl = remove_int(avl, 185);
+ avl = gpr_avl_add(avl, box(405), box(1511));
+ avl = gpr_avl_add(avl, box(733), box(1512));
+ avl = gpr_avl_add(avl, box(573), box(1513));
+ avl = gpr_avl_add(avl, box(492), box(1514));
+ avl = gpr_avl_add(avl, box(343), box(1515));
+ avl = gpr_avl_add(avl, box(527), box(1516));
+ avl = gpr_avl_add(avl, box(596), box(1517));
+ avl = gpr_avl_add(avl, box(519), box(1518));
+ avl = remove_int(avl, 243);
+ avl = remove_int(avl, 722);
+ avl = gpr_avl_add(avl, box(772), box(1521));
+ avl = remove_int(avl, 152);
+ avl = remove_int(avl, 305);
+ avl = gpr_avl_add(avl, box(754), box(1524));
+ avl = gpr_avl_add(avl, box(373), box(1525));
+ avl = remove_int(avl, 995);
+ avl = gpr_avl_add(avl, box(329), box(1527));
+ avl = remove_int(avl, 397);
+ avl = gpr_avl_add(avl, box(884), box(1529));
+ avl = remove_int(avl, 329);
+ avl = remove_int(avl, 240);
+ avl = gpr_avl_add(avl, box(566), box(1532));
+ avl = gpr_avl_add(avl, box(232), box(1533));
+ avl = remove_int(avl, 993);
+ avl = gpr_avl_add(avl, box(888), box(1535));
+ avl = remove_int(avl, 242);
+ avl = gpr_avl_add(avl, box(941), box(1537));
+ avl = remove_int(avl, 415);
+ avl = gpr_avl_add(avl, box(992), box(1539));
+ avl = remove_int(avl, 289);
+ avl = gpr_avl_add(avl, box(60), box(1541));
+ avl = gpr_avl_add(avl, box(97), box(1542));
+ avl = remove_int(avl, 965);
+ avl = remove_int(avl, 267);
+ avl = remove_int(avl, 360);
+ avl = gpr_avl_add(avl, box(5), box(1546));
+ avl = remove_int(avl, 429);
+ avl = gpr_avl_add(avl, box(412), box(1548));
+ avl = remove_int(avl, 632);
+ avl = remove_int(avl, 113);
+ avl = gpr_avl_add(avl, box(48), box(1551));
+ avl = gpr_avl_add(avl, box(108), box(1552));
+ avl = gpr_avl_add(avl, box(750), box(1553));
+ avl = remove_int(avl, 188);
+ avl = gpr_avl_add(avl, box(668), box(1555));
+ avl = remove_int(avl, 37);
+ avl = remove_int(avl, 737);
+ avl = gpr_avl_add(avl, box(93), box(1558));
+ avl = gpr_avl_add(avl, box(628), box(1559));
+ avl = gpr_avl_add(avl, box(480), box(1560));
+ avl = remove_int(avl, 958);
+ avl = remove_int(avl, 565);
+ avl = remove_int(avl, 32);
+ avl = remove_int(avl, 1);
+ avl = remove_int(avl, 335);
+ avl = gpr_avl_add(avl, box(136), box(1566));
+ avl = gpr_avl_add(avl, box(469), box(1567));
+ avl = remove_int(avl, 349);
+ avl = gpr_avl_add(avl, box(768), box(1569));
+ avl = gpr_avl_add(avl, box(915), box(1570));
+ avl = remove_int(avl, 1014);
+ avl = gpr_avl_add(avl, box(117), box(1572));
+ avl = remove_int(avl, 62);
+ avl = gpr_avl_add(avl, box(382), box(1574));
+ avl = remove_int(avl, 571);
+ avl = gpr_avl_add(avl, box(655), box(1576));
+ avl = gpr_avl_add(avl, box(323), box(1577));
+ avl = remove_int(avl, 869);
+ avl = remove_int(avl, 151);
+ avl = gpr_avl_add(avl, box(1019), box(1580));
+ avl = gpr_avl_add(avl, box(984), box(1581));
+ avl = gpr_avl_add(avl, box(870), box(1582));
+ avl = gpr_avl_add(avl, box(376), box(1583));
+ avl = remove_int(avl, 625);
+ avl = gpr_avl_add(avl, box(733), box(1585));
+ avl = remove_int(avl, 532);
+ avl = remove_int(avl, 444);
+ avl = gpr_avl_add(avl, box(428), box(1588));
+ avl = gpr_avl_add(avl, box(860), box(1589));
+ avl = gpr_avl_add(avl, box(173), box(1590));
+ avl = remove_int(avl, 649);
+ avl = remove_int(avl, 913);
+ avl = remove_int(avl, 1);
+ avl = remove_int(avl, 304);
+ avl = gpr_avl_add(avl, box(604), box(1595));
+ avl = gpr_avl_add(avl, box(639), box(1596));
+ avl = remove_int(avl, 431);
+ avl = gpr_avl_add(avl, box(993), box(1598));
+ avl = remove_int(avl, 681);
+ avl = remove_int(avl, 927);
+ avl = gpr_avl_add(avl, box(87), box(1601));
+ avl = gpr_avl_add(avl, box(91), box(1602));
+ avl = remove_int(avl, 61);
+ avl = remove_int(avl, 14);
+ avl = remove_int(avl, 305);
+ avl = remove_int(avl, 304);
+ avl = remove_int(avl, 1016);
+ avl = gpr_avl_add(avl, box(903), box(1608));
+ avl = gpr_avl_add(avl, box(951), box(1609));
+ avl = gpr_avl_add(avl, box(146), box(1610));
+ avl = gpr_avl_add(avl, box(482), box(1611));
+ avl = gpr_avl_add(avl, box(71), box(1612));
+ avl = remove_int(avl, 246);
+ avl = remove_int(avl, 696);
+ avl = gpr_avl_add(avl, box(636), box(1615));
+ avl = gpr_avl_add(avl, box(295), box(1616));
+ avl = remove_int(avl, 11);
+ avl = remove_int(avl, 231);
+ avl = gpr_avl_add(avl, box(905), box(1619));
+ avl = gpr_avl_add(avl, box(993), box(1620));
+ avl = gpr_avl_add(avl, box(433), box(1621));
+ avl = gpr_avl_add(avl, box(117), box(1622));
+ avl = gpr_avl_add(avl, box(467), box(1623));
+ avl = remove_int(avl, 419);
+ avl = gpr_avl_add(avl, box(179), box(1625));
+ avl = remove_int(avl, 926);
+ avl = remove_int(avl, 326);
+ avl = gpr_avl_add(avl, box(551), box(1628));
+ avl = remove_int(avl, 14);
+ avl = remove_int(avl, 476);
+ avl = remove_int(avl, 823);
+ avl = gpr_avl_add(avl, box(350), box(1632));
+ avl = gpr_avl_add(avl, box(133), box(1633));
+ avl = remove_int(avl, 906);
+ avl = gpr_avl_add(avl, box(827), box(1635));
+ avl = gpr_avl_add(avl, box(201), box(1636));
+ avl = remove_int(avl, 124);
+ avl = remove_int(avl, 662);
+ avl = gpr_avl_add(avl, box(314), box(1639));
+ avl = gpr_avl_add(avl, box(986), box(1640));
+ avl = gpr_avl_add(avl, box(622), box(1641));
+ avl = remove_int(avl, 130);
+ avl = gpr_avl_add(avl, box(861), box(1643));
+ avl = remove_int(avl, 497);
+ avl = remove_int(avl, 905);
+ avl = gpr_avl_add(avl, box(502), box(1646));
+ avl = remove_int(avl, 721);
+ avl = gpr_avl_add(avl, box(514), box(1648));
+ avl = gpr_avl_add(avl, box(410), box(1649));
+ avl = remove_int(avl, 869);
+ avl = remove_int(avl, 247);
+ avl = gpr_avl_add(avl, box(450), box(1652));
+ avl = remove_int(avl, 364);
+ avl = gpr_avl_add(avl, box(963), box(1654));
+ avl = gpr_avl_add(avl, box(146), box(1655));
+ avl = remove_int(avl, 147);
+ avl = remove_int(avl, 789);
+ avl = gpr_avl_add(avl, box(693), box(1658));
+ avl = gpr_avl_add(avl, box(959), box(1659));
+ avl = remove_int(avl, 478);
+ avl = gpr_avl_add(avl, box(116), box(1661));
+ avl = gpr_avl_add(avl, box(520), box(1662));
+ avl = gpr_avl_add(avl, box(809), box(1663));
+ avl = gpr_avl_add(avl, box(667), box(1664));
+ avl = gpr_avl_add(avl, box(406), box(1665));
+ avl = remove_int(avl, 409);
+ avl = gpr_avl_add(avl, box(558), box(1667));
+ avl = gpr_avl_add(avl, box(0), box(1668));
+ avl = gpr_avl_add(avl, box(948), box(1669));
+ avl = gpr_avl_add(avl, box(576), box(1670));
+ avl = remove_int(avl, 864);
+ avl = remove_int(avl, 840);
+ avl = remove_int(avl, 1001);
+ avl = gpr_avl_add(avl, box(232), box(1674));
+ avl = remove_int(avl, 676);
+ avl = remove_int(avl, 752);
+ avl = remove_int(avl, 667);
+ avl = remove_int(avl, 605);
+ avl = gpr_avl_add(avl, box(258), box(1679));
+ avl = gpr_avl_add(avl, box(648), box(1680));
+ avl = gpr_avl_add(avl, box(761), box(1681));
+ avl = remove_int(avl, 293);
+ avl = remove_int(avl, 893);
+ avl = gpr_avl_add(avl, box(194), box(1684));
+ avl = remove_int(avl, 233);
+ avl = gpr_avl_add(avl, box(888), box(1686));
+ avl = remove_int(avl, 470);
+ avl = remove_int(avl, 703);
+ avl = remove_int(avl, 190);
+ avl = remove_int(avl, 359);
+ avl = gpr_avl_add(avl, box(621), box(1691));
+ avl = remove_int(avl, 634);
+ avl = remove_int(avl, 335);
+ avl = gpr_avl_add(avl, box(718), box(1694));
+ avl = gpr_avl_add(avl, box(463), box(1695));
+ avl = gpr_avl_add(avl, box(233), box(1696));
+ avl = remove_int(avl, 376);
+ avl = remove_int(avl, 496);
+ avl = remove_int(avl, 819);
+ avl = remove_int(avl, 38);
+ avl = remove_int(avl, 436);
+ avl = remove_int(avl, 102);
+ avl = gpr_avl_add(avl, box(607), box(1703));
+ avl = remove_int(avl, 329);
+ avl = gpr_avl_add(avl, box(716), box(1705));
+ avl = remove_int(avl, 639);
+ avl = remove_int(avl, 775);
+ avl = remove_int(avl, 578);
+ avl = remove_int(avl, 464);
+ avl = remove_int(avl, 679);
+ avl = remove_int(avl, 615);
+ avl = remove_int(avl, 104);
+ avl = gpr_avl_add(avl, box(414), box(1713));
+ avl = gpr_avl_add(avl, box(212), box(1714));
+ avl = gpr_avl_add(avl, box(266), box(1715));
+ avl = gpr_avl_add(avl, box(238), box(1716));
+ avl = remove_int(avl, 153);
+ avl = gpr_avl_add(avl, box(585), box(1718));
+ avl = remove_int(avl, 121);
+ avl = gpr_avl_add(avl, box(534), box(1720));
+ avl = remove_int(avl, 579);
+ avl = gpr_avl_add(avl, box(127), box(1722));
+ avl = gpr_avl_add(avl, box(399), box(1723));
+ avl = remove_int(avl, 417);
+ avl = gpr_avl_add(avl, box(978), box(1725));
+ avl = gpr_avl_add(avl, box(768), box(1726));
+ avl = remove_int(avl, 985);
+ avl = gpr_avl_add(avl, box(536), box(1728));
+ avl = gpr_avl_add(avl, box(449), box(1729));
+ avl = gpr_avl_add(avl, box(586), box(1730));
+ avl = remove_int(avl, 998);
+ avl = remove_int(avl, 394);
+ avl = remove_int(avl, 141);
+ avl = gpr_avl_add(avl, box(889), box(1734));
+ avl = gpr_avl_add(avl, box(871), box(1735));
+ avl = gpr_avl_add(avl, box(76), box(1736));
+ avl = gpr_avl_add(avl, box(549), box(1737));
+ avl = gpr_avl_add(avl, box(757), box(1738));
+ avl = remove_int(avl, 908);
+ avl = gpr_avl_add(avl, box(789), box(1740));
+ avl = remove_int(avl, 224);
+ avl = gpr_avl_add(avl, box(407), box(1742));
+ avl = gpr_avl_add(avl, box(381), box(1743));
+ avl = gpr_avl_add(avl, box(561), box(1744));
+ avl = gpr_avl_add(avl, box(667), box(1745));
+ avl = gpr_avl_add(avl, box(522), box(1746));
+ avl = gpr_avl_add(avl, box(948), box(1747));
+ avl = remove_int(avl, 770);
+ avl = gpr_avl_add(avl, box(872), box(1749));
+ avl = gpr_avl_add(avl, box(327), box(1750));
+ avl = remove_int(avl, 10);
+ avl = gpr_avl_add(avl, box(122), box(1752));
+ avl = remove_int(avl, 606);
+ avl = gpr_avl_add(avl, box(485), box(1754));
+ avl = remove_int(avl, 6);
+ avl = gpr_avl_add(avl, box(329), box(1756));
+ avl = gpr_avl_add(avl, box(783), box(1757));
+ avl = remove_int(avl, 416);
+ avl = gpr_avl_add(avl, box(656), box(1759));
+ avl = gpr_avl_add(avl, box(971), box(1760));
+ avl = gpr_avl_add(avl, box(77), box(1761));
+ avl = gpr_avl_add(avl, box(942), box(1762));
+ avl = remove_int(avl, 361);
+ avl = gpr_avl_add(avl, box(66), box(1764));
+ avl = gpr_avl_add(avl, box(299), box(1765));
+ avl = gpr_avl_add(avl, box(929), box(1766));
+ avl = gpr_avl_add(avl, box(797), box(1767));
+ avl = remove_int(avl, 869);
+ avl = remove_int(avl, 907);
+ avl = gpr_avl_add(avl, box(870), box(1770));
+ avl = remove_int(avl, 580);
+ avl = remove_int(avl, 120);
+ avl = gpr_avl_add(avl, box(913), box(1773));
+ avl = remove_int(avl, 480);
+ avl = gpr_avl_add(avl, box(489), box(1775));
+ avl = remove_int(avl, 845);
+ avl = gpr_avl_add(avl, box(896), box(1777));
+ avl = remove_int(avl, 567);
+ avl = remove_int(avl, 427);
+ avl = gpr_avl_add(avl, box(443), box(1780));
+ avl = gpr_avl_add(avl, box(3), box(1781));
+ avl = remove_int(avl, 12);
+ avl = gpr_avl_add(avl, box(376), box(1783));
+ avl = gpr_avl_add(avl, box(155), box(1784));
+ avl = gpr_avl_add(avl, box(188), box(1785));
+ avl = gpr_avl_add(avl, box(149), box(1786));
+ avl = gpr_avl_add(avl, box(178), box(1787));
+ avl = remove_int(avl, 84);
+ avl = gpr_avl_add(avl, box(805), box(1789));
+ avl = gpr_avl_add(avl, box(612), box(1790));
+ avl = remove_int(avl, 991);
+ avl = gpr_avl_add(avl, box(837), box(1792));
+ avl = remove_int(avl, 173);
+ avl = remove_int(avl, 72);
+ avl = gpr_avl_add(avl, box(1014), box(1795));
+ avl = remove_int(avl, 303);
+ avl = gpr_avl_add(avl, box(865), box(1797));
+ avl = gpr_avl_add(avl, box(793), box(1798));
+ avl = remove_int(avl, 173);
+ avl = remove_int(avl, 477);
+ avl = gpr_avl_add(avl, box(950), box(1801));
+ avl = gpr_avl_add(avl, box(105), box(1802));
+ avl = gpr_avl_add(avl, box(895), box(1803));
+ avl = gpr_avl_add(avl, box(171), box(1804));
+ avl = gpr_avl_add(avl, box(753), box(1805));
+ avl = gpr_avl_add(avl, box(946), box(1806));
+ avl = remove_int(avl, 194);
+ avl = remove_int(avl, 559);
+ avl = remove_int(avl, 116);
+ avl = gpr_avl_add(avl, box(968), box(1810));
+ avl = remove_int(avl, 124);
+ avl = remove_int(avl, 99);
+ avl = gpr_avl_add(avl, box(563), box(1813));
+ avl = remove_int(avl, 182);
+ avl = gpr_avl_add(avl, box(816), box(1815));
+ avl = remove_int(avl, 73);
+ avl = remove_int(avl, 261);
+ avl = gpr_avl_add(avl, box(847), box(1818));
+ avl = gpr_avl_add(avl, box(368), box(1819));
+ avl = gpr_avl_add(avl, box(808), box(1820));
+ avl = gpr_avl_add(avl, box(779), box(1821));
+ avl = remove_int(avl, 818);
+ avl = gpr_avl_add(avl, box(466), box(1823));
+ avl = remove_int(avl, 316);
+ avl = gpr_avl_add(avl, box(986), box(1825));
+ avl = gpr_avl_add(avl, box(688), box(1826));
+ avl = gpr_avl_add(avl, box(509), box(1827));
+ avl = gpr_avl_add(avl, box(51), box(1828));
+ avl = remove_int(avl, 655);
+ avl = remove_int(avl, 785);
+ avl = remove_int(avl, 893);
+ avl = gpr_avl_add(avl, box(167), box(1832));
+ avl = remove_int(avl, 13);
+ avl = remove_int(avl, 263);
+ avl = gpr_avl_add(avl, box(1009), box(1835));
+ avl = remove_int(avl, 480);
+ avl = remove_int(avl, 778);
+ avl = remove_int(avl, 713);
+ avl = remove_int(avl, 628);
+ avl = gpr_avl_add(avl, box(803), box(1840));
+ avl = remove_int(avl, 267);
+ avl = gpr_avl_add(avl, box(676), box(1842));
+ avl = gpr_avl_add(avl, box(231), box(1843));
+ avl = gpr_avl_add(avl, box(824), box(1844));
+ avl = remove_int(avl, 961);
+ avl = gpr_avl_add(avl, box(311), box(1846));
+ avl = gpr_avl_add(avl, box(420), box(1847));
+ avl = gpr_avl_add(avl, box(960), box(1848));
+ avl = gpr_avl_add(avl, box(468), box(1849));
+ avl = gpr_avl_add(avl, box(815), box(1850));
+ avl = remove_int(avl, 247);
+ avl = remove_int(avl, 194);
+ avl = gpr_avl_add(avl, box(546), box(1853));
+ avl = remove_int(avl, 222);
+ avl = remove_int(avl, 914);
+ avl = remove_int(avl, 741);
+ avl = gpr_avl_add(avl, box(470), box(1857));
+ avl = gpr_avl_add(avl, box(933), box(1858));
+ avl = gpr_avl_add(avl, box(97), box(1859));
+ avl = remove_int(avl, 564);
+ avl = remove_int(avl, 295);
+ avl = gpr_avl_add(avl, box(864), box(1862));
+ avl = remove_int(avl, 329);
+ avl = gpr_avl_add(avl, box(124), box(1864));
+ avl = gpr_avl_add(avl, box(1000), box(1865));
+ avl = gpr_avl_add(avl, box(228), box(1866));
+ avl = gpr_avl_add(avl, box(187), box(1867));
+ avl = remove_int(avl, 224);
+ avl = remove_int(avl, 306);
+ avl = remove_int(avl, 884);
+ avl = gpr_avl_add(avl, box(449), box(1871));
+ avl = gpr_avl_add(avl, box(353), box(1872));
+ avl = gpr_avl_add(avl, box(994), box(1873));
+ avl = gpr_avl_add(avl, box(596), box(1874));
+ avl = gpr_avl_add(avl, box(996), box(1875));
+ avl = gpr_avl_add(avl, box(101), box(1876));
+ avl = gpr_avl_add(avl, box(1012), box(1877));
+ avl = gpr_avl_add(avl, box(982), box(1878));
+ avl = gpr_avl_add(avl, box(742), box(1879));
+ avl = remove_int(avl, 92);
+ avl = remove_int(avl, 1022);
+ avl = gpr_avl_add(avl, box(941), box(1882));
+ avl = remove_int(avl, 742);
+ avl = remove_int(avl, 919);
+ avl = gpr_avl_add(avl, box(588), box(1885));
+ avl = remove_int(avl, 221);
+ avl = gpr_avl_add(avl, box(356), box(1887));
+ avl = gpr_avl_add(avl, box(932), box(1888));
+ avl = remove_int(avl, 837);
+ avl = gpr_avl_add(avl, box(394), box(1890));
+ avl = gpr_avl_add(avl, box(642), box(1891));
+ avl = gpr_avl_add(avl, box(52), box(1892));
+ avl = gpr_avl_add(avl, box(437), box(1893));
+ avl = gpr_avl_add(avl, box(948), box(1894));
+ avl = gpr_avl_add(avl, box(93), box(1895));
+ avl = remove_int(avl, 873);
+ avl = remove_int(avl, 336);
+ avl = remove_int(avl, 277);
+ avl = remove_int(avl, 932);
+ avl = gpr_avl_add(avl, box(80), box(1900));
+ avl = gpr_avl_add(avl, box(952), box(1901));
+ avl = gpr_avl_add(avl, box(510), box(1902));
+ avl = remove_int(avl, 876);
+ avl = remove_int(avl, 612);
+ avl = gpr_avl_add(avl, box(923), box(1905));
+ avl = gpr_avl_add(avl, box(475), box(1906));
+ avl = remove_int(avl, 478);
+ avl = remove_int(avl, 148);
+ avl = gpr_avl_add(avl, box(538), box(1909));
+ avl = remove_int(avl, 47);
+ avl = gpr_avl_add(avl, box(89), box(1911));
+ avl = remove_int(avl, 723);
+ avl = gpr_avl_add(avl, box(687), box(1913));
+ avl = gpr_avl_add(avl, box(480), box(1914));
+ avl = gpr_avl_add(avl, box(149), box(1915));
+ avl = remove_int(avl, 68);
+ avl = remove_int(avl, 862);
+ avl = remove_int(avl, 363);
+ avl = gpr_avl_add(avl, box(996), box(1919));
+ avl = remove_int(avl, 380);
+ avl = gpr_avl_add(avl, box(957), box(1921));
+ avl = remove_int(avl, 413);
+ avl = gpr_avl_add(avl, box(360), box(1923));
+ avl = gpr_avl_add(avl, box(304), box(1924));
+ avl = gpr_avl_add(avl, box(634), box(1925));
+ avl = gpr_avl_add(avl, box(506), box(1926));
+ avl = remove_int(avl, 248);
+ avl = gpr_avl_add(avl, box(124), box(1928));
+ avl = gpr_avl_add(avl, box(181), box(1929));
+ avl = remove_int(avl, 507);
+ avl = gpr_avl_add(avl, box(141), box(1931));
+ avl = remove_int(avl, 409);
+ avl = remove_int(avl, 129);
+ avl = remove_int(avl, 694);
+ avl = remove_int(avl, 723);
+ avl = gpr_avl_add(avl, box(998), box(1936));
+ avl = gpr_avl_add(avl, box(906), box(1937));
+ avl = gpr_avl_add(avl, box(44), box(1938));
+ avl = remove_int(avl, 949);
+ avl = remove_int(avl, 117);
+ avl = gpr_avl_add(avl, box(700), box(1941));
+ avl = gpr_avl_add(avl, box(258), box(1942));
+ avl = remove_int(avl, 828);
+ avl = gpr_avl_add(avl, box(860), box(1944));
+ avl = gpr_avl_add(avl, box(987), box(1945));
+ avl = gpr_avl_add(avl, box(316), box(1946));
+ avl = gpr_avl_add(avl, box(919), box(1947));
+ avl = remove_int(avl, 84);
+ avl = gpr_avl_add(avl, box(473), box(1949));
+ avl = remove_int(avl, 127);
+ avl = remove_int(avl, 829);
+ avl = remove_int(avl, 829);
+ avl = gpr_avl_add(avl, box(488), box(1953));
+ avl = gpr_avl_add(avl, box(954), box(1954));
+ avl = remove_int(avl, 198);
+ avl = remove_int(avl, 972);
+ avl = remove_int(avl, 670);
+ avl = gpr_avl_add(avl, box(822), box(1958));
+ avl = remove_int(avl, 589);
+ avl = remove_int(avl, 459);
+ avl = gpr_avl_add(avl, box(1003), box(1961));
+ avl = gpr_avl_add(avl, box(657), box(1962));
+ avl = gpr_avl_add(avl, box(477), box(1963));
+ avl = gpr_avl_add(avl, box(923), box(1964));
+ avl = remove_int(avl, 496);
+ avl = remove_int(avl, 99);
+ avl = gpr_avl_add(avl, box(127), box(1967));
+ avl = gpr_avl_add(avl, box(1013), box(1968));
+ avl = gpr_avl_add(avl, box(778), box(1969));
+ avl = remove_int(avl, 5);
+ avl = remove_int(avl, 990);
+ avl = remove_int(avl, 850);
+ avl = remove_int(avl, 160);
+ avl = remove_int(avl, 86);
+ avl = gpr_avl_add(avl, box(283), box(1975));
+ avl = remove_int(avl, 278);
+ avl = remove_int(avl, 297);
+ avl = remove_int(avl, 137);
+ avl = remove_int(avl, 653);
+ avl = gpr_avl_add(avl, box(702), box(1980));
+ avl = remove_int(avl, 63);
+ avl = remove_int(avl, 427);
+ avl = remove_int(avl, 706);
+ avl = remove_int(avl, 806);
+ avl = gpr_avl_add(avl, box(335), box(1985));
+ avl = gpr_avl_add(avl, box(412), box(1986));
+ avl = remove_int(avl, 766);
+ avl = remove_int(avl, 937);
+ avl = remove_int(avl, 886);
+ avl = remove_int(avl, 652);
+ avl = gpr_avl_add(avl, box(545), box(1991));
+ avl = gpr_avl_add(avl, box(408), box(1992));
+ avl = gpr_avl_add(avl, box(841), box(1993));
+ avl = remove_int(avl, 593);
+ avl = gpr_avl_add(avl, box(582), box(1995));
+ avl = gpr_avl_add(avl, box(597), box(1996));
+ avl = remove_int(avl, 49);
+ avl = remove_int(avl, 835);
+ avl = gpr_avl_add(avl, box(417), box(1999));
+ avl = gpr_avl_add(avl, box(191), box(2000));
+ avl = remove_int(avl, 406);
+ avl = gpr_avl_add(avl, box(30), box(2002));
+ avl = remove_int(avl, 841);
+ avl = remove_int(avl, 50);
+ avl = gpr_avl_add(avl, box(967), box(2005));
+ avl = gpr_avl_add(avl, box(849), box(2006));
+ avl = remove_int(avl, 608);
+ avl = gpr_avl_add(avl, box(306), box(2008));
+ avl = remove_int(avl, 779);
+ avl = gpr_avl_add(avl, box(897), box(2010));
+ avl = gpr_avl_add(avl, box(147), box(2011));
+ avl = remove_int(avl, 982);
+ avl = gpr_avl_add(avl, box(470), box(2013));
+ avl = remove_int(avl, 951);
+ avl = gpr_avl_add(avl, box(388), box(2015));
+ avl = remove_int(avl, 616);
+ avl = remove_int(avl, 721);
+ avl = remove_int(avl, 942);
+ avl = remove_int(avl, 589);
+ avl = gpr_avl_add(avl, box(218), box(2020));
+ avl = remove_int(avl, 671);
+ avl = gpr_avl_add(avl, box(1020), box(2022));
+ avl = remove_int(avl, 277);
+ avl = gpr_avl_add(avl, box(681), box(2024));
+ avl = gpr_avl_add(avl, box(179), box(2025));
+ avl = gpr_avl_add(avl, box(370), box(2026));
+ avl = gpr_avl_add(avl, box(0), box(2027));
+ avl = remove_int(avl, 523);
+ avl = gpr_avl_add(avl, box(99), box(2029));
+ avl = gpr_avl_add(avl, box(334), box(2030));
+ avl = gpr_avl_add(avl, box(569), box(2031));
+ avl = gpr_avl_add(avl, box(257), box(2032));
+ avl = remove_int(avl, 572);
+ avl = gpr_avl_add(avl, box(805), box(2034));
+ avl = gpr_avl_add(avl, box(143), box(2035));
+ avl = gpr_avl_add(avl, box(670), box(2036));
+ avl = remove_int(avl, 42);
+ avl = gpr_avl_add(avl, box(46), box(2038));
+ avl = remove_int(avl, 970);
+ avl = gpr_avl_add(avl, box(353), box(2040));
+ avl = remove_int(avl, 258);
+ avl = gpr_avl_add(avl, box(451), box(2042));
+ avl = gpr_avl_add(avl, box(28), box(2043));
+ avl = gpr_avl_add(avl, box(729), box(2044));
+ avl = gpr_avl_add(avl, box(401), box(2045));
+ avl = gpr_avl_add(avl, box(614), box(2046));
+ avl = remove_int(avl, 990);
+ avl = remove_int(avl, 212);
+ avl = remove_int(avl, 22);
+ avl = remove_int(avl, 677);
+ avl = gpr_avl_add(avl, box(1016), box(2051));
+ avl = gpr_avl_add(avl, box(980), box(2052));
+ avl = gpr_avl_add(avl, box(990), box(2053));
+ avl = gpr_avl_add(avl, box(355), box(2054));
+ avl = remove_int(avl, 730);
+ avl = remove_int(avl, 37);
+ avl = gpr_avl_add(avl, box(407), box(2057));
+ avl = gpr_avl_add(avl, box(222), box(2058));
+ avl = gpr_avl_add(avl, box(439), box(2059));
+ avl = gpr_avl_add(avl, box(563), box(2060));
+ avl = remove_int(avl, 992);
+ avl = remove_int(avl, 786);
+ avl = gpr_avl_add(avl, box(1), box(2063));
+ avl = gpr_avl_add(avl, box(473), box(2064));
+ avl = gpr_avl_add(avl, box(992), box(2065));
+ avl = remove_int(avl, 190);
+ avl = remove_int(avl, 450);
+ avl = remove_int(avl, 1020);
+ avl = remove_int(avl, 149);
+ avl = gpr_avl_add(avl, box(329), box(2070));
+ avl = gpr_avl_add(avl, box(35), box(2071));
+ avl = remove_int(avl, 843);
+ avl = gpr_avl_add(avl, box(855), box(2073));
+ avl = remove_int(avl, 878);
+ avl = gpr_avl_add(avl, box(993), box(2075));
+ avl = gpr_avl_add(avl, box(87), box(2076));
+ avl = gpr_avl_add(avl, box(572), box(2077));
+ avl = remove_int(avl, 896);
+ avl = gpr_avl_add(avl, box(849), box(2079));
+ avl = remove_int(avl, 597);
+ avl = gpr_avl_add(avl, box(472), box(2081));
+ avl = remove_int(avl, 778);
+ avl = remove_int(avl, 934);
+ avl = remove_int(avl, 314);
+ avl = gpr_avl_add(avl, box(101), box(2085));
+ avl = remove_int(avl, 938);
+ avl = remove_int(avl, 1010);
+ avl = gpr_avl_add(avl, box(579), box(2088));
+ avl = remove_int(avl, 798);
+ avl = remove_int(avl, 88);
+ avl = gpr_avl_add(avl, box(851), box(2091));
+ avl = remove_int(avl, 705);
+ avl = gpr_avl_add(avl, box(26), box(2093));
+ avl = remove_int(avl, 973);
+ avl = gpr_avl_add(avl, box(923), box(2095));
+ avl = remove_int(avl, 668);
+ avl = gpr_avl_add(avl, box(310), box(2097));
+ avl = gpr_avl_add(avl, box(269), box(2098));
+ avl = remove_int(avl, 173);
+ avl = gpr_avl_add(avl, box(279), box(2100));
+ avl = remove_int(avl, 203);
+ avl = gpr_avl_add(avl, box(411), box(2102));
+ avl = remove_int(avl, 950);
+ avl = gpr_avl_add(avl, box(6), box(2104));
+ avl = remove_int(avl, 400);
+ avl = remove_int(avl, 468);
+ avl = remove_int(avl, 271);
+ avl = gpr_avl_add(avl, box(627), box(2108));
+ avl = remove_int(avl, 727);
+ avl = remove_int(avl, 148);
+ avl = remove_int(avl, 98);
+ avl = remove_int(avl, 997);
+ avl = remove_int(avl, 215);
+ avl = remove_int(avl, 628);
+ avl = remove_int(avl, 826);
+ avl = remove_int(avl, 664);
+ avl = gpr_avl_add(avl, box(76), box(2117));
+ avl = remove_int(avl, 194);
+ avl = remove_int(avl, 18);
+ avl = gpr_avl_add(avl, box(727), box(2120));
+ avl = remove_int(avl, 295);
+ avl = gpr_avl_add(avl, box(645), box(2122));
+ avl = remove_int(avl, 321);
+ avl = remove_int(avl, 863);
+ avl = gpr_avl_add(avl, box(824), box(2125));
+ avl = gpr_avl_add(avl, box(651), box(2126));
+ avl = gpr_avl_add(avl, box(804), box(2127));
+ avl = remove_int(avl, 307);
+ avl = gpr_avl_add(avl, box(867), box(2129));
+ avl = remove_int(avl, 384);
+ avl = gpr_avl_add(avl, box(819), box(2131));
+ avl = remove_int(avl, 674);
+ avl = gpr_avl_add(avl, box(76), box(2133));
+ avl = remove_int(avl, 898);
+ avl = gpr_avl_add(avl, box(45), box(2135));
+ avl = gpr_avl_add(avl, box(512), box(2136));
+ avl = remove_int(avl, 773);
+ avl = remove_int(avl, 907);
+ avl = remove_int(avl, 382);
+ avl = remove_int(avl, 95);
+ avl = remove_int(avl, 734);
+ avl = remove_int(avl, 81);
+ avl = gpr_avl_add(avl, box(348), box(2143));
+ avl = remove_int(avl, 509);
+ avl = remove_int(avl, 301);
+ avl = gpr_avl_add(avl, box(861), box(2146));
+ avl = gpr_avl_add(avl, box(918), box(2147));
+ avl = remove_int(avl, 992);
+ avl = gpr_avl_add(avl, box(356), box(2149));
+ avl = remove_int(avl, 64);
+ avl = remove_int(avl, 444);
+ avl = remove_int(avl, 741);
+ avl = gpr_avl_add(avl, box(710), box(2153));
+ avl = gpr_avl_add(avl, box(264), box(2154));
+ avl = remove_int(avl, 347);
+ avl = remove_int(avl, 250);
+ avl = gpr_avl_add(avl, box(82), box(2157));
+ avl = gpr_avl_add(avl, box(571), box(2158));
+ avl = remove_int(avl, 721);
+ avl = remove_int(avl, 622);
+ avl = gpr_avl_add(avl, box(950), box(2161));
+ avl = gpr_avl_add(avl, box(94), box(2162));
+ avl = remove_int(avl, 970);
+ avl = gpr_avl_add(avl, box(815), box(2164));
+ avl = remove_int(avl, 930);
+ avl = remove_int(avl, 703);
+ avl = gpr_avl_add(avl, box(432), box(2167));
+ avl = remove_int(avl, 544);
+ avl = gpr_avl_add(avl, box(21), box(2169));
+ avl = gpr_avl_add(avl, box(186), box(2170));
+ avl = remove_int(avl, 143);
+ avl = gpr_avl_add(avl, box(425), box(2172));
+ avl = remove_int(avl, 769);
+ avl = gpr_avl_add(avl, box(656), box(2174));
+ avl = remove_int(avl, 29);
+ avl = gpr_avl_add(avl, box(464), box(2176));
+ avl = remove_int(avl, 713);
+ avl = gpr_avl_add(avl, box(800), box(2178));
+ avl = remove_int(avl, 621);
+ avl = gpr_avl_add(avl, box(962), box(2180));
+ avl = remove_int(avl, 448);
+ avl = gpr_avl_add(avl, box(878), box(2182));
+ avl = remove_int(avl, 39);
+ avl = remove_int(avl, 999);
+ avl = gpr_avl_add(avl, box(182), box(2185));
+ avl = gpr_avl_add(avl, box(429), box(2186));
+ avl = gpr_avl_add(avl, box(598), box(2187));
+ avl = remove_int(avl, 551);
+ avl = gpr_avl_add(avl, box(827), box(2189));
+ avl = gpr_avl_add(avl, box(809), box(2190));
+ avl = remove_int(avl, 438);
+ avl = remove_int(avl, 811);
+ avl = gpr_avl_add(avl, box(808), box(2193));
+ avl = gpr_avl_add(avl, box(788), box(2194));
+ avl = remove_int(avl, 156);
+ avl = gpr_avl_add(avl, box(933), box(2196));
+ avl = gpr_avl_add(avl, box(344), box(2197));
+ avl = remove_int(avl, 460);
+ avl = gpr_avl_add(avl, box(161), box(2199));
+ avl = gpr_avl_add(avl, box(444), box(2200));
+ avl = remove_int(avl, 597);
+ avl = remove_int(avl, 668);
+ avl = gpr_avl_add(avl, box(703), box(2203));
+ avl = remove_int(avl, 515);
+ avl = gpr_avl_add(avl, box(380), box(2205));
+ avl = gpr_avl_add(avl, box(338), box(2206));
+ avl = remove_int(avl, 550);
+ avl = remove_int(avl, 946);
+ avl = remove_int(avl, 714);
+ avl = remove_int(avl, 739);
+ avl = gpr_avl_add(avl, box(413), box(2211));
+ avl = remove_int(avl, 450);
+ avl = gpr_avl_add(avl, box(411), box(2213));
+ avl = gpr_avl_add(avl, box(117), box(2214));
+ avl = gpr_avl_add(avl, box(322), box(2215));
+ avl = gpr_avl_add(avl, box(915), box(2216));
+ avl = gpr_avl_add(avl, box(410), box(2217));
+ avl = gpr_avl_add(avl, box(66), box(2218));
+ avl = remove_int(avl, 756);
+ avl = remove_int(avl, 596);
+ avl = gpr_avl_add(avl, box(882), box(2221));
+ avl = gpr_avl_add(avl, box(930), box(2222));
+ avl = gpr_avl_add(avl, box(36), box(2223));
+ avl = remove_int(avl, 742);
+ avl = gpr_avl_add(avl, box(539), box(2225));
+ avl = gpr_avl_add(avl, box(596), box(2226));
+ avl = remove_int(avl, 82);
+ avl = remove_int(avl, 686);
+ avl = remove_int(avl, 933);
+ avl = remove_int(avl, 42);
+ avl = remove_int(avl, 340);
+ avl = gpr_avl_add(avl, box(126), box(2232));
+ avl = gpr_avl_add(avl, box(493), box(2233));
+ avl = gpr_avl_add(avl, box(839), box(2234));
+ avl = remove_int(avl, 774);
+ avl = gpr_avl_add(avl, box(337), box(2236));
+ avl = remove_int(avl, 322);
+ avl = gpr_avl_add(avl, box(16), box(2238));
+ avl = remove_int(avl, 73);
+ avl = remove_int(avl, 85);
+ avl = remove_int(avl, 191);
+ avl = remove_int(avl, 541);
+ avl = gpr_avl_add(avl, box(704), box(2243));
+ avl = remove_int(avl, 767);
+ avl = remove_int(avl, 1006);
+ avl = remove_int(avl, 844);
+ avl = remove_int(avl, 742);
+ avl = gpr_avl_add(avl, box(48), box(2248));
+ avl = gpr_avl_add(avl, box(138), box(2249));
+ avl = gpr_avl_add(avl, box(437), box(2250));
+ avl = gpr_avl_add(avl, box(275), box(2251));
+ avl = remove_int(avl, 520);
+ avl = gpr_avl_add(avl, box(1019), box(2253));
+ avl = remove_int(avl, 955);
+ avl = gpr_avl_add(avl, box(270), box(2255));
+ avl = remove_int(avl, 680);
+ avl = remove_int(avl, 698);
+ avl = gpr_avl_add(avl, box(735), box(2258));
+ avl = gpr_avl_add(avl, box(400), box(2259));
+ avl = remove_int(avl, 991);
+ avl = gpr_avl_add(avl, box(263), box(2261));
+ avl = remove_int(avl, 704);
+ avl = gpr_avl_add(avl, box(757), box(2263));
+ avl = remove_int(avl, 194);
+ avl = remove_int(avl, 616);
+ avl = remove_int(avl, 784);
+ avl = gpr_avl_add(avl, box(382), box(2267));
+ avl = gpr_avl_add(avl, box(464), box(2268));
+ avl = gpr_avl_add(avl, box(817), box(2269));
+ avl = remove_int(avl, 445);
+ avl = gpr_avl_add(avl, box(412), box(2271));
+ avl = remove_int(avl, 525);
+ avl = gpr_avl_add(avl, box(299), box(2273));
+ avl = gpr_avl_add(avl, box(464), box(2274));
+ avl = gpr_avl_add(avl, box(715), box(2275));
+ avl = remove_int(avl, 58);
+ avl = remove_int(avl, 218);
+ avl = gpr_avl_add(avl, box(961), box(2278));
+ avl = gpr_avl_add(avl, box(491), box(2279));
+ avl = remove_int(avl, 846);
+ avl = gpr_avl_add(avl, box(762), box(2281));
+ avl = remove_int(avl, 974);
+ avl = remove_int(avl, 887);
+ avl = gpr_avl_add(avl, box(498), box(2284));
+ avl = remove_int(avl, 810);
+ avl = remove_int(avl, 743);
+ avl = remove_int(avl, 22);
+ avl = remove_int(avl, 284);
+ avl = gpr_avl_add(avl, box(482), box(2289));
+ avl = gpr_avl_add(avl, box(1021), box(2290));
+ avl = remove_int(avl, 155);
+ avl = remove_int(avl, 128);
+ avl = gpr_avl_add(avl, box(819), box(2293));
+ avl = gpr_avl_add(avl, box(324), box(2294));
+ avl = remove_int(avl, 196);
+ avl = remove_int(avl, 370);
+ avl = remove_int(avl, 753);
+ avl = remove_int(avl, 56);
+ avl = remove_int(avl, 735);
+ avl = gpr_avl_add(avl, box(272), box(2300));
+ avl = gpr_avl_add(avl, box(474), box(2301));
+ avl = gpr_avl_add(avl, box(719), box(2302));
+ avl = gpr_avl_add(avl, box(236), box(2303));
+ avl = remove_int(avl, 818);
+ avl = gpr_avl_add(avl, box(727), box(2305));
+ avl = remove_int(avl, 892);
+ avl = remove_int(avl, 871);
+ avl = remove_int(avl, 231);
+ avl = gpr_avl_add(avl, box(62), box(2309));
+ avl = gpr_avl_add(avl, box(953), box(2310));
+ avl = remove_int(avl, 701);
+ avl = gpr_avl_add(avl, box(193), box(2312));
+ avl = remove_int(avl, 619);
+ avl = remove_int(avl, 22);
+ avl = remove_int(avl, 804);
+ avl = remove_int(avl, 851);
+ avl = gpr_avl_add(avl, box(286), box(2317));
+ avl = gpr_avl_add(avl, box(751), box(2318));
+ avl = remove_int(avl, 525);
+ avl = gpr_avl_add(avl, box(217), box(2320));
+ avl = remove_int(avl, 336);
+ avl = gpr_avl_add(avl, box(86), box(2322));
+ avl = gpr_avl_add(avl, box(81), box(2323));
+ avl = gpr_avl_add(avl, box(850), box(2324));
+ avl = remove_int(avl, 872);
+ avl = gpr_avl_add(avl, box(402), box(2326));
+ avl = gpr_avl_add(avl, box(54), box(2327));
+ avl = gpr_avl_add(avl, box(980), box(2328));
+ avl = gpr_avl_add(avl, box(845), box(2329));
+ avl = remove_int(avl, 1004);
+ avl = remove_int(avl, 273);
+ avl = remove_int(avl, 879);
+ avl = gpr_avl_add(avl, box(354), box(2333));
+ avl = gpr_avl_add(avl, box(58), box(2334));
+ avl = gpr_avl_add(avl, box(127), box(2335));
+ avl = remove_int(avl, 84);
+ avl = gpr_avl_add(avl, box(360), box(2337));
+ avl = remove_int(avl, 648);
+ avl = remove_int(avl, 488);
+ avl = remove_int(avl, 585);
+ avl = remove_int(avl, 230);
+ avl = gpr_avl_add(avl, box(887), box(2342));
+ avl = remove_int(avl, 558);
+ avl = remove_int(avl, 958);
+ avl = gpr_avl_add(avl, box(822), box(2345));
+ avl = remove_int(avl, 1004);
+ avl = remove_int(avl, 747);
+ avl = gpr_avl_add(avl, box(631), box(2348));
+ avl = gpr_avl_add(avl, box(442), box(2349));
+ avl = remove_int(avl, 957);
+ avl = remove_int(avl, 964);
+ avl = gpr_avl_add(avl, box(10), box(2352));
+ avl = remove_int(avl, 189);
+ avl = gpr_avl_add(avl, box(742), box(2354));
+ avl = remove_int(avl, 108);
+ avl = gpr_avl_add(avl, box(1014), box(2356));
+ avl = remove_int(avl, 266);
+ avl = remove_int(avl, 623);
+ avl = remove_int(avl, 697);
+ avl = gpr_avl_add(avl, box(180), box(2360));
+ avl = remove_int(avl, 472);
+ avl = gpr_avl_add(avl, box(567), box(2362));
+ avl = remove_int(avl, 1020);
+ avl = remove_int(avl, 273);
+ avl = gpr_avl_add(avl, box(864), box(2365));
+ avl = gpr_avl_add(avl, box(1009), box(2366));
+ avl = remove_int(avl, 224);
+ avl = remove_int(avl, 81);
+ avl = gpr_avl_add(avl, box(653), box(2369));
+ avl = remove_int(avl, 67);
+ avl = remove_int(avl, 102);
+ avl = remove_int(avl, 76);
+ avl = remove_int(avl, 935);
+ avl = remove_int(avl, 169);
+ avl = remove_int(avl, 232);
+ avl = remove_int(avl, 79);
+ avl = gpr_avl_add(avl, box(509), box(2377));
+ avl = remove_int(avl, 900);
+ avl = remove_int(avl, 822);
+ avl = remove_int(avl, 945);
+ avl = remove_int(avl, 356);
+ avl = gpr_avl_add(avl, box(443), box(2382));
+ avl = gpr_avl_add(avl, box(925), box(2383));
+ avl = remove_int(avl, 994);
+ avl = remove_int(avl, 324);
+ avl = gpr_avl_add(avl, box(291), box(2386));
+ avl = remove_int(avl, 94);
+ avl = remove_int(avl, 795);
+ avl = remove_int(avl, 42);
+ avl = gpr_avl_add(avl, box(613), box(2390));
+ avl = remove_int(avl, 289);
+ avl = gpr_avl_add(avl, box(980), box(2392));
+ avl = remove_int(avl, 316);
+ avl = gpr_avl_add(avl, box(281), box(2394));
+ avl = gpr_avl_add(avl, box(1006), box(2395));
+ avl = remove_int(avl, 776);
+ avl = gpr_avl_add(avl, box(108), box(2397));
+ avl = gpr_avl_add(avl, box(918), box(2398));
+ avl = remove_int(avl, 721);
+ avl = remove_int(avl, 563);
+ avl = gpr_avl_add(avl, box(925), box(2401));
+ avl = remove_int(avl, 448);
+ avl = remove_int(avl, 198);
+ avl = remove_int(avl, 1);
+ avl = gpr_avl_add(avl, box(160), box(2405));
+ avl = remove_int(avl, 515);
+ avl = gpr_avl_add(avl, box(284), box(2407));
+ avl = gpr_avl_add(avl, box(225), box(2408));
+ avl = remove_int(avl, 304);
+ avl = gpr_avl_add(avl, box(714), box(2410));
+ avl = gpr_avl_add(avl, box(708), box(2411));
+ avl = gpr_avl_add(avl, box(624), box(2412));
+ avl = remove_int(avl, 662);
+ avl = remove_int(avl, 825);
+ avl = remove_int(avl, 383);
+ avl = remove_int(avl, 381);
+ avl = gpr_avl_add(avl, box(194), box(2417));
+ avl = remove_int(avl, 280);
+ avl = remove_int(avl, 25);
+ avl = remove_int(avl, 633);
+ avl = gpr_avl_add(avl, box(897), box(2421));
+ avl = remove_int(avl, 636);
+ avl = remove_int(avl, 596);
+ avl = remove_int(avl, 757);
+ avl = remove_int(avl, 343);
+ avl = remove_int(avl, 162);
+ avl = remove_int(avl, 913);
+ avl = remove_int(avl, 843);
+ avl = remove_int(avl, 280);
+ avl = remove_int(avl, 911);
+ avl = gpr_avl_add(avl, box(1008), box(2431));
+ avl = remove_int(avl, 948);
+ avl = remove_int(avl, 74);
+ avl = remove_int(avl, 571);
+ avl = gpr_avl_add(avl, box(486), box(2435));
+ avl = gpr_avl_add(avl, box(285), box(2436));
+ avl = remove_int(avl, 304);
+ avl = remove_int(avl, 516);
+ avl = gpr_avl_add(avl, box(758), box(2439));
+ avl = gpr_avl_add(avl, box(776), box(2440));
+ avl = remove_int(avl, 696);
+ avl = gpr_avl_add(avl, box(104), box(2442));
+ avl = gpr_avl_add(avl, box(700), box(2443));
+ avl = gpr_avl_add(avl, box(114), box(2444));
+ avl = gpr_avl_add(avl, box(567), box(2445));
+ avl = remove_int(avl, 620);
+ avl = gpr_avl_add(avl, box(270), box(2447));
+ avl = remove_int(avl, 730);
+ avl = gpr_avl_add(avl, box(749), box(2449));
+ avl = gpr_avl_add(avl, box(443), box(2450));
+ avl = remove_int(avl, 457);
+ avl = gpr_avl_add(avl, box(571), box(2452));
+ avl = gpr_avl_add(avl, box(626), box(2453));
+ avl = remove_int(avl, 638);
+ avl = remove_int(avl, 313);
+
+ gpr_avl_unref(avl);
+}
+
+static void test_stress(void) {
+ int added[1024];
+ int i, j;
+ int deletions = 0;
+ gpr_avl avl;
+
+ gpr_log(GPR_DEBUG, "test_stress");
+
+ srand((unsigned)time(NULL));
+ avl = gpr_avl_create(&int_int_vtable);
+
+ memset(added, 0, sizeof(added));
+
+ for (i = 1; deletions < 1000; i++) {
+ int idx = rand() % (int)GPR_ARRAY_SIZE(added);
+ GPR_ASSERT(i);
+ if (rand() < RAND_MAX / 2) {
+ added[idx] = i;
+ fprintf(stderr, "avl = gpr_avl_add(avl, box(%d), box(%d)); /* d=%d */\n",
+ idx, i, deletions);
+ avl = gpr_avl_add(avl, box(idx), box(i));
+ } else {
+ deletions += (added[idx] != 0);
+ added[idx] = 0;
+ fprintf(stderr, "avl = remove_int(avl, %d); /* d=%d */\n", idx,
+ deletions);
+ avl = remove_int(avl, idx);
+ }
+ for (j = 0; j < (int)GPR_ARRAY_SIZE(added); j++) {
+ if (added[j] != 0) {
+ check_get(avl, j, added[j]);
+ } else {
+ check_negget(avl, j);
+ }
+ }
+ }
+
+ gpr_avl_unref(avl);
+}
+
+int main(int argc, char *argv[]) {
+ grpc_test_init(argc, argv);
+
+ test_get();
+ test_ll();
+ test_lr();
+ test_rr();
+ test_rl();
+ test_unbalanced();
+ test_replace();
+ test_remove();
+ test_badcase1();
+ test_badcase2();
+ test_badcase3();
+ test_stress();
+
+ return 0;
+}
diff --git a/test/core/surface/byte_buffer_reader_test.c b/test/core/surface/byte_buffer_reader_test.c
index 7f9cd6b62b..6b41698717 100644
--- a/test/core/surface/byte_buffer_reader_test.c
+++ b/test/core/surface/byte_buffer_reader_test.c
@@ -185,8 +185,8 @@ static void test_byte_buffer_from_reader(void) {
}
static void test_readall(void) {
- char* lotsa_as[512];
- char* lotsa_bs[1024];
+ char *lotsa_as[512];
+ char *lotsa_bs[1024];
gpr_slice slices[2];
grpc_byte_buffer *buffer;
grpc_byte_buffer_reader reader;
diff --git a/test/core/transport/chttp2/hpack_encoder_test.c b/test/core/transport/chttp2/hpack_encoder_test.c
index 6553e0da20..64ea1e3f14 100644
--- a/test/core/transport/chttp2/hpack_encoder_test.c
+++ b/test/core/transport/chttp2/hpack_encoder_test.c
@@ -46,7 +46,6 @@
#define TEST(x) run_test(x, #x)
-grpc_mdctx *g_mdctx;
grpc_chttp2_hpack_compressor g_compressor;
int g_failure = 0;
@@ -76,7 +75,7 @@ static void verify(size_t window_available, int eof, size_t expect_window_used,
e[i - 1].next = &e[i];
e[i].prev = &e[i - 1];
}
- e[i].md = grpc_mdelem_from_strings(g_mdctx, key, value);
+ e[i].md = grpc_mdelem_from_strings(key, value);
}
e[0].prev = NULL;
e[nheaders - 1].next = NULL;
@@ -181,18 +180,18 @@ static void test_decode_table_overflow(void) {
static void run_test(void (*test)(), const char *name) {
gpr_log(GPR_INFO, "RUN TEST: %s", name);
- g_mdctx = grpc_mdctx_create_with_seed(0);
- grpc_chttp2_hpack_compressor_init(&g_compressor, g_mdctx);
+ grpc_chttp2_hpack_compressor_init(&g_compressor);
test();
grpc_chttp2_hpack_compressor_destroy(&g_compressor);
- grpc_mdctx_unref(g_mdctx);
}
int main(int argc, char **argv) {
size_t i;
grpc_test_init(argc, argv);
+ grpc_init();
TEST(test_basic_headers);
TEST(test_decode_table_overflow);
+ grpc_shutdown();
for (i = 0; i < num_to_delete; i++) {
gpr_free(to_delete[i]);
}
diff --git a/test/core/transport/chttp2/hpack_parser_test.c b/test/core/transport/chttp2/hpack_parser_test.c
index 3a313375a4..4456e197af 100644
--- a/test/core/transport/chttp2/hpack_parser_test.c
+++ b/test/core/transport/chttp2/hpack_parser_test.c
@@ -35,6 +35,7 @@
#include <stdarg.h>
+#include <grpc/grpc.h>
#include <grpc/support/alloc.h>
#include <grpc/support/log.h>
#include <grpc/support/slice.h>
@@ -90,9 +91,8 @@ static void test_vector(grpc_chttp2_hpack_parser *parser,
static void test_vectors(grpc_slice_split_mode mode) {
grpc_chttp2_hpack_parser parser;
- grpc_mdctx *mdctx = grpc_mdctx_create();
- grpc_chttp2_hpack_parser_init(&parser, mdctx);
+ grpc_chttp2_hpack_parser_init(&parser);
/* D.2.1 */
test_vector(&parser, mode,
"400a 6375 7374 6f6d 2d6b 6579 0d63 7573"
@@ -110,7 +110,7 @@ static void test_vectors(grpc_slice_split_mode mode) {
test_vector(&parser, mode, "82", ":method", "GET", NULL);
grpc_chttp2_hpack_parser_destroy(&parser);
- grpc_chttp2_hpack_parser_init(&parser, mdctx);
+ grpc_chttp2_hpack_parser_init(&parser);
/* D.3.1 */
test_vector(&parser, mode,
"8286 8441 0f77 7777 2e65 7861 6d70 6c65"
@@ -130,7 +130,7 @@ static void test_vectors(grpc_slice_split_mode mode) {
NULL);
grpc_chttp2_hpack_parser_destroy(&parser);
- grpc_chttp2_hpack_parser_init(&parser, mdctx);
+ grpc_chttp2_hpack_parser_init(&parser);
/* D.4.1 */
test_vector(&parser, mode,
"8286 8441 8cf1 e3c2 e5f2 3a6b a0ab 90f4"
@@ -150,8 +150,9 @@ static void test_vectors(grpc_slice_split_mode mode) {
NULL);
grpc_chttp2_hpack_parser_destroy(&parser);
- grpc_chttp2_hpack_parser_init(&parser, mdctx);
- parser.table.max_bytes = 256;
+ grpc_chttp2_hpack_parser_init(&parser);
+ grpc_chttp2_hptbl_set_max_bytes(&parser.table, 256);
+ grpc_chttp2_hptbl_set_current_table_size(&parser.table, 256);
/* D.5.1 */
test_vector(&parser, mode,
"4803 3330 3258 0770 7269 7661 7465 611d"
@@ -183,8 +184,9 @@ static void test_vectors(grpc_slice_split_mode mode) {
"foo=ASDJKHQKBZXOQWEOPIUAXQWEOIU; max-age=3600; version=1", NULL);
grpc_chttp2_hpack_parser_destroy(&parser);
- grpc_chttp2_hpack_parser_init(&parser, mdctx);
- parser.table.max_bytes = 256;
+ grpc_chttp2_hpack_parser_init(&parser);
+ grpc_chttp2_hptbl_set_max_bytes(&parser.table, 256);
+ grpc_chttp2_hptbl_set_current_table_size(&parser.table, 256);
/* D.6.1 */
test_vector(&parser, mode,
"4882 6402 5885 aec3 771a 4b61 96d0 7abe"
@@ -212,12 +214,13 @@ static void test_vectors(grpc_slice_split_mode mode) {
"set-cookie",
"foo=ASDJKHQKBZXOQWEOPIUAXQWEOIU; max-age=3600; version=1", NULL);
grpc_chttp2_hpack_parser_destroy(&parser);
- grpc_mdctx_unref(mdctx);
}
int main(int argc, char **argv) {
grpc_test_init(argc, argv);
+ grpc_init();
test_vectors(GRPC_SLICE_SPLIT_MERGE_ALL);
test_vectors(GRPC_SLICE_SPLIT_ONE_BYTE);
+ grpc_shutdown();
return 0;
}
diff --git a/test/core/transport/chttp2/hpack_table_test.c b/test/core/transport/chttp2/hpack_table_test.c
index aa3e273a6c..fde352433b 100644
--- a/test/core/transport/chttp2/hpack_table_test.c
+++ b/test/core/transport/chttp2/hpack_table_test.c
@@ -36,10 +36,12 @@
#include <string.h>
#include <stdio.h>
-#include "src/core/support/string.h"
+#include <grpc/grpc.h>
#include <grpc/support/alloc.h>
#include <grpc/support/log.h>
#include <grpc/support/string_util.h>
+
+#include "src/core/support/string.h"
#include "test/core/util/test_config.h"
#define LOG_TEST(x) gpr_log(GPR_INFO, "%s", x)
@@ -58,10 +60,8 @@ static void assert_index(const grpc_chttp2_hptbl *tbl, gpr_uint32 idx,
static void test_static_lookup(void) {
grpc_chttp2_hptbl tbl;
- grpc_mdctx *mdctx;
- mdctx = grpc_mdctx_create();
- grpc_chttp2_hptbl_init(&tbl, mdctx);
+ grpc_chttp2_hptbl_init(&tbl);
LOG_TEST("test_static_lookup");
assert_index(&tbl, 1, ":authority", "");
@@ -127,7 +127,6 @@ static void test_static_lookup(void) {
assert_index(&tbl, 61, "www-authenticate", "");
grpc_chttp2_hptbl_destroy(&tbl);
- grpc_mdctx_unref(mdctx);
}
static void test_many_additions(void) {
@@ -135,17 +134,18 @@ static void test_many_additions(void) {
int i;
char *key;
char *value;
- grpc_mdctx *mdctx;
LOG_TEST("test_many_additions");
- mdctx = grpc_mdctx_create();
- grpc_chttp2_hptbl_init(&tbl, mdctx);
+ grpc_chttp2_hptbl_init(&tbl);
for (i = 0; i < 1000000; i++) {
+ grpc_mdelem *elem;
gpr_asprintf(&key, "K:%d", i);
gpr_asprintf(&value, "VALUE:%d", i);
- grpc_chttp2_hptbl_add(&tbl, grpc_mdelem_from_strings(mdctx, key, value));
+ elem = grpc_mdelem_from_strings(key, value);
+ GPR_ASSERT(grpc_chttp2_hptbl_add(&tbl, elem));
+ GRPC_MDELEM_UNREF(elem);
assert_index(&tbl, 1 + GRPC_CHTTP2_LAST_STATIC_ENTRY, key, value);
gpr_free(key);
gpr_free(value);
@@ -159,13 +159,12 @@ static void test_many_additions(void) {
}
grpc_chttp2_hptbl_destroy(&tbl);
- grpc_mdctx_unref(mdctx);
}
static grpc_chttp2_hptbl_find_result find_simple(grpc_chttp2_hptbl *tbl,
const char *key,
const char *value) {
- grpc_mdelem *md = grpc_mdelem_from_strings(tbl->mdctx, key, value);
+ grpc_mdelem *md = grpc_mdelem_from_strings(key, value);
grpc_chttp2_hptbl_find_result r = grpc_chttp2_hptbl_find(tbl, md);
GRPC_MDELEM_UNREF(md);
return r;
@@ -173,18 +172,23 @@ static grpc_chttp2_hptbl_find_result find_simple(grpc_chttp2_hptbl *tbl,
static void test_find(void) {
grpc_chttp2_hptbl tbl;
- int i;
+ gpr_uint32 i;
char buffer[32];
- grpc_mdctx *mdctx;
+ grpc_mdelem *elem;
grpc_chttp2_hptbl_find_result r;
LOG_TEST("test_find");
- mdctx = grpc_mdctx_create();
- grpc_chttp2_hptbl_init(&tbl, mdctx);
- grpc_chttp2_hptbl_add(&tbl, grpc_mdelem_from_strings(mdctx, "abc", "xyz"));
- grpc_chttp2_hptbl_add(&tbl, grpc_mdelem_from_strings(mdctx, "abc", "123"));
- grpc_chttp2_hptbl_add(&tbl, grpc_mdelem_from_strings(mdctx, "x", "1"));
+ grpc_chttp2_hptbl_init(&tbl);
+ elem = grpc_mdelem_from_strings("abc", "xyz");
+ GPR_ASSERT(grpc_chttp2_hptbl_add(&tbl, elem));
+ GRPC_MDELEM_UNREF(elem);
+ elem = grpc_mdelem_from_strings("abc", "123");
+ GPR_ASSERT(grpc_chttp2_hptbl_add(&tbl, elem));
+ GRPC_MDELEM_UNREF(elem);
+ elem = grpc_mdelem_from_strings("x", "1");
+ GPR_ASSERT(grpc_chttp2_hptbl_add(&tbl, elem));
+ GRPC_MDELEM_UNREF(elem);
r = find_simple(&tbl, "abc", "123");
GPR_ASSERT(r.index == 2 + GRPC_CHTTP2_LAST_STATIC_ENTRY);
@@ -233,8 +237,9 @@ static void test_find(void) {
/* overflow the string buffer, check find still works */
for (i = 0; i < 10000; i++) {
gpr_ltoa(i, buffer);
- grpc_chttp2_hptbl_add(&tbl,
- grpc_mdelem_from_strings(mdctx, "test", buffer));
+ elem = grpc_mdelem_from_strings("test", buffer);
+ GPR_ASSERT(grpc_chttp2_hptbl_add(&tbl, elem));
+ GRPC_MDELEM_UNREF(elem);
}
r = find_simple(&tbl, "abc", "123");
@@ -250,7 +255,7 @@ static void test_find(void) {
GPR_ASSERT(r.has_value == 1);
for (i = 0; i < tbl.num_ents; i++) {
- int expect = 9999 - i;
+ gpr_uint32 expect = 9999 - i;
gpr_ltoa(expect, buffer);
r = find_simple(&tbl, "test", buffer);
@@ -263,13 +268,14 @@ static void test_find(void) {
GPR_ASSERT(r.has_value == 0);
grpc_chttp2_hptbl_destroy(&tbl);
- grpc_mdctx_unref(mdctx);
}
int main(int argc, char **argv) {
grpc_test_init(argc, argv);
+ grpc_init();
test_static_lookup();
test_many_additions();
test_find();
+ grpc_shutdown();
return 0;
}
diff --git a/test/core/transport/metadata_test.c b/test/core/transport/metadata_test.c
index 080e86cb63..9c1eae9552 100644
--- a/test/core/transport/metadata_test.c
+++ b/test/core/transport/metadata_test.c
@@ -35,11 +35,13 @@
#include <stdio.h>
-#include "src/core/support/string.h"
-#include "src/core/transport/chttp2/bin_encoder.h"
+#include <grpc/grpc.h>
#include <grpc/support/alloc.h>
#include <grpc/support/log.h>
#include <grpc/support/string_util.h>
+
+#include "src/core/support/string.h"
+#include "src/core/transport/chttp2/bin_encoder.h"
#include "test/core/util/test_config.h"
#define LOG_TEST(x) gpr_log(GPR_INFO, "%s", x)
@@ -48,44 +50,39 @@
#define MANY 10000
static void test_no_op(void) {
- grpc_mdctx *ctx;
-
LOG_TEST("test_no_op");
-
- ctx = grpc_mdctx_create();
- grpc_mdctx_unref(ctx);
+ grpc_init();
+ grpc_shutdown();
}
static void test_create_string(void) {
- grpc_mdctx *ctx;
grpc_mdstr *s1, *s2, *s3;
LOG_TEST("test_create_string");
- ctx = grpc_mdctx_create();
- s1 = grpc_mdstr_from_string(ctx, "hello");
- s2 = grpc_mdstr_from_string(ctx, "hello");
- s3 = grpc_mdstr_from_string(ctx, "very much not hello");
+ grpc_init();
+ s1 = grpc_mdstr_from_string("hello");
+ s2 = grpc_mdstr_from_string("hello");
+ s3 = grpc_mdstr_from_string("very much not hello");
GPR_ASSERT(s1 == s2);
GPR_ASSERT(s3 != s1);
GPR_ASSERT(gpr_slice_str_cmp(s1->slice, "hello") == 0);
GPR_ASSERT(gpr_slice_str_cmp(s3->slice, "very much not hello") == 0);
GRPC_MDSTR_UNREF(s1);
GRPC_MDSTR_UNREF(s2);
- grpc_mdctx_unref(ctx);
GRPC_MDSTR_UNREF(s3);
+ grpc_shutdown();
}
static void test_create_metadata(void) {
- grpc_mdctx *ctx;
grpc_mdelem *m1, *m2, *m3;
LOG_TEST("test_create_metadata");
- ctx = grpc_mdctx_create();
- m1 = grpc_mdelem_from_strings(ctx, "a", "b");
- m2 = grpc_mdelem_from_strings(ctx, "a", "b");
- m3 = grpc_mdelem_from_strings(ctx, "a", "c");
+ grpc_init();
+ m1 = grpc_mdelem_from_strings("a", "b");
+ m2 = grpc_mdelem_from_strings("a", "b");
+ m3 = grpc_mdelem_from_strings("a", "c");
GPR_ASSERT(m1 == m2);
GPR_ASSERT(m3 != m1);
GPR_ASSERT(m3->key == m1->key);
@@ -96,32 +93,25 @@ static void test_create_metadata(void) {
GRPC_MDELEM_UNREF(m1);
GRPC_MDELEM_UNREF(m2);
GRPC_MDELEM_UNREF(m3);
- grpc_mdctx_unref(ctx);
+ grpc_shutdown();
}
static void test_create_many_ephemeral_metadata(void) {
- grpc_mdctx *ctx;
char buffer[GPR_LTOA_MIN_BUFSIZE];
long i;
- size_t mdtab_capacity_before;
LOG_TEST("test_create_many_ephemeral_metadata");
- ctx = grpc_mdctx_create();
- mdtab_capacity_before = grpc_mdctx_get_mdtab_capacity_test_only(ctx);
+ grpc_init();
/* add, and immediately delete a bunch of different elements */
for (i = 0; i < MANY; i++) {
gpr_ltoa(i, buffer);
- GRPC_MDELEM_UNREF(grpc_mdelem_from_strings(ctx, "a", buffer));
+ GRPC_MDELEM_UNREF(grpc_mdelem_from_strings("a", buffer));
}
- /* capacity should not grow */
- GPR_ASSERT(mdtab_capacity_before ==
- grpc_mdctx_get_mdtab_capacity_test_only(ctx));
- grpc_mdctx_unref(ctx);
+ grpc_shutdown();
}
static void test_create_many_persistant_metadata(void) {
- grpc_mdctx *ctx;
char buffer[GPR_LTOA_MIN_BUFSIZE];
long i;
grpc_mdelem **created = gpr_malloc(sizeof(grpc_mdelem *) * MANY);
@@ -129,16 +119,16 @@ static void test_create_many_persistant_metadata(void) {
LOG_TEST("test_create_many_persistant_metadata");
- ctx = grpc_mdctx_create();
+ grpc_init();
/* add phase */
for (i = 0; i < MANY; i++) {
gpr_ltoa(i, buffer);
- created[i] = grpc_mdelem_from_strings(ctx, "a", buffer);
+ created[i] = grpc_mdelem_from_strings("a", buffer);
}
/* verify phase */
for (i = 0; i < MANY; i++) {
gpr_ltoa(i, buffer);
- md = grpc_mdelem_from_strings(ctx, "a", buffer);
+ md = grpc_mdelem_from_strings("a", buffer);
GPR_ASSERT(md == created[i]);
GRPC_MDELEM_UNREF(md);
}
@@ -146,37 +136,22 @@ static void test_create_many_persistant_metadata(void) {
for (i = 0; i < MANY; i++) {
GRPC_MDELEM_UNREF(created[i]);
}
- grpc_mdctx_unref(ctx);
+ grpc_shutdown();
gpr_free(created);
}
static void test_spin_creating_the_same_thing(void) {
- grpc_mdctx *ctx;
-
LOG_TEST("test_spin_creating_the_same_thing");
- ctx = grpc_mdctx_create();
- GPR_ASSERT(grpc_mdctx_get_mdtab_count_test_only(ctx) == 0);
- GPR_ASSERT(grpc_mdctx_get_mdtab_free_test_only(ctx) == 0);
-
- GRPC_MDELEM_UNREF(grpc_mdelem_from_strings(ctx, "a", "b"));
- GPR_ASSERT(grpc_mdctx_get_mdtab_count_test_only(ctx) == 1);
- GPR_ASSERT(grpc_mdctx_get_mdtab_free_test_only(ctx) == 1);
-
- GRPC_MDELEM_UNREF(grpc_mdelem_from_strings(ctx, "a", "b"));
- GPR_ASSERT(grpc_mdctx_get_mdtab_count_test_only(ctx) == 1);
- GPR_ASSERT(grpc_mdctx_get_mdtab_free_test_only(ctx) == 1);
-
- GRPC_MDELEM_UNREF(grpc_mdelem_from_strings(ctx, "a", "b"));
- GPR_ASSERT(grpc_mdctx_get_mdtab_count_test_only(ctx) == 1);
- GPR_ASSERT(grpc_mdctx_get_mdtab_free_test_only(ctx) == 1);
-
- grpc_mdctx_unref(ctx);
+ grpc_init();
+ GRPC_MDELEM_UNREF(grpc_mdelem_from_strings("a", "b"));
+ GRPC_MDELEM_UNREF(grpc_mdelem_from_strings("a", "b"));
+ GRPC_MDELEM_UNREF(grpc_mdelem_from_strings("a", "b"));
+ grpc_shutdown();
}
static void test_things_stick_around(void) {
- grpc_mdctx *ctx;
size_t i, j;
char *buffer;
size_t nstrs = 1000;
@@ -186,11 +161,11 @@ static void test_things_stick_around(void) {
LOG_TEST("test_things_stick_around");
- ctx = grpc_mdctx_create();
+ grpc_init();
for (i = 0; i < nstrs; i++) {
gpr_asprintf(&buffer, "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx%dx", i);
- strs[i] = grpc_mdstr_from_string(ctx, buffer);
+ strs[i] = grpc_mdstr_from_string(buffer);
shuf[i] = i;
gpr_free(buffer);
}
@@ -212,60 +187,58 @@ static void test_things_stick_around(void) {
GRPC_MDSTR_UNREF(strs[shuf[i]]);
for (j = i + 1; j < nstrs; j++) {
gpr_asprintf(&buffer, "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx%dx", shuf[j]);
- test = grpc_mdstr_from_string(ctx, buffer);
+ test = grpc_mdstr_from_string(buffer);
GPR_ASSERT(test == strs[shuf[j]]);
GRPC_MDSTR_UNREF(test);
gpr_free(buffer);
}
}
- grpc_mdctx_unref(ctx);
+ grpc_shutdown();
gpr_free(strs);
gpr_free(shuf);
}
static void test_slices_work(void) {
/* ensure no memory leaks when switching representation from mdstr to slice */
- grpc_mdctx *ctx;
grpc_mdstr *str;
gpr_slice slice;
LOG_TEST("test_slices_work");
- ctx = grpc_mdctx_create();
+ grpc_init();
str = grpc_mdstr_from_string(
- ctx, "123456789012345678901234567890123456789012345678901234567890");
+ "123456789012345678901234567890123456789012345678901234567890");
slice = gpr_slice_ref(str->slice);
GRPC_MDSTR_UNREF(str);
gpr_slice_unref(slice);
str = grpc_mdstr_from_string(
- ctx, "123456789012345678901234567890123456789012345678901234567890");
+ "123456789012345678901234567890123456789012345678901234567890");
slice = gpr_slice_ref(str->slice);
gpr_slice_unref(slice);
GRPC_MDSTR_UNREF(str);
- grpc_mdctx_unref(ctx);
+ grpc_shutdown();
}
static void test_base64_and_huffman_works(void) {
- grpc_mdctx *ctx;
grpc_mdstr *str;
gpr_slice slice1;
gpr_slice slice2;
LOG_TEST("test_base64_and_huffman_works");
- ctx = grpc_mdctx_create();
- str = grpc_mdstr_from_string(ctx, "abcdefg");
+ grpc_init();
+ str = grpc_mdstr_from_string("abcdefg");
slice1 = grpc_mdstr_as_base64_encoded_and_huffman_compressed(str);
slice2 = grpc_chttp2_base64_encode_and_huffman_compress(str->slice);
GPR_ASSERT(0 == gpr_slice_cmp(slice1, slice2));
gpr_slice_unref(slice2);
GRPC_MDSTR_UNREF(str);
- grpc_mdctx_unref(ctx);
+ grpc_shutdown();
}
int main(int argc, char **argv) {
diff --git a/test/core/util/reconnect_server.c b/test/core/util/reconnect_server.c
index ee481ef674..28e521221b 100644
--- a/test/core/util/reconnect_server.c
+++ b/test/core/util/reconnect_server.c
@@ -44,6 +44,7 @@
#include "src/core/iomgr/sockaddr.h"
#include "src/core/iomgr/tcp_server.h"
#include "test/core/util/port.h"
+#include "test/core/util/test_tcp_server.h"
static void pretty_print_backoffs(reconnect_server *server) {
gpr_timespec diff;
@@ -102,47 +103,18 @@ static void on_connect(grpc_exec_ctx *exec_ctx, void *arg, grpc_endpoint *tcp) {
}
void reconnect_server_init(reconnect_server *server) {
- grpc_init();
- server->tcp_server = NULL;
- grpc_pollset_init(&server->pollset);
- server->pollsets[0] = &server->pollset;
+ test_tcp_server_init(&server->tcp_server, on_connect, server);
server->head = NULL;
server->tail = NULL;
server->peer = NULL;
}
void reconnect_server_start(reconnect_server *server, int port) {
- struct sockaddr_in addr;
- int port_added;
- grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
-
- addr.sin_family = AF_INET;
- addr.sin_port = htons((gpr_uint16)port);
- memset(&addr.sin_addr, 0, sizeof(addr.sin_addr));
-
- server->tcp_server = grpc_tcp_server_create();
- port_added =
- grpc_tcp_server_add_port(server->tcp_server, &addr, sizeof(addr));
- GPR_ASSERT(port_added == port);
-
- grpc_tcp_server_start(&exec_ctx, server->tcp_server, server->pollsets, 1,
- on_connect, server);
- gpr_log(GPR_INFO, "reconnect tcp server listening on 0.0.0.0:%d", port);
-
- grpc_exec_ctx_finish(&exec_ctx);
+ test_tcp_server_start(&server->tcp_server, port);
}
void reconnect_server_poll(reconnect_server *server, int seconds) {
- grpc_pollset_worker worker;
- gpr_timespec deadline =
- gpr_time_add(gpr_now(GPR_CLOCK_MONOTONIC),
- gpr_time_from_seconds(seconds, GPR_TIMESPAN));
- grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
- gpr_mu_lock(GRPC_POLLSET_MU(&server->pollset));
- grpc_pollset_work(&exec_ctx, &server->pollset, &worker,
- gpr_now(GPR_CLOCK_MONOTONIC), deadline);
- gpr_mu_unlock(GRPC_POLLSET_MU(&server->pollset));
- grpc_exec_ctx_finish(&exec_ctx);
+ test_tcp_server_poll(&server->tcp_server, seconds);
}
void reconnect_server_clear_timestamps(reconnect_server *server) {
@@ -157,18 +129,7 @@ void reconnect_server_clear_timestamps(reconnect_server *server) {
server->peer = NULL;
}
-static void do_nothing(grpc_exec_ctx *exec_ctx, void *ignored, int success) {}
-
void reconnect_server_destroy(reconnect_server *server) {
- grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
- grpc_closure do_nothing_closure[2];
- grpc_closure_init(&do_nothing_closure[0], do_nothing, NULL);
- grpc_closure_init(&do_nothing_closure[1], do_nothing, NULL);
- grpc_tcp_server_destroy(&exec_ctx, server->tcp_server,
- &do_nothing_closure[0]);
reconnect_server_clear_timestamps(server);
- grpc_pollset_shutdown(&exec_ctx, &server->pollset, &do_nothing_closure[1]);
- grpc_exec_ctx_finish(&exec_ctx);
- grpc_pollset_destroy(&server->pollset);
- grpc_shutdown();
+ test_tcp_server_destroy(&server->tcp_server);
}
diff --git a/test/core/util/reconnect_server.h b/test/core/util/reconnect_server.h
index 8a278e0c7a..e2e6a02461 100644
--- a/test/core/util/reconnect_server.h
+++ b/test/core/util/reconnect_server.h
@@ -36,7 +36,7 @@
#include <grpc/support/sync.h>
#include <grpc/support/time.h>
-#include "src/core/iomgr/tcp_server.h"
+#include "test/core/util/test_tcp_server.h"
#ifdef __cplusplus
extern "C" {
@@ -48,9 +48,7 @@ typedef struct timestamp_list {
} timestamp_list;
typedef struct reconnect_server {
- grpc_tcp_server *tcp_server;
- grpc_pollset pollset;
- grpc_pollset *pollsets[1];
+ test_tcp_server tcp_server;
timestamp_list *head;
timestamp_list *tail;
char *peer;
diff --git a/test/core/util/test_tcp_server.c b/test/core/util/test_tcp_server.c
new file mode 100644
index 0000000000..c700d3637f
--- /dev/null
+++ b/test/core/util/test_tcp_server.c
@@ -0,0 +1,120 @@
+/*
+ *
+ * Copyright 2015, Google Inc.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ *
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following disclaimer
+ * in the documentation and/or other materials provided with the
+ * distribution.
+ * * Neither the name of Google Inc. nor the names of its
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#include "test/core/util/test_tcp_server.h"
+
+#include <grpc/grpc.h>
+#include <grpc/support/alloc.h>
+#include <grpc/support/host_port.h>
+#include <grpc/support/log.h>
+#include <grpc/support/sync.h>
+#include <grpc/support/time.h>
+#include <string.h>
+#include "src/core/iomgr/endpoint.h"
+#include "src/core/iomgr/sockaddr.h"
+#include "src/core/iomgr/tcp_server.h"
+#include "test/core/util/port.h"
+
+void test_tcp_server_init(test_tcp_server *server,
+ grpc_tcp_server_cb on_connect, void *user_data) {
+ grpc_init();
+ server->tcp_server = NULL;
+ server->shutdown = 0;
+ grpc_pollset_init(&server->pollset);
+ server->pollsets[0] = &server->pollset;
+ server->on_connect = on_connect;
+ server->cb_data = user_data;
+}
+
+void test_tcp_server_start(test_tcp_server *server, int port) {
+ struct sockaddr_in addr;
+ grpc_tcp_listener *listener;
+ int port_added;
+ grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
+
+ addr.sin_family = AF_INET;
+ addr.sin_port = htons((gpr_uint16)port);
+ memset(&addr.sin_addr, 0, sizeof(addr.sin_addr));
+
+ server->tcp_server = grpc_tcp_server_create();
+ listener = grpc_tcp_server_add_port(server->tcp_server, &addr, sizeof(addr));
+ port_added = grpc_tcp_listener_get_port(listener);
+ GPR_ASSERT(port_added == port);
+
+ grpc_tcp_server_start(&exec_ctx, server->tcp_server, server->pollsets, 1,
+ server->on_connect, server->cb_data);
+ gpr_log(GPR_INFO, "test tcp server listening on 0.0.0.0:%d", port);
+
+ grpc_exec_ctx_finish(&exec_ctx);
+}
+
+void test_tcp_server_poll(test_tcp_server *server, int seconds) {
+ grpc_pollset_worker worker;
+ gpr_timespec deadline =
+ gpr_time_add(gpr_now(GPR_CLOCK_MONOTONIC),
+ gpr_time_from_seconds(seconds, GPR_TIMESPAN));
+ grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
+ gpr_mu_lock(GRPC_POLLSET_MU(&server->pollset));
+ grpc_pollset_work(&exec_ctx, &server->pollset, &worker,
+ gpr_now(GPR_CLOCK_MONOTONIC), deadline);
+ gpr_mu_unlock(GRPC_POLLSET_MU(&server->pollset));
+ grpc_exec_ctx_finish(&exec_ctx);
+}
+
+static void on_server_destroyed(grpc_exec_ctx *exec_ctx, void *data,
+ int success) {
+ test_tcp_server *server = data;
+ server->shutdown = 1;
+}
+
+static void do_nothing(grpc_exec_ctx *exec_ctx, void *arg, int success) {}
+
+void test_tcp_server_destroy(test_tcp_server *server) {
+ grpc_exec_ctx exec_ctx = GRPC_EXEC_CTX_INIT;
+ gpr_timespec shutdown_deadline;
+ grpc_closure server_shutdown_cb;
+ grpc_closure do_nothing_cb;
+ grpc_closure_init(&server_shutdown_cb, on_server_destroyed, server);
+ grpc_closure_init(&do_nothing_cb, do_nothing, NULL);
+ grpc_tcp_server_destroy(&exec_ctx, server->tcp_server, &server_shutdown_cb);
+ shutdown_deadline = gpr_time_add(gpr_now(GPR_CLOCK_MONOTONIC),
+ gpr_time_from_seconds(5, GPR_TIMESPAN));
+ while (!server->shutdown &&
+ gpr_time_cmp(gpr_now(GPR_CLOCK_MONOTONIC), shutdown_deadline) < 0) {
+ test_tcp_server_poll(server, 1);
+ }
+ grpc_pollset_shutdown(&exec_ctx, &server->pollset, &do_nothing_cb);
+ grpc_exec_ctx_finish(&exec_ctx);
+ grpc_pollset_destroy(&server->pollset);
+ grpc_shutdown();
+}
diff --git a/test/core/util/test_tcp_server.h b/test/core/util/test_tcp_server.h
new file mode 100644
index 0000000000..deb65eef11
--- /dev/null
+++ b/test/core/util/test_tcp_server.h
@@ -0,0 +1,55 @@
+/*
+ *
+ * Copyright 2015, Google Inc.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ *
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following disclaimer
+ * in the documentation and/or other materials provided with the
+ * distribution.
+ * * Neither the name of Google Inc. nor the names of its
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#ifndef GRPC_TEST_CORE_UTIL_TEST_TCP_SERVER_H
+#define GRPC_TEST_CORE_UTIL_TEST_TCP_SERVER_H
+
+#include <grpc/support/sync.h>
+#include "src/core/iomgr/tcp_server.h"
+
+typedef struct test_tcp_server {
+ grpc_tcp_server *tcp_server;
+ int shutdown;
+ grpc_pollset pollset;
+ grpc_pollset *pollsets[1];
+ grpc_tcp_server_cb on_connect;
+ void *cb_data;
+} test_tcp_server;
+
+void test_tcp_server_init(test_tcp_server *server,
+ grpc_tcp_server_cb on_connect, void *user_data);
+void test_tcp_server_start(test_tcp_server *server, int port);
+void test_tcp_server_poll(test_tcp_server *server, int seconds);
+void test_tcp_server_destroy(test_tcp_server *server);
+
+#endif /* GRPC_TEST_CORE_UTIL_TEST_TCP_SERVER_H */