Merge pull request #89 from skriss/set-azuredisk-uri
for azureDisk restores, update the diskURI in addition to diskNamepull/91/head
commit
47a6e71b1f
|
@ -20,6 +20,7 @@ import (
|
|||
"errors"
|
||||
"fmt"
|
||||
"regexp"
|
||||
"strings"
|
||||
|
||||
apierrors "k8s.io/apimachinery/pkg/api/errors"
|
||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||
|
@ -103,15 +104,28 @@ func GetPVSource(spec map[string]interface{}) (string, map[string]interface{}) {
|
|||
}
|
||||
|
||||
// SetVolumeID looks for a supported PV source within the provided PV spec data.
|
||||
// If sets the appropriate ID field within the source if found, and returns an
|
||||
// If sets the appropriate ID field(s) within the source if found, and returns an
|
||||
// error if a supported PV source is not found.
|
||||
func SetVolumeID(spec map[string]interface{}, volumeID string) error {
|
||||
sourceType, source := GetPVSource(spec)
|
||||
|
||||
if sourceType == "" {
|
||||
return errors.New("persistent volume source is not compatible")
|
||||
}
|
||||
|
||||
// for azureDisk, we need to do a find-replace within the diskURI (if it exists)
|
||||
// to switch the old disk name with the new.
|
||||
if sourceType == "azureDisk" {
|
||||
uri, err := collections.GetString(source, "diskURI")
|
||||
if err == nil {
|
||||
priorVolumeID, err := collections.GetString(source, supportedVolumeTypes["azureDisk"])
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
source["diskURI"] = strings.Replace(uri, priorVolumeID, volumeID, -1)
|
||||
}
|
||||
}
|
||||
|
||||
source[supportedVolumeTypes[sourceType]] = volumeID
|
||||
|
||||
return nil
|
||||
|
|
|
@ -0,0 +1,108 @@
|
|||
/*
|
||||
Copyright 2017 Heptio Inc.
|
||||
|
||||
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
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
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.
|
||||
*/
|
||||
|
||||
package kube
|
||||
|
||||
import (
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
"github.com/stretchr/testify/require"
|
||||
|
||||
"github.com/heptio/ark/pkg/util/collections"
|
||||
)
|
||||
|
||||
func TestSetVolumeID(t *testing.T) {
|
||||
tests := []struct {
|
||||
name string
|
||||
spec map[string]interface{}
|
||||
volumeID string
|
||||
expectedErr error
|
||||
specFieldExpectations map[string]string
|
||||
}{
|
||||
{
|
||||
name: "awsElasticBlockStore normal case",
|
||||
spec: map[string]interface{}{
|
||||
"awsElasticBlockStore": map[string]interface{}{
|
||||
"volumeID": "vol-old",
|
||||
},
|
||||
},
|
||||
volumeID: "vol-new",
|
||||
expectedErr: nil,
|
||||
},
|
||||
{
|
||||
name: "gcePersistentDisk normal case",
|
||||
spec: map[string]interface{}{
|
||||
"gcePersistentDisk": map[string]interface{}{
|
||||
"pdName": "old-pd",
|
||||
},
|
||||
},
|
||||
volumeID: "new-pd",
|
||||
expectedErr: nil,
|
||||
},
|
||||
{
|
||||
name: "azureDisk normal case",
|
||||
spec: map[string]interface{}{
|
||||
"azureDisk": map[string]interface{}{
|
||||
"diskName": "old-disk",
|
||||
"diskURI": "some-nonsense/old-disk",
|
||||
},
|
||||
},
|
||||
volumeID: "new-disk",
|
||||
expectedErr: nil,
|
||||
specFieldExpectations: map[string]string{
|
||||
"azureDisk.diskURI": "some-nonsense/new-disk",
|
||||
},
|
||||
},
|
||||
{
|
||||
name: "azureDisk with no diskURI",
|
||||
spec: map[string]interface{}{
|
||||
"azureDisk": map[string]interface{}{
|
||||
"diskName": "old-disk",
|
||||
},
|
||||
},
|
||||
volumeID: "new-disk",
|
||||
expectedErr: nil,
|
||||
},
|
||||
}
|
||||
|
||||
for _, test := range tests {
|
||||
t.Run(test.name, func(t *testing.T) {
|
||||
err := SetVolumeID(test.spec, test.volumeID)
|
||||
|
||||
require.Equal(t, test.expectedErr, err)
|
||||
|
||||
if test.expectedErr != nil {
|
||||
return
|
||||
}
|
||||
|
||||
pv := map[string]interface{}{
|
||||
"spec": test.spec,
|
||||
}
|
||||
|
||||
volumeID, err := GetVolumeID(pv)
|
||||
require.Nil(t, err)
|
||||
|
||||
assert.Equal(t, test.volumeID, volumeID)
|
||||
|
||||
for path, expected := range test.specFieldExpectations {
|
||||
actual, err := collections.GetString(test.spec, path)
|
||||
assert.Nil(t, err)
|
||||
assert.Equal(t, expected, actual)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue