William Petit
19539ec34a
All checks were successful
arcad/edge/pipeline/pr-master This commit looks good
103 lines
2.0 KiB
Go
103 lines
2.0 KiB
Go
package client
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"net/http/httptest"
|
|
"os"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/keegancsmith/rpc"
|
|
|
|
"forge.cadoles.com/arcad/edge/pkg/storage/rpc/server"
|
|
"forge.cadoles.com/arcad/edge/pkg/storage/sqlite"
|
|
"forge.cadoles.com/arcad/edge/pkg/storage/testsuite"
|
|
"github.com/pkg/errors"
|
|
"gitlab.com/wpetit/goweb/logger"
|
|
)
|
|
|
|
func TestBlobStore(t *testing.T) {
|
|
t.Parallel()
|
|
if testing.Verbose() {
|
|
logger.SetLevel(logger.LevelDebug)
|
|
}
|
|
|
|
httpServer, err := startNewBlobStoreServer()
|
|
if err != nil {
|
|
t.Fatalf("%+v", errors.WithStack(err))
|
|
}
|
|
|
|
defer httpServer.Close()
|
|
|
|
serverAddr := httpServer.Listener.Addr()
|
|
|
|
client, err := rpc.DialHTTPPath(
|
|
serverAddr.Network(),
|
|
serverAddr.String(),
|
|
"",
|
|
)
|
|
if err != nil {
|
|
t.Fatalf("%+v", errors.WithStack(err))
|
|
}
|
|
defer client.Close()
|
|
|
|
store := NewBlobStore(client)
|
|
|
|
testsuite.TestBlobStore(context.Background(), t, store)
|
|
}
|
|
|
|
func BenchmarkBlobStore(t *testing.B) {
|
|
logger.SetLevel(logger.LevelError)
|
|
|
|
httpServer, err := startNewBlobStoreServer()
|
|
if err != nil {
|
|
t.Fatalf("%+v", errors.WithStack(err))
|
|
}
|
|
|
|
defer httpServer.Close()
|
|
|
|
serverAddr := httpServer.Listener.Addr()
|
|
|
|
client, err := rpc.DialHTTPPath(
|
|
serverAddr.Network(),
|
|
serverAddr.String(),
|
|
"",
|
|
)
|
|
if err != nil {
|
|
t.Fatalf("%+v", errors.WithStack(err))
|
|
}
|
|
defer client.Close()
|
|
|
|
store := NewBlobStore(client)
|
|
|
|
testsuite.BenchmarkBlobStore(t, store)
|
|
|
|
}
|
|
|
|
func getSQLiteBlobStore() (*sqlite.BlobStore, error) {
|
|
file := "./testdata/blobstore_test.sqlite"
|
|
|
|
if err := os.Remove(file); err != nil && !errors.Is(err, os.ErrNotExist) {
|
|
return nil, errors.WithStack(err)
|
|
}
|
|
|
|
dsn := fmt.Sprintf("%s?_pragma=foreign_keys(1)&_pragma=busy_timeout=%d", file, (60 * time.Second).Milliseconds())
|
|
store := sqlite.NewBlobStore(dsn)
|
|
|
|
return store, nil
|
|
}
|
|
|
|
func startNewBlobStoreServer() (*httptest.Server, error) {
|
|
store, err := getSQLiteBlobStore()
|
|
if err != nil {
|
|
return nil, errors.WithStack(err)
|
|
}
|
|
|
|
server := server.NewBlobStoreServer(store)
|
|
|
|
httpServer := httptest.NewServer(server)
|
|
|
|
return httpServer, nil
|
|
}
|