From 79e0a6fdc441d8f97163f38e87d81506577fca84 Mon Sep 17 00:00:00 2001 From: Daniel Huang <90274225+dahuang-purestorage@users.noreply.github.com> Date: Wed, 21 Feb 2024 10:37:35 -0800 Subject: [PATCH] add check for shared volumes in getVolumeStats (#2419) (#2420) * add check for shared volumes in getVolumeStats (#2419) Adds check for shared v4 volumes that have a different attach path than the assumed CSI volume path. JIRA: PWX-35351 Signed-off-by: dahuang --- api/api.go | 5 +++++ csi/node.go | 3 ++- csi/node_test.go | 15 ++++++++++++++- 3 files changed, 21 insertions(+), 2 deletions(-) diff --git a/api/api.go b/api/api.go index dfef1c5a5..9cfc860d3 100644 --- a/api/api.go +++ b/api/api.go @@ -1491,3 +1491,8 @@ func (s *ProxySpec) GetPureFullVolumeName() string { return "" } + +const ( + // SharedVolExportPrefix is the export path where shared volumes are mounted + SharedVolExportPrefix = "/var/lib/osd/pxns" +) diff --git a/csi/node.go b/csi/node.go index cd8c4a1b7..6deece075 100644 --- a/csi/node.go +++ b/csi/node.go @@ -364,8 +364,9 @@ func (s *OsdCsiServer) NodeGetVolumeStats(ctx context.Context, req *csi.NodeGetV } var attachPathMatch bool + sharedPath := fmt.Sprintf("%s/%s", api.SharedVolExportPrefix, id) for _, attachPath := range vol.AttachPath { - if attachPath == path { + if attachPath == path || attachPath == sharedPath { attachPathMatch = true } } diff --git a/csi/node_test.go b/csi/node_test.go index 0688f100d..9e1b7f6d0 100644 --- a/csi/node_test.go +++ b/csi/node_test.go @@ -1067,8 +1067,9 @@ func TestNodeGetVolumeStats(t *testing.T) { used := int64(1 * 1024 * 1024) available := size - used id := "myvol123" + sharedPath := fmt.Sprintf("%s/%s", api.SharedVolExportPrefix, id) // "/var/lib/osd/pxns/myvol123" vol := &api.Volume{ - AttachPath: []string{"/test"}, + AttachPath: []string{"/test", sharedPath}, Id: id, Locator: &api.VolumeLocator{ Name: id, @@ -1104,6 +1105,18 @@ func TestNodeGetVolumeStats(t *testing.T) { assert.Equal(t, false, resp.VolumeCondition.Abnormal) assert.Equal(t, "Volume status is up", resp.VolumeCondition.Message) + // Get VolumeStats - shared volume + resp, err = c.NodeGetVolumeStats( + context.Background(), + &csi.NodeGetVolumeStatsRequest{VolumeId: id, VolumePath: sharedPath}) + assert.NoError(t, err) + assert.Equal(t, 1, len(resp.Usage)) + assert.Equal(t, size, resp.Usage[0].Total) + assert.Equal(t, used, resp.Usage[0].Used) + assert.Equal(t, available, resp.Usage[0].Available) + assert.Equal(t, false, resp.VolumeCondition.Abnormal) + assert.Equal(t, "Volume status is up", resp.VolumeCondition.Message) + // Get VolumeStats - down vol.Status = api.VolumeStatus_VOLUME_STATUS_DOWN resp, err = c.NodeGetVolumeStats(