Raphael Isemann | b1dfad0 | 2018-08-01 06:04:48 +0000 | [diff] [blame] | 1 | //===-- StreamTest.cpp ------------------------------------------*- C++ -*-===// |
| 2 | // |
| 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
| 5 | // This file is distributed under the University of Illinois Open Source |
| 6 | // License. See LICENSE.TXT for details. |
| 7 | // |
| 8 | //===----------------------------------------------------------------------===// |
| 9 | |
| 10 | #include "lldb/Utility/StreamString.h" |
| 11 | #include "gtest/gtest.h" |
| 12 | |
| 13 | using namespace lldb_private; |
| 14 | |
| 15 | namespace { |
| 16 | struct StreamTest : ::testing::Test { |
| 17 | // Note: Stream is an abstract class, so we use StreamString to test it. To |
| 18 | // make it easier to change this later, only methods in this class explicitly |
| 19 | // refer to the StringStream class. |
| 20 | StreamString s; |
| 21 | // We return here a std::string because that way gtest can print better |
| 22 | // assertion messages. |
| 23 | std::string TakeValue() { |
| 24 | std::string result = s.GetString().str(); |
| 25 | s.Clear(); |
| 26 | return result; |
| 27 | } |
| 28 | }; |
| 29 | } |
| 30 | |
| 31 | namespace { |
| 32 | // A StreamTest where we expect the Stream output to be binary. |
| 33 | struct BinaryStreamTest : StreamTest { |
| 34 | void SetUp() override { |
| 35 | s.GetFlags().Set(Stream::eBinary); |
| 36 | } |
| 37 | }; |
| 38 | } |
| 39 | |
| 40 | TEST_F(StreamTest, ChangingByteOrder) { |
| 41 | s.SetByteOrder(lldb::eByteOrderPDP); |
| 42 | EXPECT_EQ(lldb::eByteOrderPDP, s.GetByteOrder()); |
| 43 | } |
| 44 | |
| 45 | TEST_F(StreamTest, PutChar) { |
| 46 | s.PutChar('a'); |
| 47 | EXPECT_EQ("a", TakeValue()); |
| 48 | |
| 49 | s.PutChar('1'); |
| 50 | EXPECT_EQ("1", TakeValue()); |
| 51 | } |
| 52 | |
| 53 | TEST_F(StreamTest, PutCharWhitespace) { |
| 54 | s.PutChar(' '); |
| 55 | EXPECT_EQ(" ", TakeValue()); |
| 56 | |
| 57 | s.PutChar('\n'); |
| 58 | EXPECT_EQ("\n", TakeValue()); |
| 59 | |
| 60 | s.PutChar('\r'); |
| 61 | EXPECT_EQ("\r", TakeValue()); |
| 62 | |
| 63 | s.PutChar('\t'); |
| 64 | EXPECT_EQ("\t", TakeValue()); |
| 65 | } |
| 66 | |
| 67 | TEST_F(StreamTest, PutCString) { |
| 68 | s.PutCString(""); |
| 69 | EXPECT_EQ("", TakeValue()); |
| 70 | |
| 71 | s.PutCString("foobar"); |
| 72 | EXPECT_EQ("foobar", TakeValue()); |
| 73 | |
| 74 | s.PutCString(" "); |
| 75 | EXPECT_EQ(" ", TakeValue()); |
| 76 | } |
| 77 | |
| 78 | TEST_F(StreamTest, PutCStringWithStringRef) { |
| 79 | s.PutCString(llvm::StringRef("")); |
| 80 | EXPECT_EQ("", TakeValue()); |
| 81 | |
| 82 | s.PutCString(llvm::StringRef("foobar")); |
| 83 | EXPECT_EQ("foobar", TakeValue()); |
| 84 | |
| 85 | s.PutCString(llvm::StringRef(" ")); |
| 86 | EXPECT_EQ(" ", TakeValue()); |
| 87 | } |
| 88 | |
| 89 | TEST_F(StreamTest, QuotedCString) { |
| 90 | s.QuotedCString("foo"); |
| 91 | EXPECT_EQ(R"("foo")", TakeValue()); |
| 92 | |
| 93 | s.QuotedCString("ba r"); |
| 94 | EXPECT_EQ(R"("ba r")", TakeValue()); |
| 95 | |
| 96 | s.QuotedCString(" "); |
| 97 | EXPECT_EQ(R"(" ")", TakeValue()); |
| 98 | } |
| 99 | |
| 100 | TEST_F(StreamTest, PutCharNull) { |
| 101 | s.PutChar('\0'); |
| 102 | EXPECT_EQ(std::string("\0", 1), TakeValue()); |
| 103 | |
| 104 | s.PutChar('a'); |
| 105 | EXPECT_EQ(std::string("a", 1), TakeValue()); |
| 106 | } |
| 107 | |
| 108 | TEST_F(StreamTest, PutCStringAsRawHex8) { |
Raphael Isemann | b1dfad0 | 2018-08-01 06:04:48 +0000 | [diff] [blame] | 109 | s.PutCStringAsRawHex8("foobar"); |
| 110 | EXPECT_EQ("666f6f626172", TakeValue()); |
| 111 | |
| 112 | s.PutCStringAsRawHex8(" "); |
| 113 | EXPECT_EQ("20", TakeValue()); |
| 114 | } |
| 115 | |
| 116 | TEST_F(StreamTest, PutHex8) { |
| 117 | s.PutHex8((uint8_t)55); |
| 118 | EXPECT_EQ("37", TakeValue()); |
| 119 | s.PutHex8(std::numeric_limits<uint8_t>::max()); |
| 120 | EXPECT_EQ("ff", TakeValue()); |
| 121 | s.PutHex8((uint8_t)0); |
| 122 | EXPECT_EQ("00", TakeValue()); |
| 123 | } |
| 124 | |
| 125 | TEST_F(StreamTest, PutNHex8) { |
| 126 | s.PutNHex8(0, (uint8_t)55); |
| 127 | EXPECT_EQ("", TakeValue()); |
| 128 | s.PutNHex8(1, (uint8_t)55); |
| 129 | EXPECT_EQ("37", TakeValue()); |
| 130 | s.PutNHex8(2, (uint8_t)55); |
| 131 | EXPECT_EQ("3737", TakeValue()); |
| 132 | s.PutNHex8(1, (uint8_t)56); |
| 133 | EXPECT_EQ("38", TakeValue()); |
| 134 | } |
| 135 | |
| 136 | TEST_F(StreamTest, PutHex16ByteOrderLittle) { |
| 137 | s.PutHex16(0x1234U, lldb::eByteOrderLittle); |
| 138 | EXPECT_EQ("3412", TakeValue()); |
| 139 | s.PutHex16(std::numeric_limits<uint16_t>::max(), lldb::eByteOrderLittle); |
| 140 | EXPECT_EQ("ffff", TakeValue()); |
| 141 | s.PutHex16(0U, lldb::eByteOrderLittle); |
| 142 | EXPECT_EQ("0000", TakeValue()); |
| 143 | } |
| 144 | |
| 145 | TEST_F(StreamTest, PutHex16ByteOrderBig) { |
| 146 | s.PutHex16(0x1234U, lldb::eByteOrderBig); |
| 147 | EXPECT_EQ("1234", TakeValue()); |
| 148 | s.PutHex16(std::numeric_limits<uint16_t>::max(), lldb::eByteOrderBig); |
| 149 | EXPECT_EQ("ffff", TakeValue()); |
| 150 | s.PutHex16(0U, lldb::eByteOrderBig); |
| 151 | EXPECT_EQ("0000", TakeValue()); |
| 152 | } |
| 153 | |
| 154 | TEST_F(StreamTest, PutHex32ByteOrderLittle) { |
| 155 | s.PutHex32(0x12345678U, lldb::eByteOrderLittle); |
| 156 | EXPECT_EQ("78563412", TakeValue()); |
| 157 | s.PutHex32(std::numeric_limits<uint32_t>::max(), lldb::eByteOrderLittle); |
| 158 | EXPECT_EQ("ffffffff", TakeValue()); |
| 159 | s.PutHex32(0U, lldb::eByteOrderLittle); |
| 160 | EXPECT_EQ("00000000", TakeValue()); |
| 161 | } |
| 162 | |
| 163 | TEST_F(StreamTest, PutHex32ByteOrderBig) { |
| 164 | s.PutHex32(0x12345678U, lldb::eByteOrderBig); |
| 165 | EXPECT_EQ("12345678", TakeValue()); |
| 166 | s.PutHex32(std::numeric_limits<uint32_t>::max(), lldb::eByteOrderBig); |
| 167 | EXPECT_EQ("ffffffff", TakeValue()); |
| 168 | s.PutHex32(0U, lldb::eByteOrderBig); |
| 169 | EXPECT_EQ("00000000", TakeValue()); |
| 170 | } |
| 171 | |
| 172 | TEST_F(StreamTest, PutHex64ByteOrderLittle) { |
| 173 | s.PutHex64(0x1234567890ABCDEFU, lldb::eByteOrderLittle); |
| 174 | EXPECT_EQ("efcdab9078563412", TakeValue()); |
| 175 | s.PutHex64(std::numeric_limits<uint64_t>::max(), lldb::eByteOrderLittle); |
| 176 | EXPECT_EQ("ffffffffffffffff", TakeValue()); |
| 177 | s.PutHex64(0U, lldb::eByteOrderLittle); |
| 178 | EXPECT_EQ("0000000000000000", TakeValue()); |
| 179 | } |
| 180 | |
| 181 | TEST_F(StreamTest, PutHex64ByteOrderBig) { |
| 182 | s.PutHex64(0x1234567890ABCDEFU, lldb::eByteOrderBig); |
| 183 | EXPECT_EQ("1234567890abcdef", TakeValue()); |
| 184 | s.PutHex64(std::numeric_limits<uint64_t>::max(), lldb::eByteOrderBig); |
| 185 | EXPECT_EQ("ffffffffffffffff", TakeValue()); |
| 186 | s.PutHex64(0U, lldb::eByteOrderBig); |
| 187 | EXPECT_EQ("0000000000000000", TakeValue()); |
| 188 | } |
| 189 | |
Raphael Isemann | 0bb8d83 | 2018-08-01 17:12:58 +0000 | [diff] [blame^] | 190 | TEST_F(StreamTest, PutMaxHex64ByteOrderBig) { |
| 191 | std::size_t bytes; |
| 192 | bytes = s.PutMaxHex64(0x12U, 1, lldb::eByteOrderBig); |
| 193 | EXPECT_EQ(2U, bytes); |
| 194 | bytes = s.PutMaxHex64(0x1234U, 2, lldb::eByteOrderBig); |
| 195 | EXPECT_EQ(4U, bytes); |
| 196 | bytes = s.PutMaxHex64(0x12345678U, 4, lldb::eByteOrderBig); |
| 197 | EXPECT_EQ(8U, bytes); |
| 198 | bytes = s.PutMaxHex64(0x1234567890ABCDEFU, 8, lldb::eByteOrderBig); |
| 199 | EXPECT_EQ(16U, bytes); |
| 200 | EXPECT_EQ("121234123456781234567890abcdef", TakeValue()); |
| 201 | } |
| 202 | |
| 203 | TEST_F(StreamTest, PutMaxHex64ByteOrderLittle) { |
| 204 | std::size_t bytes; |
| 205 | bytes = s.PutMaxHex64(0x12U, 1, lldb::eByteOrderLittle); |
| 206 | EXPECT_EQ(2U, bytes); |
| 207 | bytes = s.PutMaxHex64(0x1234U, 2, lldb::eByteOrderLittle); |
| 208 | EXPECT_EQ(4U, bytes); |
| 209 | bytes = s.PutMaxHex64(0x12345678U, 4, lldb::eByteOrderLittle); |
| 210 | EXPECT_EQ(8U, bytes); |
| 211 | bytes = s.PutMaxHex64(0x1234567890ABCDEFU, 8, lldb::eByteOrderLittle); |
| 212 | EXPECT_EQ(16U, bytes); |
| 213 | EXPECT_EQ("12341278563412efcdab9078563412", TakeValue()); |
| 214 | } |
| 215 | |
Raphael Isemann | b1dfad0 | 2018-08-01 06:04:48 +0000 | [diff] [blame] | 216 | //------------------------------------------------------------------------------ |
| 217 | // Shift operator tests. |
| 218 | //------------------------------------------------------------------------------ |
| 219 | |
| 220 | TEST_F(StreamTest, ShiftOperatorChars) { |
| 221 | s << 'a' << 'b'; |
| 222 | EXPECT_EQ("ab", TakeValue()); |
| 223 | } |
| 224 | |
| 225 | TEST_F(StreamTest, ShiftOperatorStrings) { |
| 226 | s << "cstring\n"; |
| 227 | s << llvm::StringRef("llvm::StringRef\n"); |
| 228 | EXPECT_EQ("cstring\nllvm::StringRef\n", TakeValue()); |
| 229 | } |
| 230 | |
| 231 | TEST_F(StreamTest, ShiftOperatorInts) { |
| 232 | s << std::numeric_limits<int8_t>::max() << " "; |
| 233 | s << std::numeric_limits<int16_t>::max() << " "; |
| 234 | s << std::numeric_limits<int32_t>::max() << " "; |
| 235 | s << std::numeric_limits<int64_t>::max(); |
| 236 | EXPECT_EQ("127 32767 2147483647 9223372036854775807", TakeValue()); |
| 237 | } |
| 238 | |
| 239 | TEST_F(StreamTest, ShiftOperatorUInts) { |
| 240 | s << std::numeric_limits<uint8_t>::max() << " "; |
| 241 | s << std::numeric_limits<uint16_t>::max() << " "; |
| 242 | s << std::numeric_limits<uint32_t>::max() << " "; |
| 243 | s << std::numeric_limits<uint64_t>::max(); |
| 244 | EXPECT_EQ("ff ffff ffffffff ffffffffffffffff", TakeValue()); |
| 245 | } |
| 246 | |
| 247 | TEST_F(StreamTest, ShiftOperatorPtr) { |
| 248 | // This test is a bit tricky because pretty much everything related to |
| 249 | // pointer printing seems to lead to UB or IB. So let's make the most basic |
| 250 | // test that just checks that we print *something*. This way we at least know |
| 251 | // that pointer printing doesn't do really bad things (e.g. crashing, reading |
| 252 | // OOB/uninitialized memory which the sanitizers would spot). |
| 253 | |
| 254 | // Shift our own pointer to the output. |
| 255 | int i = 3; |
| 256 | int *ptr = &i; |
| 257 | s << ptr; |
| 258 | |
| 259 | EXPECT_TRUE(!TakeValue().empty()); |
| 260 | } |
| 261 | |
| 262 | TEST_F(StreamTest, PutPtr) { |
| 263 | // See the ShiftOperatorPtr test for the rationale. |
| 264 | int i = 3; |
| 265 | int *ptr = &i; |
| 266 | s.PutPointer(ptr); |
| 267 | |
| 268 | EXPECT_TRUE(!TakeValue().empty()); |
| 269 | } |
| 270 | |
| 271 | // Alias to make it more clear that 'invalid' means for the Stream interface |
| 272 | // that it should use the host byte order. |
| 273 | const static auto hostByteOrder = lldb::eByteOrderInvalid; |
| 274 | |
| 275 | //------------------------------------------------------------------------------ |
| 276 | // PutRawBytes/PutBytesAsRawHex tests. |
| 277 | //------------------------------------------------------------------------------ |
| 278 | |
| 279 | TEST_F(StreamTest, PutBytesAsRawHex8ToBigEndian) { |
| 280 | uint32_t value = 0x12345678; |
| 281 | s.PutBytesAsRawHex8(static_cast<void*>(&value), sizeof(value), |
| 282 | hostByteOrder, lldb::eByteOrderBig); |
| 283 | EXPECT_EQ("78563412", TakeValue()); |
| 284 | } |
| 285 | |
| 286 | TEST_F(StreamTest, PutRawBytesToBigEndian) { |
| 287 | uint32_t value = 0x12345678; |
| 288 | s.PutRawBytes(static_cast<void*>(&value), sizeof(value), |
| 289 | hostByteOrder, lldb::eByteOrderBig); |
| 290 | EXPECT_EQ("\x78\x56\x34\x12", TakeValue()); |
| 291 | } |
| 292 | |
| 293 | TEST_F(StreamTest, PutBytesAsRawHex8ToLittleEndian) { |
| 294 | uint32_t value = 0x12345678; |
| 295 | s.PutBytesAsRawHex8(static_cast<void*>(&value), sizeof(value), |
| 296 | hostByteOrder, lldb::eByteOrderLittle); |
| 297 | EXPECT_EQ("12345678", TakeValue()); |
| 298 | } |
| 299 | |
| 300 | TEST_F(StreamTest, PutRawBytesToLittleEndian) { |
| 301 | uint32_t value = 0x12345678; |
| 302 | s.PutRawBytes(static_cast<void*>(&value), sizeof(value), |
| 303 | hostByteOrder, lldb::eByteOrderLittle); |
| 304 | EXPECT_EQ("\x12\x34\x56\x78", TakeValue()); |
| 305 | } |
| 306 | |
| 307 | TEST_F(StreamTest, PutBytesAsRawHex8ToMixedEndian) { |
| 308 | uint32_t value = 0x12345678; |
| 309 | s.PutBytesAsRawHex8(static_cast<void*>(&value), sizeof(value), |
| 310 | hostByteOrder, lldb::eByteOrderPDP); |
| 311 | |
| 312 | // FIXME: PDP byte order is not actually implemented but Stream just silently |
| 313 | // prints the value in some random byte order... |
| 314 | #if 0 |
| 315 | EXPECT_EQ("34127856", TakeValue()); |
| 316 | #endif |
| 317 | } |
| 318 | |
| 319 | TEST_F(StreamTest, PutRawBytesToMixedEndian) { |
| 320 | uint32_t value = 0x12345678; |
| 321 | s.PutRawBytes(static_cast<void*>(&value), sizeof(value), |
| 322 | lldb::eByteOrderInvalid, lldb::eByteOrderPDP); |
| 323 | |
| 324 | // FIXME: PDP byte order is not actually implemented but Stream just silently |
| 325 | // prints the value in some random byte order... |
| 326 | #if 0 |
| 327 | EXPECT_EQ("\x34\x12\x78\x56", TakeValue()); |
| 328 | #endif |
| 329 | } |
| 330 | |
| 331 | //------------------------------------------------------------------------------ |
| 332 | // ULEB128 support for binary streams. |
| 333 | //------------------------------------------------------------------------------ |
| 334 | |
| 335 | TEST_F(BinaryStreamTest, PutULEB128OneByte) { |
| 336 | auto bytes = s.PutULEB128(0x74ULL); |
| 337 | EXPECT_EQ("\x74", TakeValue()); |
| 338 | EXPECT_EQ(1U, bytes); |
| 339 | } |
| 340 | |
| 341 | TEST_F(BinaryStreamTest, PutULEB128TwoBytes) { |
| 342 | auto bytes = s.PutULEB128(0x1985ULL); |
| 343 | EXPECT_EQ("\x85\x33", TakeValue()); |
| 344 | EXPECT_EQ(2U, bytes); |
| 345 | } |
| 346 | |
| 347 | TEST_F(BinaryStreamTest, PutULEB128ThreeBytes) { |
| 348 | auto bytes = s.PutULEB128(0x5023ULL); |
| 349 | EXPECT_EQ("\xA3\xA0\x1", TakeValue()); |
| 350 | EXPECT_EQ(3U, bytes); |
| 351 | } |
| 352 | |
| 353 | TEST_F(BinaryStreamTest, PutULEB128FourBytes) { |
| 354 | auto bytes = s.PutULEB128(0xA48032ULL); |
| 355 | EXPECT_EQ("\xB2\x80\x92\x5", TakeValue()); |
| 356 | EXPECT_EQ(4U, bytes); |
| 357 | } |
| 358 | |
| 359 | TEST_F(BinaryStreamTest, PutULEB128FiveBytes) { |
| 360 | auto bytes = s.PutULEB128(0x12345678ULL); |
| 361 | EXPECT_EQ("\xF8\xAC\xD1\x91\x1", TakeValue()); |
| 362 | EXPECT_EQ(5U, bytes); |
| 363 | } |
| 364 | |
| 365 | TEST_F(BinaryStreamTest, PutULEB128SixBytes) { |
| 366 | auto bytes = s.PutULEB128(0xABFE3FAFDFULL); |
| 367 | EXPECT_EQ("\xDF\xDF\xFE\xF1\xBF\x15", TakeValue()); |
| 368 | EXPECT_EQ(6U, bytes); |
| 369 | } |
| 370 | |
| 371 | TEST_F(BinaryStreamTest, PutULEB128SevenBytes) { |
| 372 | auto bytes = s.PutULEB128(0xDABFE3FAFDFULL); |
| 373 | EXPECT_EQ("\xDF\xDF\xFE\xF1\xBF\xB5\x3", TakeValue()); |
| 374 | EXPECT_EQ(7U, bytes); |
| 375 | } |
| 376 | |
| 377 | TEST_F(BinaryStreamTest, PutULEB128EightBytes) { |
| 378 | auto bytes = s.PutULEB128(0x7CDABFE3FAFDFULL); |
| 379 | EXPECT_EQ("\xDF\xDF\xFE\xF1\xBF\xB5\xF3\x3", TakeValue()); |
| 380 | EXPECT_EQ(8U, bytes); |
| 381 | } |
| 382 | |
| 383 | TEST_F(BinaryStreamTest, PutULEB128NineBytes) { |
| 384 | auto bytes = s.PutULEB128(0x327CDABFE3FAFDFULL); |
| 385 | EXPECT_EQ("\xDF\xDF\xFE\xF1\xBF\xB5\xF3\x93\x3", TakeValue()); |
| 386 | EXPECT_EQ(9U, bytes); |
| 387 | } |
| 388 | |
| 389 | TEST_F(BinaryStreamTest, PutULEB128MaxValue) { |
| 390 | auto bytes = s.PutULEB128(std::numeric_limits<uint64_t>::max()); |
| 391 | EXPECT_EQ("\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\x1", TakeValue()); |
| 392 | EXPECT_EQ(10U, bytes); |
| 393 | } |
| 394 | |
| 395 | TEST_F(BinaryStreamTest, PutULEB128Zero) { |
| 396 | auto bytes = s.PutULEB128(0x0U); |
| 397 | EXPECT_EQ(std::string("\0", 1), TakeValue()); |
| 398 | EXPECT_EQ(1U, bytes); |
| 399 | } |
| 400 | |
| 401 | TEST_F(BinaryStreamTest, PutULEB128One) { |
| 402 | auto bytes = s.PutULEB128(0x1U); |
| 403 | EXPECT_EQ("\x1", TakeValue()); |
| 404 | EXPECT_EQ(1U, bytes); |
| 405 | } |
| 406 | |
| 407 | //------------------------------------------------------------------------------ |
| 408 | // SLEB128 support for binary streams. |
| 409 | //------------------------------------------------------------------------------ |
| 410 | |
| 411 | TEST_F(BinaryStreamTest, PutSLEB128OneByte) { |
| 412 | auto bytes = s.PutSLEB128(0x74LL); |
| 413 | EXPECT_EQ(std::string("\xF4\0", 2), TakeValue()); |
| 414 | EXPECT_EQ(2U, bytes); |
| 415 | } |
| 416 | |
| 417 | TEST_F(BinaryStreamTest, PutSLEB128TwoBytes) { |
| 418 | auto bytes = s.PutSLEB128(0x1985LL); |
| 419 | EXPECT_EQ("\x85\x33", TakeValue()); |
| 420 | EXPECT_EQ(2U, bytes); |
| 421 | } |
| 422 | |
| 423 | TEST_F(BinaryStreamTest, PutSLEB128ThreeBytes) { |
| 424 | auto bytes = s.PutSLEB128(0x5023LL); |
| 425 | EXPECT_EQ("\xA3\xA0\x1", TakeValue()); |
| 426 | EXPECT_EQ(3U, bytes); |
| 427 | } |
| 428 | |
| 429 | TEST_F(BinaryStreamTest, PutSLEB128FourBytes) { |
| 430 | auto bytes = s.PutSLEB128(0xA48032LL); |
| 431 | EXPECT_EQ("\xB2\x80\x92\x5", TakeValue()); |
| 432 | EXPECT_EQ(4U, bytes); |
| 433 | } |
| 434 | |
| 435 | TEST_F(BinaryStreamTest, PutSLEB128FiveBytes) { |
| 436 | auto bytes = s.PutSLEB128(0x12345678LL); |
| 437 | EXPECT_EQ("\xF8\xAC\xD1\x91\x1", TakeValue()); |
| 438 | EXPECT_EQ(5U, bytes); |
| 439 | } |
| 440 | |
| 441 | TEST_F(BinaryStreamTest, PutSLEB128SixBytes) { |
| 442 | auto bytes = s.PutSLEB128(0xABFE3FAFDFLL); |
| 443 | EXPECT_EQ("\xDF\xDF\xFE\xF1\xBF\x15", TakeValue()); |
| 444 | EXPECT_EQ(6U, bytes); |
| 445 | } |
| 446 | |
| 447 | TEST_F(BinaryStreamTest, PutSLEB128SevenBytes) { |
| 448 | auto bytes = s.PutSLEB128(0xDABFE3FAFDFLL); |
| 449 | EXPECT_EQ("\xDF\xDF\xFE\xF1\xBF\xB5\x3", TakeValue()); |
| 450 | EXPECT_EQ(7U, bytes); |
| 451 | } |
| 452 | |
| 453 | TEST_F(BinaryStreamTest, PutSLEB128EightBytes) { |
| 454 | auto bytes = s.PutSLEB128(0x7CDABFE3FAFDFLL); |
| 455 | EXPECT_EQ("\xDF\xDF\xFE\xF1\xBF\xB5\xF3\x3", TakeValue()); |
| 456 | EXPECT_EQ(8U, bytes); |
| 457 | } |
| 458 | |
| 459 | TEST_F(BinaryStreamTest, PutSLEB128NineBytes) { |
| 460 | auto bytes = s.PutSLEB128(0x327CDABFE3FAFDFLL); |
| 461 | EXPECT_EQ("\xDF\xDF\xFE\xF1\xBF\xB5\xF3\x93\x3", TakeValue()); |
| 462 | EXPECT_EQ(9U, bytes); |
| 463 | } |
| 464 | |
| 465 | TEST_F(BinaryStreamTest, PutSLEB128MaxValue) { |
| 466 | auto bytes = s.PutSLEB128(std::numeric_limits<int64_t>::max()); |
| 467 | EXPECT_EQ(std::string("\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\0", 10), TakeValue()); |
| 468 | EXPECT_EQ(10U, bytes); |
| 469 | } |
| 470 | |
| 471 | TEST_F(BinaryStreamTest, PutSLEB128Zero) { |
| 472 | auto bytes = s.PutSLEB128(0x0); |
| 473 | EXPECT_EQ(std::string("\0", 1), TakeValue()); |
| 474 | EXPECT_EQ(1U, bytes); |
| 475 | } |
| 476 | |
| 477 | TEST_F(BinaryStreamTest, PutSLEB128One) { |
| 478 | auto bytes = s.PutSLEB128(0x1); |
| 479 | EXPECT_EQ(std::string("\x1", 1), TakeValue()); |
| 480 | EXPECT_EQ(1U, bytes); |
| 481 | } |
| 482 | |
| 483 | //------------------------------------------------------------------------------ |
| 484 | // SLEB128/ULEB128 support for non-binary streams. |
| 485 | //------------------------------------------------------------------------------ |
| 486 | |
| 487 | // The logic for this is very simple, so it should be enough to test some basic |
| 488 | // use cases. |
| 489 | |
| 490 | TEST_F(StreamTest, PutULEB128) { |
| 491 | auto bytes = s.PutULEB128(0x74ULL); |
| 492 | EXPECT_EQ("0x74", TakeValue()); |
| 493 | EXPECT_EQ(4U, bytes); |
| 494 | } |
| 495 | |
| 496 | TEST_F(StreamTest, PutSLEB128) { |
| 497 | auto bytes = s.PutSLEB128(0x1985LL); |
| 498 | EXPECT_EQ("0x6533", TakeValue()); |
| 499 | EXPECT_EQ(6U, bytes); |
| 500 | } |