mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
* Add update methods for the dual writer * improve errors * [WIP] add tests for the update method * Move example package to its own package so it can be used by the rest package. Finish tests * Add codeowners * Use Pod as a dummy resource * :int * Lint * [REVIEW] rename var * [REVIEW] don't rely on legacy storage at all in mode4 * Update pkg/apiserver/rest/dualwriter_mode2.go Co-authored-by: Arati R. <33031346+suntala@users.noreply.github.com> * [REVIEW] improve comment * Update pkg/apiserver/rest/dualwriter_mode1.go Co-authored-by: Dan Cech <dcech@grafana.com> * [REVIEW] improve mode3 * Lint * Move test files * Update pkg/apiserver/rest/dualwriter_mode2.go Co-authored-by: Arati R. <33031346+suntala@users.noreply.github.com> * Lint * Update pkg/apiserver/rest/dualwriter_mode4_test.go Co-authored-by: Arati R. <33031346+suntala@users.noreply.github.com> * Fix error * Lint * Update pkg/apiserver/rest/dualwriter_mode2.go Co-authored-by: Arati R. <33031346+suntala@users.noreply.github.com> * Don't set the flag to true as updatedObj creates an object in case it's not found * Lint * Lint * Add tests on update * Lint --------- Co-authored-by: Arati R. <33031346+suntala@users.noreply.github.com> Co-authored-by: Dan Cech <dcech@grafana.com>
136 lines
4.9 KiB
Go
136 lines
4.9 KiB
Go
package rest
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/stretchr/testify/mock"
|
|
"k8s.io/apimachinery/pkg/api/meta"
|
|
metainternalversion "k8s.io/apimachinery/pkg/apis/meta/internalversion"
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
"k8s.io/apimachinery/pkg/runtime"
|
|
"k8s.io/apiserver/pkg/registry/rest"
|
|
)
|
|
|
|
type legacyStoreMock struct {
|
|
*mock.Mock
|
|
LegacyStorage
|
|
}
|
|
|
|
type storageMock struct {
|
|
*mock.Mock
|
|
Storage
|
|
}
|
|
|
|
func (m legacyStoreMock) Get(ctx context.Context, name string, options *metav1.GetOptions) (runtime.Object, error) {
|
|
args := m.Called(ctx, name, options)
|
|
if name == "object-fail" {
|
|
return nil, args.Error(1)
|
|
}
|
|
return args.Get(0).(runtime.Object), args.Error(1)
|
|
}
|
|
|
|
func (m legacyStoreMock) Create(ctx context.Context, obj runtime.Object, createValidation rest.ValidateObjectFunc, options *metav1.CreateOptions) (runtime.Object, error) {
|
|
args := m.Called(ctx, obj, createValidation, options)
|
|
acc, err := meta.Accessor(obj)
|
|
if err != nil {
|
|
return nil, args.Error(1)
|
|
}
|
|
name := acc.GetName()
|
|
if name == "object-fail" {
|
|
return nil, args.Error(1)
|
|
}
|
|
return args.Get(0).(runtime.Object), args.Error(1)
|
|
}
|
|
|
|
func (m legacyStoreMock) List(ctx context.Context, options *metainternalversion.ListOptions) (runtime.Object, error) {
|
|
args := m.Called(ctx, options)
|
|
if options.Kind == "fail" {
|
|
return nil, args.Error(1)
|
|
}
|
|
return args.Get(0).(runtime.Object), args.Error(1)
|
|
}
|
|
|
|
func (m legacyStoreMock) Update(ctx context.Context, name string, objInfo rest.UpdatedObjectInfo, createValidation rest.ValidateObjectFunc, updateValidation rest.ValidateObjectUpdateFunc, forceAllowCreate bool, options *metav1.UpdateOptions) (runtime.Object, bool, error) {
|
|
args := m.Called(ctx, name, objInfo, createValidation, updateValidation, forceAllowCreate, options)
|
|
if name == "object-fail" {
|
|
return nil, false, args.Error(2)
|
|
}
|
|
return args.Get(0).(runtime.Object), args.Bool(1), args.Error(2)
|
|
}
|
|
|
|
func (m legacyStoreMock) Delete(ctx context.Context, name string, deleteValidation rest.ValidateObjectFunc, options *metav1.DeleteOptions) (runtime.Object, bool, error) {
|
|
args := m.Called(ctx, name, deleteValidation, options)
|
|
if name == "object-fail" {
|
|
return nil, false, args.Error(2)
|
|
}
|
|
if name == "not-found-legacy" {
|
|
return nil, false, args.Error(2)
|
|
}
|
|
return args.Get(0).(runtime.Object), args.Bool(1), args.Error(2)
|
|
}
|
|
|
|
func (m legacyStoreMock) DeleteCollection(ctx context.Context, deleteValidation rest.ValidateObjectFunc, options *metav1.DeleteOptions, listOptions *metainternalversion.ListOptions) (runtime.Object, error) {
|
|
args := m.Called(ctx, deleteValidation, options, listOptions)
|
|
if options.Kind == "fail" {
|
|
return nil, args.Error(1)
|
|
}
|
|
return args.Get(0).(runtime.Object), args.Error(1)
|
|
}
|
|
|
|
// Unified Store
|
|
func (m storageMock) Get(ctx context.Context, name string, options *metav1.GetOptions) (runtime.Object, error) {
|
|
args := m.Called(ctx, name, options)
|
|
if name == "object-fail" {
|
|
return nil, args.Error(1)
|
|
}
|
|
if name == "not-found" {
|
|
return nil, args.Error(1)
|
|
}
|
|
return args.Get(0).(runtime.Object), args.Error(1)
|
|
}
|
|
|
|
func (m storageMock) Create(ctx context.Context, obj runtime.Object, createValidation rest.ValidateObjectFunc, options *metav1.CreateOptions) (runtime.Object, error) {
|
|
args := m.Called(ctx, obj, createValidation, options)
|
|
acc, err := meta.Accessor(obj)
|
|
if err != nil {
|
|
return nil, args.Error(1)
|
|
}
|
|
name := acc.GetName()
|
|
if name == "object-fail" {
|
|
return nil, args.Error(1)
|
|
}
|
|
return args.Get(0).(runtime.Object), args.Error(1)
|
|
}
|
|
|
|
func (m storageMock) List(ctx context.Context, options *metainternalversion.ListOptions) (runtime.Object, error) {
|
|
args := m.Called(ctx, options)
|
|
if options.Kind == "fail" {
|
|
return nil, args.Error(1)
|
|
}
|
|
return args.Get(0).(runtime.Object), args.Error(1)
|
|
}
|
|
|
|
func (m storageMock) Update(ctx context.Context, name string, objInfo rest.UpdatedObjectInfo, createValidation rest.ValidateObjectFunc, updateValidation rest.ValidateObjectUpdateFunc, forceAllowCreate bool, options *metav1.UpdateOptions) (runtime.Object, bool, error) {
|
|
args := m.Called(ctx, name, objInfo, createValidation, updateValidation, forceAllowCreate, options)
|
|
if name == "object-fail" {
|
|
return nil, false, args.Error(2)
|
|
}
|
|
return args.Get(0).(runtime.Object), args.Bool(1), args.Error(2)
|
|
}
|
|
|
|
func (m storageMock) Delete(ctx context.Context, name string, deleteValidation rest.ValidateObjectFunc, options *metav1.DeleteOptions) (runtime.Object, bool, error) {
|
|
args := m.Called(ctx, name, deleteValidation, options)
|
|
if name == "object-fail" {
|
|
return nil, false, args.Error(2)
|
|
}
|
|
return args.Get(0).(runtime.Object), args.Bool(1), args.Error(2)
|
|
}
|
|
|
|
func (m storageMock) DeleteCollection(ctx context.Context, deleteValidation rest.ValidateObjectFunc, options *metav1.DeleteOptions, listOptions *metainternalversion.ListOptions) (runtime.Object, error) {
|
|
args := m.Called(ctx, deleteValidation, options, listOptions)
|
|
if options.Kind == "fail" {
|
|
return nil, args.Error(1)
|
|
}
|
|
return args.Get(0).(runtime.Object), args.Error(1)
|
|
}
|