fr32: More testing

This commit is contained in:
Łukasz Magiera 2020-05-28 19:49:25 +02:00
parent 4db8351348
commit d38296a553
2 changed files with 84 additions and 3 deletions

View File

@ -10,7 +10,7 @@ import (
var mtTresh = 32 << 20
func mt(in, out []byte, padLen int, op func(in, out []byte)) {
func mt(in, out []byte, padLen int, op func(unpadded, padded []byte)) {
threads := padLen / mtTresh
if threads > runtime.NumCPU() {
threads = 1 << (32 - bits.LeadingZeros32(uint32(runtime.NumCPU())))
@ -35,6 +35,15 @@ func mt(in, out []byte, padLen int, op func(in, out []byte)) {
// Assumes len(in)%127==0 and len(out)%128==0
func Pad(in, out []byte) {
if len(out) > mtTresh {
mt(in, out, len(out), pad)
return
}
pad(in, out)
}
func pad(in, out []byte) {
if len(out) > mtTresh {
mt(in, out, len(out), Pad)
return
@ -79,13 +88,19 @@ func Pad(in, out []byte) {
}
}
// Assumes len(in)%128==0 and len(out)%127==0
func Unpad(in []byte, out []byte) {
if len(out) > mtTresh {
mt(in, out, len(in), Unpad)
if len(in) > mtTresh {
mt(out, in, len(in), unpad)
return
}
unpad(out, in)
}
func unpad(out, in []byte) {
chunks := len(in) / 128
for chunk := 0; chunk < chunks; chunk++ {
inOffNext := chunk*128 + 1

66
fr32/fr32_ffi_cmp_test.go Normal file
View File

@ -0,0 +1,66 @@
package fr32
import (
"bytes"
"io"
"io/ioutil"
"os"
"testing"
"github.com/stretchr/testify/require"
ffi "github.com/filecoin-project/filecoin-ffi"
"github.com/filecoin-project/specs-actors/actors/abi"
"github.com/filecoin-project/sector-storage/ffiwrapper"
)
func TestWriteTwoPcs(t *testing.T) {
tf, _ := ioutil.TempFile("/tmp/", "scrb-")
paddedSize := abi.PaddedPieceSize(16 << 20)
n := 2
var rawBytes []byte
for i := 0; i < n; i++ {
buf := bytes.Repeat([]byte{0xab * byte(i)}, int(paddedSize.Unpadded()))
rawBytes = append(rawBytes, buf...)
rf, w, _ := ffiwrapper.ToReadableFile(bytes.NewReader(buf), int64(len(buf)))
_, _, _, err := ffi.WriteWithAlignment(abi.RegisteredProof_StackedDRG32GiBSeal, rf, abi.UnpaddedPieceSize(len(buf)), tf, nil)
if err != nil {
panic(err)
}
if err := w(); err != nil {
panic(err)
}
}
if _, err := tf.Seek(io.SeekStart, 0); err != nil {
panic(err)
}
ffiBytes, err := ioutil.ReadAll(tf)
if err != nil {
panic(err)
}
if err := tf.Close(); err != nil {
panic(err)
}
if err := os.Remove(tf.Name()); err != nil {
panic(err)
}
outBytes := make([]byte, int(paddedSize) * n)
Pad(rawBytes, outBytes)
require.Equal(t, ffiBytes, outBytes)
unpadBytes := make([]byte, int(paddedSize.Unpadded()) * n)
Unpad(ffiBytes, unpadBytes)
require.Equal(t, rawBytes, unpadBytes)
}