TestGzip.cpp 4.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. /*
  2. * Copyright (c) 2020-2021, the SerenityOS developers.
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <LibTest/TestCase.h>
  7. #include <AK/Array.h>
  8. #include <AK/Random.h>
  9. #include <LibCompress/Gzip.h>
  10. TEST_CASE(gzip_decompress_simple)
  11. {
  12. Array<u8, 33> const compressed {
  13. 0x1f, 0x8b, 0x08, 0x00, 0x77, 0xff, 0x47, 0x5f, 0x02, 0xff, 0x2b, 0xcf,
  14. 0x2f, 0x4a, 0x31, 0x54, 0x48, 0x4c, 0x4a, 0x56, 0x28, 0x07, 0xb2, 0x8c,
  15. 0x00, 0xc2, 0x1d, 0x22, 0x15, 0x0f, 0x00, 0x00, 0x00
  16. };
  17. const u8 uncompressed[] = "word1 abc word2";
  18. auto const decompressed = Compress::GzipDecompressor::decompress_all(compressed);
  19. EXPECT(decompressed.value().bytes() == (ReadonlyBytes { uncompressed, sizeof(uncompressed) - 1 }));
  20. }
  21. TEST_CASE(gzip_decompress_multiple_members)
  22. {
  23. Array<u8, 52> const compressed {
  24. 0x1f, 0x8b, 0x08, 0x00, 0xe0, 0x03, 0x48, 0x5f, 0x02, 0xff, 0x4b, 0x4c,
  25. 0x4a, 0x4e, 0x4c, 0x4a, 0x06, 0x00, 0x4c, 0x99, 0x6e, 0x72, 0x06, 0x00,
  26. 0x00, 0x00, 0x1f, 0x8b, 0x08, 0x00, 0xe0, 0x03, 0x48, 0x5f, 0x02, 0xff,
  27. 0x4b, 0x4c, 0x4a, 0x4e, 0x4c, 0x4a, 0x06, 0x00, 0x4c, 0x99, 0x6e, 0x72,
  28. 0x06, 0x00, 0x00, 0x00
  29. };
  30. const u8 uncompressed[] = "abcabcabcabc";
  31. auto const decompressed = Compress::GzipDecompressor::decompress_all(compressed);
  32. EXPECT(decompressed.value().bytes() == (ReadonlyBytes { uncompressed, sizeof(uncompressed) - 1 }));
  33. }
  34. TEST_CASE(gzip_decompress_zeroes)
  35. {
  36. Array<u8, 161> const compressed {
  37. 0x1f, 0x8b, 0x08, 0x00, 0x6e, 0x7a, 0x4b, 0x5f, 0x02, 0xff, 0xed, 0xc1,
  38. 0x31, 0x01, 0x00, 0x00, 0x00, 0xc2, 0xa0, 0xf5, 0x4f, 0xed, 0x61, 0x0d,
  39. 0xa0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  40. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  41. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  42. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  43. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  44. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  45. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  46. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  47. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  48. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  49. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x6e, 0xcd, 0xcd, 0xe8,
  50. 0x7e, 0x00, 0x00, 0x02, 0x00
  51. };
  52. Array<u8, 128 * 1024> const uncompressed = { 0 };
  53. auto const decompressed = Compress::GzipDecompressor::decompress_all(compressed);
  54. EXPECT(uncompressed == decompressed.value().bytes());
  55. }
  56. TEST_CASE(gzip_decompress_repeat_around_buffer)
  57. {
  58. Array<u8, 70> const compressed {
  59. 0x1f, 0x8b, 0x08, 0x00, 0xc6, 0x74, 0x53, 0x5f, 0x02, 0xff, 0xed, 0xc1,
  60. 0x01, 0x0d, 0x00, 0x00, 0x0c, 0x02, 0xa0, 0xdb, 0xbf, 0xf4, 0x37, 0x6b,
  61. 0x08, 0x24, 0xdb, 0x0e, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  62. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  63. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x80, 0xca,
  64. 0xb8, 0x07, 0xcd, 0xe5, 0x38, 0xfa, 0x00, 0x80, 0x00, 0x00
  65. };
  66. Array<u8, 0x8000> uncompressed;
  67. uncompressed.span().slice(0x0000, 0x0100).fill(1);
  68. uncompressed.span().slice(0x0100, 0x7e00).fill(0);
  69. uncompressed.span().slice(0x7f00, 0x0100).fill(1);
  70. auto const decompressed = Compress::GzipDecompressor::decompress_all(compressed);
  71. EXPECT(uncompressed == decompressed.value().bytes());
  72. }
  73. TEST_CASE(gzip_round_trip)
  74. {
  75. auto original = ByteBuffer::create_uninitialized(1024).release_value();
  76. fill_with_random(original.data(), 1024);
  77. auto compressed = Compress::GzipCompressor::compress_all(original);
  78. EXPECT(compressed.has_value());
  79. auto uncompressed = Compress::GzipDecompressor::decompress_all(compressed.value());
  80. EXPECT(!uncompressed.is_error());
  81. EXPECT(uncompressed.value() == original);
  82. }