aboutsummaryrefslogtreecommitdiff
path: root/zstd_test.go
diff options
context:
space:
mode:
authorGravatar Co1a <aaron9shire@gmail.com> 2024-02-21 14:21:52 +0800
committerGravatar GitHub <noreply@github.com> 2024-02-21 07:21:52 +0100
commit5f81476d7cf339624b5fec57a06ee96d3e27d9c2 (patch)
tree62b06111db30c5895dc775f53bf5577f1092c06a /zstd_test.go
parentLimit memory for fuzz testing (diff)
downloadfasthttp-5f81476d7cf339624b5fec57a06ee96d3e27d9c2.tar.gz
fasthttp-5f81476d7cf339624b5fec57a06ee96d3e27d9c2.tar.bz2
fasthttp-5f81476d7cf339624b5fec57a06ee96d3e27d9c2.zip
feat:support zstd compress and uncompressed (#1701)
* feat:support zstd compress and uncompressed * fix:real & stackless write using different pool to avoid get stackless.writer * fix:zstd normalize compress level * Change empty string checks to be more idiomatic (#1684) * chore:lint fix and rebase with master * chore:remove 1.18 test & upgrade compress version * fix:error default compress level * Fix lint --------- Co-authored-by: Erik Dubbelboer <erik@dubbelboer.com>
Diffstat (limited to 'zstd_test.go')
-rw-r--r--zstd_test.go102
1 files changed, 102 insertions, 0 deletions
diff --git a/zstd_test.go b/zstd_test.go
new file mode 100644
index 0000000..dc0c45f
--- /dev/null
+++ b/zstd_test.go
@@ -0,0 +1,102 @@
+package fasthttp
+
+import (
+ "bytes"
+ "fmt"
+ "io"
+ "testing"
+)
+
+func TestZstdBytesSerial(t *testing.T) {
+ t.Parallel()
+
+ if err := testZstdBytes(); err != nil {
+ t.Fatal(err)
+ }
+}
+
+func TestZstdBytesConcurrent(t *testing.T) {
+ t.Parallel()
+
+ if err := testConcurrent(10, testZstdBytes); err != nil {
+ t.Fatal(err)
+ }
+}
+
+func testZstdBytes() error {
+ for _, s := range compressTestcases {
+ if err := testZstdBytesSingleCase(s); err != nil {
+ return err
+ }
+ }
+ return nil
+}
+
+func testZstdBytesSingleCase(s string) error {
+ prefix := []byte("foobar")
+ ZstdpedS := AppendZstdBytes(prefix, []byte(s))
+ if !bytes.Equal(ZstdpedS[:len(prefix)], prefix) {
+ return fmt.Errorf("unexpected prefix when compressing %q: %q. Expecting %q", s, ZstdpedS[:len(prefix)], prefix)
+ }
+
+ unZstdedS, err := AppendUnzstdBytes(prefix, ZstdpedS[len(prefix):])
+ if err != nil {
+ return fmt.Errorf("unexpected error when uncompressing %q: %w", s, err)
+ }
+ if !bytes.Equal(unZstdedS[:len(prefix)], prefix) {
+ return fmt.Errorf("unexpected prefix when uncompressing %q: %q. Expecting %q", s, unZstdedS[:len(prefix)], prefix)
+ }
+ unZstdedS = unZstdedS[len(prefix):]
+ if string(unZstdedS) != s {
+ return fmt.Errorf("unexpected uncompressed string %q. Expecting %q", unZstdedS, s)
+ }
+ return nil
+}
+
+func TestZstdCompressSerial(t *testing.T) {
+ t.Parallel()
+
+ if err := testZstdCompress(); err != nil {
+ t.Fatal(err)
+ }
+}
+
+func TestZstdCompressConcurrent(t *testing.T) {
+ t.Parallel()
+
+ if err := testConcurrent(10, testZstdCompress); err != nil {
+ t.Fatal(err)
+ }
+}
+
+func testZstdCompress() error {
+ for _, s := range compressTestcases {
+ if err := testZstdCompressSingleCase(s); err != nil {
+ return err
+ }
+ }
+ return nil
+}
+
+func testZstdCompressSingleCase(s string) error {
+ var buf bytes.Buffer
+ zw := acquireStacklessZstdWriter(&buf, CompressZstdDefault)
+ if _, err := zw.Write([]byte(s)); err != nil {
+ return fmt.Errorf("unexpected error: %w. s=%q", err, s)
+ }
+ releaseStacklessZstdWriter(zw, CompressZstdDefault)
+
+ zr, err := acquireZstdReader(&buf)
+ if err != nil {
+ return fmt.Errorf("unexpected error: %w. s=%q", err, s)
+ }
+ body, err := io.ReadAll(zr)
+ if err != nil {
+ return fmt.Errorf("unexpected error: %w. s=%q", err, s)
+ }
+ if string(body) != s {
+ return fmt.Errorf("unexpected string after decompression: %q. Expecting %q", body, s)
+ }
+ releaseZstdReader(zr)
+ return nil
+}