blob: 8f69b02a25e561aee2081fe6519d5f1705e5246b [file] [log] [blame] [edit]
package zstd
import (
"bytes"
"errors"
"fmt"
"io/ioutil"
"os"
"testing"
)
var raw []byte
var (
ErrNoPayloadEnv = errors.New("PAYLOAD env was not set")
)
func init() {
var err error
payload := os.Getenv("PAYLOAD")
if len(payload) > 0 {
raw, err = ioutil.ReadFile(payload)
if err != nil {
fmt.Printf("Error opening payload: %s\n", err)
}
}
}
// Test our version of compress bound vs C implementation
func TestCompressBound(t *testing.T) {
tests := []int{0, 1, 2, 10, 456, 15468, 1313, 512, 54564654653}
for _, test := range tests {
if CompressBound(test) != cCompressBound(test) {
t.Fatalf("For %v, results are differents: %v != %v", test,
CompressBound(test), cCompressBound(test))
}
}
}
// Test error code
func TestErrorCode(t *testing.T) {
tests := make([]int, 211)
for i := 0; i < len(tests); i++ {
tests[i] = i - 105
}
for _, test := range tests {
err := getError(test)
if err == nil && cIsError(test) {
t.Fatalf("C function returned error for %v but ours did not", test)
} else if err != nil && !cIsError(test) {
t.Fatalf("Ours function returned error for %v but C one did not", test)
}
}
}
// Test compression
func TestCompressDecompress(t *testing.T) {
input := []byte("Hello World!")
out, err := Compress(nil, input)
if err != nil {
t.Fatalf("Error while compressing: %v", err)
}
out2 := make([]byte, 1000)
out2, err = Compress(out2, input)
if err != nil {
t.Fatalf("Error while compressing: %v", err)
}
t.Logf("Compressed: %v", out)
rein, err := Decompress(nil, out)
if err != nil {
t.Fatalf("Error while decompressing: %v", err)
}
rein2 := make([]byte, 10)
rein2, err = Decompress(rein2, out2)
if err != nil {
t.Fatalf("Error while decompressing: %v", err)
}
if string(input) != string(rein) {
t.Fatalf("Cannot compress and decompress: %s != %s", input, rein)
}
if string(input) != string(rein2) {
t.Fatalf("Cannot compress and decompress: %s != %s", input, rein)
}
}
func TestEmptySlice(t *testing.T) {
_, err := Compress(nil, []byte{})
if err != ErrEmptySlice {
t.Fatalf("Did not get the correct error: %s", err)
}
}
func TestTooSmall(t *testing.T) {
var long bytes.Buffer
for i := 0; i < 10000; i++ {
long.Write([]byte("Hellow World!"))
}
input := long.Bytes()
out, err := Compress(nil, input)
if err != nil {
t.Fatalf("Error while compressing: %v", err)
}
rein := make([]byte, 1)
// This should switch to the decompression stream to handle too small dst
rein, err = Decompress(rein, out)
if err != nil {
t.Fatalf("Failed decompressing: %s", err)
}
if string(input) != string(rein) {
t.Fatalf("Cannot compress and decompress: %s != %s", input, rein)
}
}
func TestRealPayload(t *testing.T) {
if raw == nil {
t.Skip(ErrNoPayloadEnv)
}
dst, err := Compress(nil, raw)
if err != nil {
t.Fatalf("Failed to compress: %s", err)
}
rein, err := Decompress(nil, dst)
if err != nil {
t.Fatalf("Failed to decompress: %s", err)
}
if string(raw) != string(rein) {
t.Fatalf("compressed/decompressed payloads are not the same (lengths: %v & %v)", len(raw), len(rein))
}
}
func BenchmarkCompression(b *testing.B) {
if raw == nil {
b.Fatal(ErrNoPayloadEnv)
}
dst := make([]byte, CompressBound(len(raw)))
b.SetBytes(int64(len(raw)))
b.ResetTimer()
for i := 0; i < b.N; i++ {
_, err := Compress(dst, raw)
if err != nil {
b.Fatalf("Failed compressing: %s", err)
}
}
}
func BenchmarkDecompression(b *testing.B) {
if raw == nil {
b.Fatal(ErrNoPayloadEnv)
}
src := make([]byte, len(raw))
dst, err := Compress(nil, raw)
if err != nil {
b.Fatalf("Failed compressing: %s", err)
}
b.Logf("Reduced from %v to %v", len(raw), len(dst))
b.SetBytes(int64(len(raw)))
b.ResetTimer()
for i := 0; i < b.N; i++ {
src2, err := Decompress(src, dst)
if err != nil {
b.Fatalf("Failed decompressing: %s", err)
}
b.StopTimer()
if !bytes.Equal(raw, src2) {
b.Fatalf("Results are not the same: %v != %v", len(raw), len(src2))
}
b.StartTimer()
}
}