Skip to content

Commit

Permalink
AER-6786 - accurate (as opposed to pessimistic) size check.
Browse files Browse the repository at this point in the history
  • Loading branch information
gooding470 committed Dec 16, 2024
1 parent 14b718e commit dd860f5
Showing 1 changed file with 5 additions and 2 deletions.
7 changes: 5 additions & 2 deletions as/src/query/query.c
Original file line number Diff line number Diff line change
Expand Up @@ -2385,8 +2385,11 @@ aggr_query_add_val_response(aggr_query_slice* slice, const as_val* val,
bool success)
{
uint32_t size = as_particle_asval_client_value_size(val);
cf_buf_builder* bb = *slice->bb_r;

if (size > PROTO_SIZE_MAX - QUERY_CHUNK_LIMIT) {
// Note - 7 is name length of SUCCESS or FAILURE bin. TODO - clean up.
if (size + sizeof(as_msg) + sizeof(as_msg_op) + 7 + bb->used_sz >
PROTO_SIZE_MAX) {
cf_warning(AS_QUERY, "aggregation output too big (%u)", size);

// TODO - hack for hotfix - replace eventually ...
Expand All @@ -2397,8 +2400,8 @@ aggr_query_add_val_response(aggr_query_slice* slice, const as_val* val,
}

as_msg_make_val_response_bufbuilder(val, slice->bb_r, size, success);
bb = *slice->bb_r;

cf_buf_builder* bb = *slice->bb_r;
conn_query_job* conn_job = (conn_query_job*)slice->job;

// If we exceed the proto size limit, send accumulated data back to client
Expand Down

0 comments on commit dd860f5

Please sign in to comment.