summaryrefslogtreecommitdiff
path: root/neozip/test/test_deflate_deterministic.cc
diff options
context:
space:
mode:
authorMehmet Samet Duman <yongdohyun@projecttick.org>2026-04-02 19:56:09 +0300
committerMehmet Samet Duman <yongdohyun@projecttick.org>2026-04-02 19:56:09 +0300
commit7fb132859fda54aa96bc9dd46d302b343eeb5a02 (patch)
treeb43ae77d7451fb470a260c03349a1caf2846c5e5 /neozip/test/test_deflate_deterministic.cc
parentb1e34e861b5d732afe828d58aad2c638135061fd (diff)
parentc2712b8a345191f6ed79558c089777df94590087 (diff)
downloadProject-Tick-7fb132859fda54aa96bc9dd46d302b343eeb5a02.tar.gz
Project-Tick-7fb132859fda54aa96bc9dd46d302b343eeb5a02.zip
Add 'neozip/' from commit 'c2712b8a345191f6ed79558c089777df94590087'
git-subtree-dir: neozip git-subtree-mainline: b1e34e861b5d732afe828d58aad2c638135061fd git-subtree-split: c2712b8a345191f6ed79558c089777df94590087
Diffstat (limited to 'neozip/test/test_deflate_deterministic.cc')
-rw-r--r--neozip/test/test_deflate_deterministic.cc71
1 files changed, 71 insertions, 0 deletions
diff --git a/neozip/test/test_deflate_deterministic.cc b/neozip/test/test_deflate_deterministic.cc
new file mode 100644
index 0000000000..5cb5cb4ff1
--- /dev/null
+++ b/neozip/test/test_deflate_deterministic.cc
@@ -0,0 +1,71 @@
+/* test_deflate_deterministic.cc - Test deterministic output after deflateReset */
+
+#include "zbuild.h"
+#ifdef ZLIB_COMPAT
+# include "zlib.h"
+#else
+# include "zlib-ng.h"
+#endif
+
+#include <string>
+#include <gtest/gtest.h>
+
+#include "deflate.h"
+#include "test_shared.h"
+
+
+
+/* Issue: https://github.com/zlib-ng/zlib-ng/issues/2100 */
+
+/* len(data_b) must be greater len(data_a) */
+static const uint8_t data_a[] = { 0 , 'A', 'A', 'A', 'A', 0 , 'A', 'A', 'A', 'A', 'A', 'A', 'A', 'A' };
+static const uint8_t data_b[] = { 'B', 'B', 'B', 'B', 'B', 'B', 'B', 'B', 'B', 'B', 'B', 'B', 'B', 'B', 'B' };
+
+static std::string compress_data(const uint8_t *src, size_t len, PREFIX3(stream)* z_stream) {
+ const uint32_t buffer_size = 1024;
+ uint8_t buffer[buffer_size];
+ int err;
+
+ z_stream->next_in = (z_const uint8_t *)src;
+ z_stream->avail_in = (uint32_t)len;
+ z_stream->next_out = buffer;
+ z_stream->avail_out = buffer_size;
+ err = PREFIX(deflate)(z_stream, Z_FINISH);
+ EXPECT_EQ(err, Z_STREAM_END);
+ return std::string((const char *)buffer, (size_t)(z_stream->next_out - buffer));
+}
+
+TEST(deflate, deterministic) {
+ const int compression_level = 6;
+ const int window_bits = 15;
+ int err;
+
+ PREFIX3(stream) a_stream;
+ memset(&a_stream, 0, sizeof(a_stream));
+
+ /* Compress a with newly created z_stream. */
+ err = PREFIX(deflateInit2)(&a_stream, compression_level, Z_DEFLATED, window_bits, 8, Z_DEFAULT_STRATEGY);
+ EXPECT_EQ(err, Z_OK);
+
+ const std::string a_compressed = compress_data(data_a, sizeof(data_a), &a_stream);
+ err = PREFIX(deflateEnd)(&a_stream);
+ EXPECT_EQ(err, Z_OK);
+
+ /* Compress b with newly created z_stream. */
+ PREFIX3(stream) b_stream;
+ memset(&b_stream, 0, sizeof(b_stream));
+
+ err = PREFIX(deflateInit2)(&b_stream, compression_level, Z_DEFLATED, window_bits, 8, Z_DEFAULT_STRATEGY);
+ EXPECT_EQ(err, Z_OK);
+ const std::string b_compressed = compress_data(data_b, sizeof(data_b), &b_stream);
+
+ /* Reset the stream. */
+ err = PREFIX(deflateReset)(&b_stream);
+ EXPECT_EQ(err, Z_OK);
+
+ const std::string a_compressed2 = compress_data(data_a, sizeof(data_a), &b_stream);
+ err = PREFIX(deflateEnd)(&b_stream);
+ EXPECT_EQ(err, Z_OK);
+
+ EXPECT_EQ(a_compressed, a_compressed2);
+}