mirror of
https://github.com/portainer/portainer.git
synced 2025-07-19 13:29:41 +02:00
* use the Store interface IsErrObjectNotFound() to avoid revealing internal errors Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * what happens when you extract the datastore interfaces into their own package Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * Start renaming Storage methods Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * extract the boltdb specific code from the Portainer storage code (example, the others need the same) Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * more extract bolt.Tx from datastore code Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * minimise imports by putting moving the struct definition into the file that needs the Service imports Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * more extraction of boltdb.Tx Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * extract the use of bucket.SetSequence Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * almost done - just endpoint.Synchonise :/ Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * so, endpoint.Synchonize looks hard, but i can't find where we use it, so 'delete first refactoring' Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * fix test compile errors Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * test compile fixes after rebase Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * fix a mis-remembering I had wrt deserialisation - last time i used AnyData - jsoniter's bindTo looks interesting for the same reason Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * set us up to make the connection an interface Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * make the db connection a datastore interface, and separate out our datastore services from the bolt ones Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * rename methods to something less oltdb internals specific Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * these errors are not boltdb secific Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * start using the db-backend factory method too Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * export boltdb raw in case we can't export from the service layer Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * add a raw export from boltdb to yaml for broken db's, and an export services to yaml in backup Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * add the version info by hand for now Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * actually, the export from services can be fully typed - its the import that needs to do more work Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * redo raw export, and make import capable of using it Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * add DockerHub Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * migration from anything older than v1.21.0 has been broken for quite a while, deleting the un-tested code Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * fix go test ./... again Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * my goland wasn't setup to gofmt Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * move the two extremely dubious migration tests down into store, so they can use the test store code Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * the migrator is now free of boltdb Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * reverse goland overzealous replcement of internal with boltdb Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * more undo over-zealous goland internal->boltdb Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * yay, now bolt is only mentioned inside the api/database/ dir Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * and this might be the last of the boltdb references? Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * add todo Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * extract the store code into a separate module too Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * don't need the fileService in boltdb anymore Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * use IsErrObjectNotFound() Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * use a string to select what database backend we use Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * make isNew store an ephemeral bool that doesn't stay true after we've initialised it Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * move the import.json wip to a separate file so its more obvious - we'll be using it for testing, emergency fixups, and in the next part of the store work, when we improve migrations and data model lifecycles Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * undo vscode formatting html Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * fix app templates symbol (#6221) * feat(webhook) EE-2125 send registry auth haeder when update swarms service via webhook (#6220) * feat(webhook) EE-2125 add some helpers to registry utils * feat(webhook) EE-2125 persist registryID when creating a webhook * feat(webhook) EE-2125 send registry auth header when executing a webhook * feat(webhook) EE-2125 send registryID to backend when creating a service with webhook * feat(webhook) EE-2125 use the initial registry ID to create webhook on editing service screen * feat(webhook) EE-2125 update webhook when update registry * feat(webhook) EE-2125 add endpoint of update webhook * feat(webhook) EE-2125 code cleanup * feat(webhook) EE-2125 fix a typo * feat(webhook) EE-2125 fix circle import issue with unit test Co-authored-by: Simon Meng <simon.meng@portainer.io> * fix(kubeconfig): show kubeconfig download button for non admin users [EE-2123] (#6204) Co-authored-by: Simon Meng <simon.meng@portainer.io> * fix data-cy for k8s cluster menu (#6226) LGTM * feat(stack): make stack created from app template editable EE-1941 (#6104) feat(stack): make stack from app template editable * fix(container):disable Duplicate/Edit button when the container is portainer (#6223) * fix/ee-1909/show-pull-image-error (#6195) Co-authored-by: sunportainer <ericsun@SG1.local> * feat(cy): add data-cy to helm install button (#6241) * feat(cy): add data-cy to add registry button (#6242) * refactor(app): convert root folder files to es6 (#4159) * refactor(app): duplicate constants as es6 exports (#4158) * fix(docker): provide workaround to save network name variable (#6080) * fix/EE-1862/unable-to-stop-or-remove-stack workaround for var without default value in yaml file * fix/EE-1862/unable-to-stop-or-remove-stack check yaml file * fixed func and var names * wrapper error and used bool for stringset * UT case for createNetworkEnvFile * UT case for %s=%s * powerful StringSet * wrapper error for extract network name * wrapper all the return err * store more env * put to env file * make default value None * feat: gzip static resources (#6258) * fix(ssl)//handle --sslcert and --sslkey ee-2106 (#6203) * fix/ee-2106/handle-sslcert-sslkey Co-authored-by: sunportainer <ericsun@SG1.local> * fix(server):support disable https only ee-2068 (#6232) * fix/ee-2068/disable-forcely-https * feat(store): implement store tests EE-2112 (#6224) * add store tests * add some more tests * Update missing helm user repo methods * remove redundant comments * add webhook export * update webhooks * use the Store interface IsErrObjectNotFound() to avoid revealing internal errors Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * what happens when you extract the datastore interfaces into their own package Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * Start renaming Storage methods Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * extract the boltdb specific code from the Portainer storage code (example, the others need the same) Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * more extract bolt.Tx from datastore code Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * minimise imports by putting moving the struct definition into the file that needs the Service imports Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * more extraction of boltdb.Tx Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * extract the use of bucket.SetSequence Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * almost done - just endpoint.Synchonise :/ Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * so, endpoint.Synchonize looks hard, but i can't find where we use it, so 'delete first refactoring' Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * fix test compile errors Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * test compile fixes after rebase Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * fix a mis-remembering I had wrt deserialisation - last time i used AnyData - jsoniter's bindTo looks interesting for the same reason Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * set us up to make the connection an interface Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * make the db connection a datastore interface, and separate out our datastore services from the bolt ones Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * rename methods to something less oltdb internals specific Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * these errors are not boltdb secific Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * start using the db-backend factory method too Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * export boltdb raw in case we can't export from the service layer Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * add a raw export from boltdb to yaml for broken db's, and an export services to yaml in backup Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * add the version info by hand for now Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * actually, the export from services can be fully typed - its the import that needs to do more work Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * redo raw export, and make import capable of using it Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * add DockerHub Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * migration from anything older than v1.21.0 has been broken for quite a while, deleting the un-tested code Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * fix go test ./... again Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * my goland wasn't setup to gofmt Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * move the two extremely dubious migration tests down into store, so they can use the test store code Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * the migrator is now free of boltdb Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * reverse goland overzealous replcement of internal with boltdb Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * more undo over-zealous goland internal->boltdb Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * yay, now bolt is only mentioned inside the api/database/ dir Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * and this might be the last of the boltdb references? Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * add todo Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * extract the store code into a separate module too Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * don't need the fileService in boltdb anymore Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * use IsErrObjectNotFound() Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * use a string to select what database backend we use Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * make isNew store an ephemeral bool that doesn't stay true after we've initialised it Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * move the import.json wip to a separate file so its more obvious - we'll be using it for testing, emergency fixups, and in the next part of the store work, when we improve migrations and data model lifecycles Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * undo vscode formatting html Signed-off-by: Sven Dowideit <sven.dowideit@portainer.io> * Update missing helm user repo methods * feat(store): implement store tests EE-2112 (#6224) * add store tests * add some more tests * remove redundant comments * add webhook export * update webhooks * fix build issues after rebasing * move migratorparams * remove unneeded integer type conversions * disable the db import/export for now Co-authored-by: Richard Wei <54336863+WaysonWei@users.noreply.github.com> Co-authored-by: cong meng <mcpacino@gmail.com> Co-authored-by: Simon Meng <simon.meng@portainer.io> Co-authored-by: Marcelo Rydel <marcelorydel26@gmail.com> Co-authored-by: Hao Zhang <hao.zhang@portainer.io> Co-authored-by: sunportainer <93502624+sunportainer@users.noreply.github.com> Co-authored-by: sunportainer <ericsun@SG1.local> Co-authored-by: wheresolivia <78844659+wheresolivia@users.noreply.github.com> Co-authored-by: Chaim Lev-Ari <chiptus@users.noreply.github.com> Co-authored-by: Chao Geng <93526589+chaogeng77977@users.noreply.github.com> Co-authored-by: Dmitry Salakhov <to@dimasalakhov.com> Co-authored-by: Matt Hook <hookenz@gmail.com>
265 lines
10 KiB
Go
265 lines
10 KiB
Go
package testhelpers
|
|
|
|
import (
|
|
"io"
|
|
|
|
portainer "github.com/portainer/portainer/api"
|
|
"github.com/portainer/portainer/api/dataservices"
|
|
"github.com/portainer/portainer/api/dataservices/errors"
|
|
)
|
|
|
|
type testDatastore struct {
|
|
customTemplate dataservices.CustomTemplateService
|
|
edgeGroup dataservices.EdgeGroupService
|
|
edgeJob dataservices.EdgeJobService
|
|
edgeStack dataservices.EdgeStackService
|
|
endpoint dataservices.EndpointService
|
|
endpointGroup dataservices.EndpointGroupService
|
|
endpointRelation dataservices.EndpointRelationService
|
|
helmUserRepository dataservices.HelmUserRepositoryService
|
|
registry dataservices.RegistryService
|
|
resourceControl dataservices.ResourceControlService
|
|
apiKeyRepositoryService dataservices.APIKeyRepository
|
|
role dataservices.RoleService
|
|
sslSettings dataservices.SSLSettingsService
|
|
settings dataservices.SettingsService
|
|
stack dataservices.StackService
|
|
tag dataservices.TagService
|
|
teamMembership dataservices.TeamMembershipService
|
|
team dataservices.TeamService
|
|
tunnelServer dataservices.TunnelServerService
|
|
user dataservices.UserService
|
|
version dataservices.VersionService
|
|
webhook dataservices.WebhookService
|
|
}
|
|
|
|
func (d *testDatastore) BackupTo(io.Writer) error { return nil }
|
|
func (d *testDatastore) Open() (bool, error) { return false, nil }
|
|
func (d *testDatastore) Init() error { return nil }
|
|
func (d *testDatastore) Close() error { return nil }
|
|
func (d *testDatastore) CheckCurrentEdition() error { return nil }
|
|
func (d *testDatastore) MigrateData() error { return nil }
|
|
func (d *testDatastore) Rollback(force bool) error { return nil }
|
|
func (d *testDatastore) CustomTemplate() dataservices.CustomTemplateService { return d.customTemplate }
|
|
func (d *testDatastore) EdgeGroup() dataservices.EdgeGroupService { return d.edgeGroup }
|
|
func (d *testDatastore) EdgeJob() dataservices.EdgeJobService { return d.edgeJob }
|
|
func (d *testDatastore) EdgeStack() dataservices.EdgeStackService { return d.edgeStack }
|
|
func (d *testDatastore) Endpoint() dataservices.EndpointService { return d.endpoint }
|
|
func (d *testDatastore) EndpointGroup() dataservices.EndpointGroupService { return d.endpointGroup }
|
|
func (d *testDatastore) EndpointRelation() dataservices.EndpointRelationService {
|
|
return d.endpointRelation
|
|
}
|
|
func (d *testDatastore) HelmUserRepository() dataservices.HelmUserRepositoryService {
|
|
return d.helmUserRepository
|
|
}
|
|
func (d *testDatastore) Registry() dataservices.RegistryService { return d.registry }
|
|
func (d *testDatastore) ResourceControl() dataservices.ResourceControlService {
|
|
return d.resourceControl
|
|
}
|
|
func (d *testDatastore) Role() dataservices.RoleService { return d.role }
|
|
func (d *testDatastore) APIKeyRepository() dataservices.APIKeyRepository {
|
|
return d.apiKeyRepositoryService
|
|
}
|
|
func (d *testDatastore) Settings() dataservices.SettingsService { return d.settings }
|
|
func (d *testDatastore) SSLSettings() dataservices.SSLSettingsService { return d.sslSettings }
|
|
func (d *testDatastore) Stack() dataservices.StackService { return d.stack }
|
|
func (d *testDatastore) Tag() dataservices.TagService { return d.tag }
|
|
func (d *testDatastore) TeamMembership() dataservices.TeamMembershipService { return d.teamMembership }
|
|
func (d *testDatastore) Team() dataservices.TeamService { return d.team }
|
|
func (d *testDatastore) TunnelServer() dataservices.TunnelServerService { return d.tunnelServer }
|
|
func (d *testDatastore) User() dataservices.UserService { return d.user }
|
|
func (d *testDatastore) Version() dataservices.VersionService { return d.version }
|
|
func (d *testDatastore) Webhook() dataservices.WebhookService { return d.webhook }
|
|
|
|
func (d *testDatastore) IsErrObjectNotFound(e error) bool {
|
|
return false
|
|
}
|
|
|
|
func (d *testDatastore) Export(filename string) (err error) {
|
|
return nil
|
|
}
|
|
func (d *testDatastore) Import(filename string) (err error) {
|
|
return nil
|
|
}
|
|
|
|
type datastoreOption = func(d *testDatastore)
|
|
|
|
// NewDatastore creates new instance of testDatastore.
|
|
// Will apply options before returning, opts will be applied from left to right.
|
|
func NewDatastore(options ...datastoreOption) *testDatastore {
|
|
d := testDatastore{}
|
|
for _, o := range options {
|
|
o(&d)
|
|
}
|
|
return &d
|
|
}
|
|
|
|
type stubSettingsService struct {
|
|
settings *portainer.Settings
|
|
}
|
|
|
|
func (s *stubSettingsService) BucketName() string { return "settings" }
|
|
|
|
func (s *stubSettingsService) Settings() (*portainer.Settings, error) {
|
|
return s.settings, nil
|
|
}
|
|
func (s *stubSettingsService) UpdateSettings(settings *portainer.Settings) error {
|
|
s.settings = settings
|
|
return nil
|
|
}
|
|
func (s *stubSettingsService) IsFeatureFlagEnabled(feature portainer.Feature) bool {
|
|
return false
|
|
}
|
|
func WithSettingsService(settings *portainer.Settings) datastoreOption {
|
|
return func(d *testDatastore) {
|
|
d.settings = &stubSettingsService{
|
|
settings: settings,
|
|
}
|
|
}
|
|
}
|
|
|
|
type stubUserService struct {
|
|
users []portainer.User
|
|
}
|
|
|
|
func (s *stubUserService) BucketName() string { return "users" }
|
|
func (s *stubUserService) User(ID portainer.UserID) (*portainer.User, error) { return nil, nil }
|
|
func (s *stubUserService) UserByUsername(username string) (*portainer.User, error) { return nil, nil }
|
|
func (s *stubUserService) Users() ([]portainer.User, error) { return s.users, nil }
|
|
func (s *stubUserService) UsersByRole(role portainer.UserRole) ([]portainer.User, error) {
|
|
return s.users, nil
|
|
}
|
|
func (s *stubUserService) Create(user *portainer.User) error { return nil }
|
|
func (s *stubUserService) UpdateUser(ID portainer.UserID, user *portainer.User) error { return nil }
|
|
func (s *stubUserService) DeleteUser(ID portainer.UserID) error { return nil }
|
|
|
|
// WithUsers testDatastore option that will instruct testDatastore to return provided users
|
|
func WithUsers(us []portainer.User) datastoreOption {
|
|
return func(d *testDatastore) {
|
|
d.user = &stubUserService{users: us}
|
|
}
|
|
}
|
|
|
|
type stubEdgeJobService struct {
|
|
jobs []portainer.EdgeJob
|
|
}
|
|
|
|
func (s *stubEdgeJobService) BucketName() string { return "edgejob" }
|
|
func (s *stubEdgeJobService) EdgeJobs() ([]portainer.EdgeJob, error) { return s.jobs, nil }
|
|
func (s *stubEdgeJobService) EdgeJob(ID portainer.EdgeJobID) (*portainer.EdgeJob, error) {
|
|
return nil, nil
|
|
}
|
|
func (s *stubEdgeJobService) Create(edgeJob *portainer.EdgeJob) error { return nil }
|
|
func (s *stubEdgeJobService) UpdateEdgeJob(ID portainer.EdgeJobID, edgeJob *portainer.EdgeJob) error {
|
|
return nil
|
|
}
|
|
func (s *stubEdgeJobService) DeleteEdgeJob(ID portainer.EdgeJobID) error { return nil }
|
|
func (s *stubEdgeJobService) GetNextIdentifier() int { return 0 }
|
|
|
|
// WithEdgeJobs option will instruct testDatastore to return provided jobs
|
|
func WithEdgeJobs(js []portainer.EdgeJob) datastoreOption {
|
|
return func(d *testDatastore) {
|
|
d.edgeJob = &stubEdgeJobService{jobs: js}
|
|
}
|
|
}
|
|
|
|
type stubEndpointRelationService struct {
|
|
relations []portainer.EndpointRelation
|
|
}
|
|
|
|
func (s *stubEndpointRelationService) BucketName() string { return "endpoint_relation" }
|
|
func (s *stubEndpointRelationService) EndpointRelations() ([]portainer.EndpointRelation, error) {
|
|
return s.relations, nil
|
|
}
|
|
func (s *stubEndpointRelationService) EndpointRelation(ID portainer.EndpointID) (*portainer.EndpointRelation, error) {
|
|
for _, relation := range s.relations {
|
|
if relation.EndpointID == ID {
|
|
return &relation, nil
|
|
}
|
|
}
|
|
|
|
return nil, errors.ErrObjectNotFound
|
|
}
|
|
func (s *stubEndpointRelationService) Create(EndpointRelation *portainer.EndpointRelation) error {
|
|
return nil
|
|
}
|
|
func (s *stubEndpointRelationService) UpdateEndpointRelation(ID portainer.EndpointID, relation *portainer.EndpointRelation) error {
|
|
for i, r := range s.relations {
|
|
if r.EndpointID == ID {
|
|
s.relations[i] = *relation
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
func (s *stubEndpointRelationService) DeleteEndpointRelation(ID portainer.EndpointID) error {
|
|
return nil
|
|
}
|
|
func (s *stubEndpointRelationService) GetNextIdentifier() int { return 0 }
|
|
|
|
// WithEndpointRelations option will instruct testDatastore to return provided jobs
|
|
func WithEndpointRelations(relations []portainer.EndpointRelation) datastoreOption {
|
|
return func(d *testDatastore) {
|
|
d.endpointRelation = &stubEndpointRelationService{relations: relations}
|
|
}
|
|
}
|
|
|
|
type stubEndpointService struct {
|
|
endpoints []portainer.Endpoint
|
|
}
|
|
|
|
func (s *stubEndpointService) BucketName() string { return "endpoint" }
|
|
func (s *stubEndpointService) Endpoint(ID portainer.EndpointID) (*portainer.Endpoint, error) {
|
|
for _, endpoint := range s.endpoints {
|
|
if endpoint.ID == ID {
|
|
return &endpoint, nil
|
|
}
|
|
}
|
|
|
|
return nil, errors.ErrObjectNotFound
|
|
}
|
|
|
|
func (s *stubEndpointService) Endpoints() ([]portainer.Endpoint, error) {
|
|
return s.endpoints, nil
|
|
}
|
|
|
|
func (s *stubEndpointService) Create(endpoint *portainer.Endpoint) error {
|
|
s.endpoints = append(s.endpoints, *endpoint)
|
|
|
|
return nil
|
|
}
|
|
|
|
func (s *stubEndpointService) UpdateEndpoint(ID portainer.EndpointID, endpoint *portainer.Endpoint) error {
|
|
for i, e := range s.endpoints {
|
|
if e.ID == ID {
|
|
s.endpoints[i] = *endpoint
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (s *stubEndpointService) DeleteEndpoint(ID portainer.EndpointID) error {
|
|
endpoints := []portainer.Endpoint{}
|
|
|
|
for _, endpoint := range s.endpoints {
|
|
if endpoint.ID != ID {
|
|
endpoints = append(endpoints, endpoint)
|
|
}
|
|
}
|
|
|
|
s.endpoints = endpoints
|
|
|
|
return nil
|
|
}
|
|
|
|
func (s *stubEndpointService) GetNextIdentifier() int {
|
|
return len(s.endpoints)
|
|
}
|
|
|
|
// WithEndpoints option will instruct testDatastore to return provided environments(endpoints)
|
|
func WithEndpoints(endpoints []portainer.Endpoint) datastoreOption {
|
|
return func(d *testDatastore) {
|
|
d.endpoint = &stubEndpointService{endpoints: endpoints}
|
|
}
|
|
}
|