Files
grpc/test/core/slice/slice_buffer_test.cc
Craig Tiller 339906443b [clang-format] Match include file ordering to internal clang-format (#40905)
gRPC is currently getting formatted with two different clang-format implementations, and due to some weirdness they have different include file orderings. This change introduces clang-format configuration to ensure that the two systems align - it's *highly* expected that this will need some maintenance going forward as the two systems evolve.

Closes #40905

PiperOrigin-RevId: 819606209
2025-10-15 00:24:11 -07:00

83 lines
2.6 KiB
C++

// Copyright 2022 The gRPC Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include "src/core/lib/slice/slice_buffer.h"
#include <grpc/slice.h>
#include <grpc/support/alloc.h>
#include <grpc/support/port_platform.h>
#include <string.h>
#include <memory>
#include <utility>
#include "src/core/lib/slice/slice.h"
#include "src/core/util/grpc_check.h"
#include "gtest/gtest.h"
using ::grpc_core::Slice;
using ::grpc_core::SliceBuffer;
static constexpr int kNewSliceLength = 100;
Slice MakeSlice(size_t len) {
GRPC_CHECK_GT(len, 0);
unsigned char* contents = static_cast<unsigned char*>(gpr_malloc(len));
memset(contents, 'a', len);
return Slice(grpc_slice_new(contents, len, gpr_free));
}
TEST(SliceBufferTest, AddAndRemoveTest) {
SliceBuffer sb;
Slice first_slice = MakeSlice(kNewSliceLength);
Slice second_slice = MakeSlice(kNewSliceLength);
Slice first_slice_copy = first_slice.Copy();
sb.Append(std::move(first_slice));
sb.Append(std::move(second_slice));
ASSERT_EQ(sb.Count(), 2);
ASSERT_EQ(sb.Length(), 2 * kNewSliceLength);
Slice popped = sb.TakeFirst();
ASSERT_EQ(popped, first_slice_copy);
ASSERT_EQ(sb.Count(), 1);
ASSERT_EQ(sb.Length(), kNewSliceLength);
sb.Prepend(std::move(popped));
ASSERT_EQ(sb.Count(), 2);
ASSERT_EQ(sb.Length(), 2 * kNewSliceLength);
sb.Clear();
ASSERT_EQ(sb.Count(), 0);
ASSERT_EQ(sb.Length(), 0);
}
TEST(SliceBufferTest, SliceRefTest) {
SliceBuffer sb;
Slice first_slice = MakeSlice(kNewSliceLength);
Slice second_slice = MakeSlice(kNewSliceLength + 1);
Slice first_slice_copy = first_slice.Copy();
Slice second_slice_copy = second_slice.Copy();
ASSERT_EQ(sb.AppendIndexed(std::move(first_slice)), 0);
ASSERT_EQ(sb.AppendIndexed(std::move(second_slice)), 1);
Slice first_reffed = sb.RefSlice(0);
Slice second_reffed = sb.RefSlice(1);
ASSERT_EQ(first_reffed, first_slice_copy);
ASSERT_EQ(second_reffed, second_slice_copy);
ASSERT_EQ(sb.Count(), 2);
ASSERT_EQ(sb.Length(), 2 * kNewSliceLength + 1);
sb.Clear();
}
int main(int argc, char** argv) {
testing::InitGoogleTest(&argc, argv);
return RUN_ALL_TESTS();
}