mirror of
https://github.com/ceph/ceph-csi.git
synced 2024-11-26 00:00:23 +00:00
util: get clusterID for the passed in mon string
as part of migration support, the clusterID has to be fetched from passed in mon. Because the intree RBD storage class only got monitor and not `clusterID` parameter support. However, in CSI, SC has the `clusterID` parameter support but not mon. Due to that we have to fetch the clusterID from config file for the passed in mon and use it in our operations. This adds a helper function to retrieve clusterID from passed in mon string. Updates https://github.com/ceph/ceph-csi/issues/2509 Signed-off-by: Humble Chirammal <hchiramm@redhat.com>
This commit is contained in:
parent
22bb31df19
commit
1f5963919f
@ -161,3 +161,44 @@ func GetClusterID(options map[string]string) (string, error) {
|
|||||||
|
|
||||||
return clusterID, nil
|
return clusterID, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetClusterIDFromMon will be called with a mon string to fetch
|
||||||
|
// clusterID based on the passed in mon string. If passed in 'mon'
|
||||||
|
// string has been found in the config the clusterID is returned,
|
||||||
|
// else error.
|
||||||
|
func GetClusterIDFromMon(mon string) (string, error) {
|
||||||
|
clusterID, err := readClusterInfoWithMon(CsiConfigFile, mon)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
return clusterID, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func readClusterInfoWithMon(pathToConfig, mon string) (string, error) {
|
||||||
|
var config []ClusterInfo
|
||||||
|
|
||||||
|
// #nosec
|
||||||
|
content, err := ioutil.ReadFile(pathToConfig)
|
||||||
|
if err != nil {
|
||||||
|
err = fmt.Errorf("error fetching configuration file %q: %w", pathToConfig, err)
|
||||||
|
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
err = json.Unmarshal(content, &config)
|
||||||
|
if err != nil {
|
||||||
|
return "", fmt.Errorf("unmarshal failed (%w), raw buffer response: %s",
|
||||||
|
err, string(content))
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, cluster := range config {
|
||||||
|
for _, m := range cluster.Monitors {
|
||||||
|
if m == mon {
|
||||||
|
return cluster.ClusterID, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return "", fmt.Errorf("missing configuration of cluster ID for mon %q", mon)
|
||||||
|
}
|
||||||
|
@ -34,7 +34,7 @@ func cleanupTestData() {
|
|||||||
os.RemoveAll(basePath)
|
os.RemoveAll(basePath)
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: make this function less complex.
|
// nolint:gocyclo,cyclop // TODO: make this function less complex.
|
||||||
func TestCSIConfig(t *testing.T) {
|
func TestCSIConfig(t *testing.T) {
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
var err error
|
var err error
|
||||||
@ -132,4 +132,42 @@ func TestCSIConfig(t *testing.T) {
|
|||||||
if err != nil || content != "mon4,mon5,mon6" {
|
if err != nil || content != "mon4,mon5,mon6" {
|
||||||
t.Errorf("Failed: want (%s), got (%s) (%v)", "mon4,mon5,mon6", content, err)
|
t.Errorf("Failed: want (%s), got (%s) (%v)", "mon4,mon5,mon6", content, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
data = "[{\"clusterID\":\"" + clusterID2 + "\",\"monitors\":[\"mon1\",\"mon2\",\"mon3\"]}," +
|
||||||
|
"{\"clusterID\":\"" + clusterID1 + "\",\"monitors\":[\"mon4\",\"mon5\",\"mon6\"]}]"
|
||||||
|
err = ioutil.WriteFile(basePath+"/"+csiClusters, []byte(data), 0o600)
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Test setup error %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// TEST: Should pass as clusterID is present in config
|
||||||
|
content, err = readClusterInfoWithMon(pathToConfig, "mon1")
|
||||||
|
if err != nil || content != "test2" {
|
||||||
|
t.Errorf("Failed: want (%s), got (%s) (%v)", "test2", content, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// TEST: Should pass as clusterID is present in config
|
||||||
|
content, err = readClusterInfoWithMon(pathToConfig, "mon5")
|
||||||
|
if err != nil || content != "test1" {
|
||||||
|
t.Errorf("Failed: want (%s), got (%s) (%v)", "test1", content, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// TEST: Should fail as clusterID is not present in config
|
||||||
|
content, err = readClusterInfoWithMon(pathToConfig, "mon8")
|
||||||
|
if err == nil {
|
||||||
|
t.Errorf("Failed: got (%s)", content)
|
||||||
|
}
|
||||||
|
|
||||||
|
data = "[{\"clusterID\":\"" + clusterID2 + "\", \"radosNamespace\": \"ns1\", \"monitors\":[\"mon1\"]}," +
|
||||||
|
"{\"clusterID\":\"" + clusterID1 + "\",\"monitors\":[\"mon1\"]}]"
|
||||||
|
err = ioutil.WriteFile(basePath+"/"+csiClusters, []byte(data), 0o600)
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Test setup error %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// TEST: Should pass as clusterID is present in config
|
||||||
|
content, err = readClusterInfoWithMon(pathToConfig, "mon1")
|
||||||
|
if err != nil || content != clusterID1 {
|
||||||
|
t.Errorf("Failed: want (%s), got (%s) (%v)", "test2", content, err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user