bouncer/internal/store/testsuite/layer_repository.go
William Petit e66938f1d3
All checks were successful
Cadoles/bouncer/pipeline/head This commit looks good
feat: initial commit
2023-05-21 22:27:25 +02:00

67 lines
1.4 KiB
Go

package testsuite
import (
"context"
"testing"
"forge.cadoles.com/cadoles/bouncer/internal/store"
"github.com/pkg/errors"
)
type layerRepositoryTestCase struct {
Name string
Do func(repo store.LayerRepository) error
}
const layerType store.LayerType = "test"
var layerRepositoryTestCases = []layerRepositoryTestCase{
{
Name: "Create layer",
Do: func(repo store.LayerRepository) error {
ctx := context.Background()
options := map[string]any{}
layer, err := repo.CreateLayer(ctx, "create_layer_proxy", "create_layer", layerType, options)
if err != nil {
return errors.WithStack(err)
}
if layer == nil {
return errors.Errorf("layer should not be nil")
}
if layer.Name == "" {
return errors.Errorf("layer.Name should not be empty")
}
if layer.Proxy == "" {
return errors.Errorf("layer.Proxy should not be empty")
}
if layer.CreatedAt.IsZero() {
return errors.Errorf("layer.CreatedAt should not be zero value")
}
if layer.UpdatedAt.IsZero() {
return errors.Errorf("layer.UpdatedAt should not be zero value")
}
return nil
},
},
}
func TestLayerRepository(t *testing.T, repo store.LayerRepository) {
for _, tc := range layerRepositoryTestCases {
func(tc layerRepositoryTestCase) {
t.Run(tc.Name, func(t *testing.T) {
if err := tc.Do(repo); err != nil {
t.Fatalf("%+v", errors.WithStack(err))
}
})
}(tc)
}
}