diff options
| author | chrislusf <chris.lu@gmail.com> | 2015-04-13 23:39:11 -0700 |
|---|---|---|
| committer | chrislusf <chris.lu@gmail.com> | 2015-04-13 23:39:11 -0700 |
| commit | 830a44a84a61b41b393e2105846f4f8ce07c55b5 (patch) | |
| tree | d23a102583481f016aedadeeab9681ebd2f9d9af | |
| parent | 98aa9cc068cdfedc199a0a5c8a22ecd9813d47e3 (diff) | |
| download | seaweedfs-830a44a84a61b41b393e2105846f4f8ce07c55b5.tar.xz seaweedfs-830a44a84a61b41b393e2105846f4f8ce07c55b5.zip | |
Add compression test
| -rw-r--r-- | go/compress/compression_test.go | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/go/compress/compression_test.go b/go/compress/compression_test.go new file mode 100644 index 000000000..83b7c0055 --- /dev/null +++ b/go/compress/compression_test.go @@ -0,0 +1,45 @@ +package compress + +import ( + "math/rand" + "testing" +) + +func TestSortedData(t *testing.T) { + data := make([]int32, 102400) + for i := 1; i < len(data); i++ { + data[i] = data[i-1] + rand.Int31n(15) + } + testCompressAndUncompress(t, data, "Sorted data") +} + +func TestUnsortedData(t *testing.T) { + data := make([]int32, 102400) + for i := 0; i < len(data); i++ { + data[i] = rand.Int31n(255) + } + testCompressAndUncompress(t, data, "Unsorted data") +} + +func testCompressAndUncompress(t *testing.T, data []int32, desc string) { + + compressed_data, err := Compress32(data) + if err != nil { + t.Fatal("Compress error", err.Error()) + } + uncompressed_data, err := Uncompress32(compressed_data, make([]int32, len(data)*2)) + if err != nil { + t.Fatal("Compress error", err.Error()) + } + if len(uncompressed_data) != len(data) { + t.Fatal("Len differs", len(data), len(uncompressed_data)) + } + for i := 0; i < len(data); i++ { + if data[i] != uncompressed_data[i] { + t.Fatal("Data differs:", i, data[i], uncompressed_data[i]) + } + } + + println(desc, " Data length:", len(data), " => Compressed length:", len(compressed_data)) + +} |
