202 lines
4.8 KiB
C++
202 lines
4.8 KiB
C++
/*
|
|
* Copyright (C) 2019 The Android Open Source Project
|
|
*
|
|
* 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 <gtest/gtest.h>
|
|
|
|
#include <utils/sstream.h>
|
|
|
|
#include <utils/Log.h>
|
|
|
|
using namespace utils;
|
|
using namespace utils::io;
|
|
|
|
TEST(ostream, setConsumer) {
|
|
slog.d.setConsumer(+[](void*, char const*) {
|
|
GTEST_FAIL();
|
|
}, nullptr);
|
|
// we test that we don't crash if the log is empty and that we don't call the consumer.
|
|
flush(slog.d);
|
|
|
|
slog.d.setConsumer(nullptr, nullptr);
|
|
slog.d << "hello world";
|
|
// we test that after resetting the consumer, it's not called on flush.
|
|
flush(slog.d);
|
|
|
|
const char* str = "hello world!";
|
|
slog.d.setConsumer(+[](void* user, char const* str) {
|
|
ASSERT_STREQ(str, (const char*)user);
|
|
}, (void*)str);
|
|
slog.d << str;
|
|
// we test that the comsumer is called with the right string
|
|
flush(slog.d);
|
|
slog.d.setConsumer(nullptr, nullptr);
|
|
}
|
|
|
|
TEST(sstream, EmptyString) {
|
|
sstream ss;
|
|
EXPECT_STREQ("", ss.c_str());
|
|
}
|
|
|
|
TEST(sstream, Formatting) {
|
|
{
|
|
sstream ss;
|
|
ss << (short) 32767;
|
|
EXPECT_STREQ("32767", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (unsigned short) 65535;
|
|
EXPECT_STREQ("65535", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (char) 'A';
|
|
EXPECT_STREQ("A", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (unsigned char) 'B';
|
|
EXPECT_STREQ("B", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (int) 2147483647;
|
|
EXPECT_STREQ("2147483647", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (unsigned int) 4294967295;
|
|
EXPECT_STREQ("4294967295", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (long) -2147483647;
|
|
EXPECT_STREQ("-2147483647", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (unsigned long) 4294967295;
|
|
EXPECT_STREQ("4294967295", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (long long) 9223372036854775807;
|
|
EXPECT_STREQ("9223372036854775807", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (unsigned long long) 18446744073709551615u;
|
|
EXPECT_STREQ("18446744073709551615", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (float) 3.14; // 3.14 can't be represented exactly by a float
|
|
EXPECT_STREQ("3.1400001", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (double) -1;
|
|
EXPECT_STREQ("-1", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (long double) 1;
|
|
EXPECT_STREQ("1.000000", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (bool) true;
|
|
EXPECT_STREQ("true", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (const char *) "hello";
|
|
EXPECT_STREQ("hello", ss.c_str());
|
|
}
|
|
{
|
|
sstream ss;
|
|
ss << (const unsigned char *) "world";
|
|
EXPECT_STREQ("world", ss.c_str());
|
|
}
|
|
}
|
|
|
|
TEST(sstream, LargeBuffer) {
|
|
sstream ss;
|
|
|
|
const char* filler = "1234567890ABCDEF";
|
|
|
|
// Fill the buffer with 1024 * 1024 * 16 bytes (~16MB).
|
|
for (size_t i = 0; i < 1024 * 1024; i++) {
|
|
ss << filler;
|
|
}
|
|
|
|
EXPECT_EQ(1024 * 1024 * 16, strlen(ss.c_str()));
|
|
EXPECT_EQ(1024 * 1024 * 16, ss.length());
|
|
}
|
|
|
|
TEST(sstream, LargeString) {
|
|
sstream ss;
|
|
|
|
// Create a 1GB C-string.
|
|
constexpr size_t size = 1024 * 1024 * 1024;
|
|
char* filler = (char*) malloc(size + 1);
|
|
std::fill_n(filler, size, 'A');
|
|
filler[size] = 0; // null-terminator
|
|
|
|
ss << filler;
|
|
|
|
EXPECT_EQ(size, strlen(ss.c_str()));
|
|
EXPECT_EQ(size, ss.length());
|
|
EXPECT_STREQ(filler, ss.c_str());
|
|
|
|
free(filler);
|
|
}
|
|
|
|
TEST(sstream, SeveralStrings) {
|
|
sstream ss;
|
|
|
|
// Create a 1KB C-string.
|
|
constexpr size_t sizeA = 1024;
|
|
char* fillerA = (char*) malloc(sizeA + 1);
|
|
std::fill_n(fillerA, sizeA, 'A');
|
|
fillerA[sizeA] = 0; // null-terminator
|
|
|
|
// Create a 7KB C-string.
|
|
constexpr size_t sizeB = 7 * 1024;
|
|
char* fillerB = (char*) malloc(sizeB + 1);
|
|
std::fill_n(fillerB, sizeB, 'B');
|
|
fillerB[sizeB] = 0;
|
|
|
|
ss << fillerA;
|
|
ss << fillerB;
|
|
|
|
EXPECT_EQ(sizeA + sizeB, strlen(ss.c_str()));
|
|
EXPECT_EQ(sizeA + sizeB, ss.length());
|
|
|
|
free(fillerA);
|
|
free(fillerB);
|
|
}
|
|
|
|
TEST(sstream, length) {
|
|
sstream ss;
|
|
|
|
EXPECT_EQ(0, ss.length());
|
|
ss << "Hello, world\n";
|
|
EXPECT_EQ(13, ss.length());
|
|
ss << "Foo bar\n";
|
|
EXPECT_EQ(13 + 8, ss.length());
|
|
}
|