Skip to content

Commit 1488e1e

Browse files
committed
Add reclaimPolicy,volumeBindMode,allowVolumeExpandsion to kubectl get storage class
1 parent 31b7e3d commit 1488e1e

File tree

2 files changed

+80
-3
lines changed

2 files changed

+80
-3
lines changed

pkg/printers/internalversion/printers.go

Lines changed: 20 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -410,6 +410,9 @@ func AddHandlers(h printers.PrintHandler) {
410410
storageClassColumnDefinitions := []metav1beta1.TableColumnDefinition{
411411
{Name: "Name", Type: "string", Format: "name", Description: metav1.ObjectMeta{}.SwaggerDoc()["name"]},
412412
{Name: "Provisioner", Type: "string", Description: storagev1.StorageClass{}.SwaggerDoc()["provisioner"]},
413+
{Name: "ReclaimPolicy", Type: "string", Description: storagev1.StorageClass{}.SwaggerDoc()["reclaimPolicy"]},
414+
{Name: "VolumeBindingMode", Type: "string", Description: storagev1.StorageClass{}.SwaggerDoc()["volumeBindingMode"]},
415+
{Name: "AllowVolumeExpansion", Type: "string", Description: storagev1.StorageClass{}.SwaggerDoc()["allowVolumeExpansion"]},
413416
{Name: "Age", Type: "string", Description: metav1.ObjectMeta{}.SwaggerDoc()["creationTimestamp"]},
414417
}
415418

@@ -1857,7 +1860,23 @@ func printStorageClass(obj *storage.StorageClass, options printers.GenerateOptio
18571860
name += " (default)"
18581861
}
18591862
provtype := obj.Provisioner
1860-
row.Cells = append(row.Cells, name, provtype, translateTimestampSince(obj.CreationTimestamp))
1863+
reclaimPolicy := string(api.PersistentVolumeReclaimDelete)
1864+
if obj.ReclaimPolicy != nil {
1865+
reclaimPolicy = string(*obj.ReclaimPolicy)
1866+
}
1867+
1868+
volumeBindingMode := string(storage.VolumeBindingImmediate)
1869+
if obj.VolumeBindingMode != nil {
1870+
volumeBindingMode = string(*obj.VolumeBindingMode)
1871+
}
1872+
1873+
allowVolumeExpansion := false
1874+
if obj.AllowVolumeExpansion != nil {
1875+
allowVolumeExpansion = *obj.AllowVolumeExpansion
1876+
}
1877+
1878+
row.Cells = append(row.Cells, name, provtype, reclaimPolicy, volumeBindingMode, allowVolumeExpansion,
1879+
translateTimestampSince(obj.CreationTimestamp))
18611880

18621881
return []metav1beta1.TableRow{row}, nil
18631882
}

pkg/printers/internalversion/printers_test.go

Lines changed: 60 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -4366,6 +4366,10 @@ func TestPrintCronJobList(t *testing.T) {
43664366
}
43674367

43684368
func TestPrintStorageClass(t *testing.T) {
4369+
policyDelte := api.PersistentVolumeReclaimDelete
4370+
policyRetain := api.PersistentVolumeReclaimRetain
4371+
bindModeImmediate := storage.VolumeBindingImmediate
4372+
bindModeWait := storage.VolumeBindingWaitForFirstConsumer
43694373
tests := []struct {
43704374
sc storage.StorageClass
43714375
expected []metav1beta1.TableRow
@@ -4378,7 +4382,8 @@ func TestPrintStorageClass(t *testing.T) {
43784382
},
43794383
Provisioner: "kubernetes.io/glusterfs",
43804384
},
4381-
expected: []metav1beta1.TableRow{{Cells: []interface{}{"sc1", "kubernetes.io/glusterfs", "0s"}}},
4385+
expected: []metav1beta1.TableRow{{Cells: []interface{}{"sc1", "kubernetes.io/glusterfs", "Delete",
4386+
"Immediate", false, "0s"}}},
43824387
},
43834388
{
43844389
sc: storage.StorageClass{
@@ -4388,7 +4393,60 @@ func TestPrintStorageClass(t *testing.T) {
43884393
},
43894394
Provisioner: "kubernetes.io/nfs",
43904395
},
4391-
expected: []metav1beta1.TableRow{{Cells: []interface{}{"sc2", "kubernetes.io/nfs", "5m"}}},
4396+
expected: []metav1beta1.TableRow{{Cells: []interface{}{"sc2", "kubernetes.io/nfs", "Delete",
4397+
"Immediate", false, "5m"}}},
4398+
},
4399+
{
4400+
sc: storage.StorageClass{
4401+
ObjectMeta: metav1.ObjectMeta{
4402+
Name: "sc3",
4403+
CreationTimestamp: metav1.Time{Time: time.Now().Add(-3e11)},
4404+
},
4405+
Provisioner: "kubernetes.io/nfs",
4406+
ReclaimPolicy: &policyDelte,
4407+
},
4408+
expected: []metav1beta1.TableRow{{Cells: []interface{}{"sc3", "kubernetes.io/nfs", "Delete",
4409+
"Immediate", false, "5m"}}},
4410+
},
4411+
{
4412+
sc: storage.StorageClass{
4413+
ObjectMeta: metav1.ObjectMeta{
4414+
Name: "sc4",
4415+
CreationTimestamp: metav1.Time{Time: time.Now().Add(-3e11)},
4416+
},
4417+
Provisioner: "kubernetes.io/nfs",
4418+
ReclaimPolicy: &policyRetain,
4419+
VolumeBindingMode: &bindModeImmediate,
4420+
},
4421+
expected: []metav1beta1.TableRow{{Cells: []interface{}{"sc4", "kubernetes.io/nfs", "Retain",
4422+
"Immediate", false, "5m"}}},
4423+
},
4424+
{
4425+
sc: storage.StorageClass{
4426+
ObjectMeta: metav1.ObjectMeta{
4427+
Name: "sc5",
4428+
CreationTimestamp: metav1.Time{Time: time.Now().Add(-3e11)},
4429+
},
4430+
Provisioner: "kubernetes.io/nfs",
4431+
ReclaimPolicy: &policyRetain,
4432+
VolumeBindingMode: &bindModeWait,
4433+
},
4434+
expected: []metav1beta1.TableRow{{Cells: []interface{}{"sc5", "kubernetes.io/nfs", "Retain",
4435+
"WaitForFirstConsumer", false, "5m"}}},
4436+
},
4437+
{
4438+
sc: storage.StorageClass{
4439+
ObjectMeta: metav1.ObjectMeta{
4440+
Name: "sc6",
4441+
CreationTimestamp: metav1.Time{Time: time.Now().Add(-3e11)},
4442+
},
4443+
Provisioner: "kubernetes.io/nfs",
4444+
ReclaimPolicy: &policyRetain,
4445+
AllowVolumeExpansion: boolP(true),
4446+
VolumeBindingMode: &bindModeWait,
4447+
},
4448+
expected: []metav1beta1.TableRow{{Cells: []interface{}{"sc6", "kubernetes.io/nfs", "Retain",
4449+
"WaitForFirstConsumer", true, "5m"}}},
43924450
},
43934451
}
43944452

0 commit comments

Comments
 (0)