2020-04-06 17:54:01 +02:00
|
|
|
/*
|
2020-06-18 16:13:24 +02:00
|
|
|
Copyright 2020 Docker, Inc.
|
2020-04-06 17:54:01 +02:00
|
|
|
|
2020-06-18 16:13:24 +02:00
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
2020-04-06 17:54:01 +02:00
|
|
|
|
2020-06-18 16:13:24 +02:00
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
2020-04-06 17:54:01 +02:00
|
|
|
|
2020-06-18 16:13:24 +02:00
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
2020-04-06 17:54:01 +02:00
|
|
|
*/
|
|
|
|
|
2020-04-24 18:04:32 +02:00
|
|
|
package store
|
2020-04-06 17:54:01 +02:00
|
|
|
|
|
|
|
import (
|
2020-04-24 18:04:32 +02:00
|
|
|
_ "crypto/sha256"
|
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
|
2020-08-04 13:23:23 +02:00
|
|
|
"gotest.tools/v3/assert"
|
|
|
|
"gotest.tools/v3/assert/cmp"
|
2020-05-14 21:53:14 +02:00
|
|
|
|
2020-08-21 17:24:53 +02:00
|
|
|
"github.com/docker/compose-cli/errdefs"
|
2020-04-06 17:54:01 +02:00
|
|
|
)
|
|
|
|
|
2020-08-04 13:23:23 +02:00
|
|
|
func testStore(t *testing.T) Store {
|
|
|
|
d, err := ioutil.TempDir("", "store")
|
|
|
|
assert.NilError(t, err)
|
2020-04-24 18:04:32 +02:00
|
|
|
|
2020-08-04 13:23:23 +02:00
|
|
|
t.Cleanup(func() {
|
|
|
|
_ = os.RemoveAll(d)
|
|
|
|
})
|
2020-04-24 18:04:32 +02:00
|
|
|
|
2020-09-16 15:53:25 +02:00
|
|
|
s, err := New(d)
|
2020-08-04 13:23:23 +02:00
|
|
|
assert.NilError(t, err)
|
2020-04-24 18:04:32 +02:00
|
|
|
|
2020-08-04 13:23:23 +02:00
|
|
|
return s
|
2020-04-24 18:04:32 +02:00
|
|
|
}
|
|
|
|
|
2020-08-04 13:23:23 +02:00
|
|
|
func TestCreate(t *testing.T) {
|
|
|
|
s := testStore(t)
|
|
|
|
err := s.Create("test", "test", "description", ContextMetadata{})
|
|
|
|
assert.NilError(t, err)
|
2020-05-11 17:56:58 +02:00
|
|
|
|
2020-08-04 13:23:23 +02:00
|
|
|
err = s.Create("test", "test", "descrsiption", ContextMetadata{})
|
|
|
|
assert.Error(t, err, `context "test": already exists`)
|
|
|
|
assert.Assert(t, errdefs.IsAlreadyExistsError(err))
|
2020-04-24 18:04:32 +02:00
|
|
|
}
|
|
|
|
|
2020-08-04 13:23:23 +02:00
|
|
|
func TestGetEndpoint(t *testing.T) {
|
|
|
|
s := testStore(t)
|
|
|
|
err := s.Create("aci", "aci", "description", AciContext{
|
Change the way a context is stored
Initially we stored the context data in the `Metadata` of the context
but in hindsight this data would be better of in the `Endpoints` because
that's what it is used for.
Before:
```json
{
"Name": "aci",
"Metadata": {
"Type": "aci",
"Data": {
"key": "value"
}
},
"Endpoints": {
"docker": {}
}
}
```
After:
```json
{
"Name": "aci",
"Type": "aci",
"Metadata": {},
"Endpoints": {
"aci": {
"key": "value"
},
"docker": {}
}
}
```
With this change the contexts that we create are more in line with the contexts the docker cli creates.
It also makes the code less complicated since we don't need to marsal twice any more. The API is nicer too:
```go
// Get a context:
c, err := store.Get(contextName)
// Get the stored endpoint:
var aciContext store.AciContext
if err := contextStore.GetEndpoint(currentContext, &aciContext); err != nil {
return nil, err
}
```
2020-05-22 11:16:01 +02:00
|
|
|
Location: "eu",
|
|
|
|
})
|
2020-08-04 13:23:23 +02:00
|
|
|
assert.NilError(t, err)
|
Change the way a context is stored
Initially we stored the context data in the `Metadata` of the context
but in hindsight this data would be better of in the `Endpoints` because
that's what it is used for.
Before:
```json
{
"Name": "aci",
"Metadata": {
"Type": "aci",
"Data": {
"key": "value"
}
},
"Endpoints": {
"docker": {}
}
}
```
After:
```json
{
"Name": "aci",
"Type": "aci",
"Metadata": {},
"Endpoints": {
"aci": {
"key": "value"
},
"docker": {}
}
}
```
With this change the contexts that we create are more in line with the contexts the docker cli creates.
It also makes the code less complicated since we don't need to marsal twice any more. The API is nicer too:
```go
// Get a context:
c, err := store.Get(contextName)
// Get the stored endpoint:
var aciContext store.AciContext
if err := contextStore.GetEndpoint(currentContext, &aciContext); err != nil {
return nil, err
}
```
2020-05-22 11:16:01 +02:00
|
|
|
|
|
|
|
var ctx AciContext
|
2020-08-04 13:23:23 +02:00
|
|
|
err = s.GetEndpoint("aci", &ctx)
|
|
|
|
assert.NilError(t, err)
|
|
|
|
assert.Equal(t, ctx.Location, "eu")
|
Change the way a context is stored
Initially we stored the context data in the `Metadata` of the context
but in hindsight this data would be better of in the `Endpoints` because
that's what it is used for.
Before:
```json
{
"Name": "aci",
"Metadata": {
"Type": "aci",
"Data": {
"key": "value"
}
},
"Endpoints": {
"docker": {}
}
}
```
After:
```json
{
"Name": "aci",
"Type": "aci",
"Metadata": {},
"Endpoints": {
"aci": {
"key": "value"
},
"docker": {}
}
}
```
With this change the contexts that we create are more in line with the contexts the docker cli creates.
It also makes the code less complicated since we don't need to marsal twice any more. The API is nicer too:
```go
// Get a context:
c, err := store.Get(contextName)
// Get the stored endpoint:
var aciContext store.AciContext
if err := contextStore.GetEndpoint(currentContext, &aciContext); err != nil {
return nil, err
}
```
2020-05-22 11:16:01 +02:00
|
|
|
|
|
|
|
var exampleCtx ExampleContext
|
2020-08-04 13:23:23 +02:00
|
|
|
err = s.GetEndpoint("aci", &exampleCtx)
|
|
|
|
assert.Error(t, err, "wrong context type")
|
Change the way a context is stored
Initially we stored the context data in the `Metadata` of the context
but in hindsight this data would be better of in the `Endpoints` because
that's what it is used for.
Before:
```json
{
"Name": "aci",
"Metadata": {
"Type": "aci",
"Data": {
"key": "value"
}
},
"Endpoints": {
"docker": {}
}
}
```
After:
```json
{
"Name": "aci",
"Type": "aci",
"Metadata": {},
"Endpoints": {
"aci": {
"key": "value"
},
"docker": {}
}
}
```
With this change the contexts that we create are more in line with the contexts the docker cli creates.
It also makes the code less complicated since we don't need to marsal twice any more. The API is nicer too:
```go
// Get a context:
c, err := store.Get(contextName)
// Get the stored endpoint:
var aciContext store.AciContext
if err := contextStore.GetEndpoint(currentContext, &aciContext); err != nil {
return nil, err
}
```
2020-05-22 11:16:01 +02:00
|
|
|
}
|
|
|
|
|
2020-08-04 13:23:23 +02:00
|
|
|
func TestGetUnknown(t *testing.T) {
|
|
|
|
s := testStore(t)
|
|
|
|
meta, err := s.Get("unknown")
|
|
|
|
assert.Assert(t, cmp.Nil(meta))
|
|
|
|
assert.Error(t, err, `context "unknown": not found`)
|
|
|
|
assert.Assert(t, errdefs.IsNotFoundError(err))
|
2020-04-26 22:07:50 +02:00
|
|
|
}
|
|
|
|
|
2020-08-04 13:23:23 +02:00
|
|
|
func TestGet(t *testing.T) {
|
|
|
|
s := testStore(t)
|
|
|
|
err := s.Create("test", "type", "description", ContextMetadata{})
|
|
|
|
assert.NilError(t, err)
|
|
|
|
|
|
|
|
meta, err := s.Get("test")
|
|
|
|
assert.NilError(t, err)
|
|
|
|
assert.Assert(t, meta != nil)
|
|
|
|
var m DockerContext
|
|
|
|
if meta != nil {
|
|
|
|
m = *meta
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.Equal(t, m.Name, "test")
|
|
|
|
assert.Equal(t, m.Metadata.Description, "description")
|
|
|
|
assert.Equal(t, m.Type(), "type")
|
2020-04-27 11:45:23 +02:00
|
|
|
}
|
2020-04-27 14:04:53 +02:00
|
|
|
|
2020-08-04 13:23:23 +02:00
|
|
|
func TestRemoveNotFound(t *testing.T) {
|
|
|
|
s := testStore(t)
|
|
|
|
err := s.Remove("notfound")
|
|
|
|
assert.Error(t, err, `context "notfound": not found`)
|
|
|
|
assert.Assert(t, errdefs.IsNotFoundError(err))
|
2020-05-11 17:57:17 +02:00
|
|
|
}
|
|
|
|
|
2020-08-04 13:23:23 +02:00
|
|
|
func TestRemove(t *testing.T) {
|
|
|
|
s := testStore(t)
|
|
|
|
err := s.Create("testremove", "type", "description", ContextMetadata{})
|
|
|
|
assert.NilError(t, err)
|
2020-05-26 23:34:38 +02:00
|
|
|
|
2020-08-04 13:23:23 +02:00
|
|
|
meta, err := s.Get("testremove")
|
|
|
|
assert.NilError(t, err)
|
|
|
|
assert.Assert(t, meta != nil)
|
2020-05-11 17:57:17 +02:00
|
|
|
|
2020-08-04 13:23:23 +02:00
|
|
|
err = s.Remove("testremove")
|
|
|
|
assert.NilError(t, err)
|
2020-05-26 23:34:38 +02:00
|
|
|
|
2020-08-04 13:23:23 +02:00
|
|
|
meta, err = s.Get("testremove")
|
|
|
|
assert.Error(t, err, `context "testremove": not found`)
|
|
|
|
assert.Assert(t, cmp.Nil(meta))
|
2020-05-11 17:57:17 +02:00
|
|
|
|
2020-04-24 14:39:49 +02:00
|
|
|
}
|