mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-08-07 11:13:48 +00:00
Merge pull request #116342 from msau42/unlock
Unlock CSIMigrationvSphere feature gate
This commit is contained in:
commit
8b413d224a
@ -896,7 +896,7 @@ var defaultKubernetesFeatureGates = map[featuregate.Feature]featuregate.FeatureS
|
|||||||
|
|
||||||
CSIMigrationRBD: {Default: false, PreRelease: featuregate.Alpha}, // Off by default (requires RBD CSI driver)
|
CSIMigrationRBD: {Default: false, PreRelease: featuregate.Alpha}, // Off by default (requires RBD CSI driver)
|
||||||
|
|
||||||
CSIMigrationvSphere: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.28
|
CSIMigrationvSphere: {Default: true, PreRelease: featuregate.GA}, // LockToDefault when CSI driver with GA support for Windows, raw block and xfs features are available
|
||||||
|
|
||||||
CSINodeExpandSecret: {Default: false, PreRelease: featuregate.Alpha},
|
CSINodeExpandSecret: {Default: false, PreRelease: featuregate.Alpha},
|
||||||
|
|
||||||
|
@ -91,6 +91,62 @@ func TestIsMigratable(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestCheckMigrationFeatureFlags(t *testing.T) {
|
||||||
|
testCases := []struct {
|
||||||
|
name string
|
||||||
|
pluginFeature featuregate.Feature
|
||||||
|
pluginFeatureEnabled bool
|
||||||
|
pluginUnregsiterFeature featuregate.Feature
|
||||||
|
pluginUnregsiterEnabled bool
|
||||||
|
expectMigrationComplete bool
|
||||||
|
expectErr bool
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "plugin specific migration feature enabled with plugin unregister disabled",
|
||||||
|
pluginFeature: features.CSIMigrationvSphere,
|
||||||
|
pluginFeatureEnabled: true,
|
||||||
|
pluginUnregsiterFeature: features.InTreePluginvSphereUnregister,
|
||||||
|
pluginUnregsiterEnabled: false,
|
||||||
|
expectMigrationComplete: false,
|
||||||
|
expectErr: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "plugin specific migration feature and plugin unregister disabled",
|
||||||
|
pluginFeature: features.CSIMigrationvSphere,
|
||||||
|
pluginFeatureEnabled: false,
|
||||||
|
pluginUnregsiterFeature: features.InTreePluginvSphereUnregister,
|
||||||
|
pluginUnregsiterEnabled: false,
|
||||||
|
expectMigrationComplete: false,
|
||||||
|
expectErr: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "all features enabled",
|
||||||
|
pluginFeature: features.CSIMigrationvSphere,
|
||||||
|
pluginFeatureEnabled: true,
|
||||||
|
pluginUnregsiterFeature: features.InTreePluginvSphereUnregister,
|
||||||
|
pluginUnregsiterEnabled: true,
|
||||||
|
expectMigrationComplete: true,
|
||||||
|
expectErr: false,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for _, test := range testCases {
|
||||||
|
t.Run(fmt.Sprintf("Testing %v", test.name), func(t *testing.T) {
|
||||||
|
defer featuregatetesting.SetFeatureGateDuringTest(t, utilfeature.DefaultFeatureGate, test.pluginFeature, test.pluginFeatureEnabled)()
|
||||||
|
defer featuregatetesting.SetFeatureGateDuringTest(t, utilfeature.DefaultFeatureGate, test.pluginUnregsiterFeature, test.pluginUnregsiterEnabled)()
|
||||||
|
migrationComplete, err := CheckMigrationFeatureFlags(utilfeature.DefaultFeatureGate, test.pluginFeature, test.pluginUnregsiterFeature)
|
||||||
|
if err != nil && test.expectErr == false {
|
||||||
|
t.Errorf("Unexpected error: %v", err)
|
||||||
|
}
|
||||||
|
if err == nil && test.expectErr == true {
|
||||||
|
t.Errorf("Unexpected validation pass")
|
||||||
|
}
|
||||||
|
if migrationComplete != test.expectMigrationComplete {
|
||||||
|
t.Errorf("Unexpected migrationComplete result. Exp: %v, got %v", test.expectMigrationComplete, migrationComplete)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func TestMigrationFeatureFlagStatus(t *testing.T) {
|
func TestMigrationFeatureFlagStatus(t *testing.T) {
|
||||||
testCases := []struct {
|
testCases := []struct {
|
||||||
name string
|
name string
|
||||||
|
Loading…
Reference in New Issue
Block a user