Skip to content

Commit

Permalink
Merge pull request kubernetes#11 from siyuanfoundation/compat-versions
Browse files Browse the repository at this point in the history
update feature gating changes section
  • Loading branch information
jpbetz authored Jan 18, 2024
2 parents 219e3d6 + d2a0caa commit 92be63c
Show file tree
Hide file tree
Showing 2 changed files with 71 additions and 1 deletion.
71 changes: 70 additions & 1 deletion keps/sig-architecture/4330-compatibility-versions/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -324,8 +324,9 @@ compatibility version support.
#### Feature gating changes
In order to preserve the behavior of in-development features across multiple releases,
feature implementations may also be gated by version number.
feature implementation history should also be preserved in the code base.
Naively, the feature implementations can be gated by version number.
For example, if `FeatureA` is partially implemented in 1.28 and additional functionality
is added in 1.29, the feature developer is expected to gate the functionality by version.
E.g.:
Expand All @@ -335,6 +336,74 @@ if feature_gate.Enabled(FeatureA) && feature_gate.CompatibilityVersion() <= "1.2
if feature_gate.Enabled(FeatureA) && feature_gate.CompatibilityVersion() >= "1.29" {implementation 2}
```
A better way might be to define a `featureOptions` struct constructed based on the the feature gate, and have the `featureOptions` control the main code flow, so that the main code is version agnostic.
E.g.:
```go
// in kube_features.go
const (
FeatureA featuregate.Feature = "FeatureA"
FeatureB featuregate.Feature = "FeatureB"
)

func init() {
utilfeature.DefaultMutableFeatureGate.AddVersioned(defaultKubernetesFeatureGates)
}

var defaultKubernetesFeatureGates = map[Feature]VersionedSpecs{
featureA: VersionedSpecs{
{Version: mustParseVersion("1.27"), Default: false, PreRelease: Alpha},
},
featureB: VersionedSpecs{
{Version: mustParseVersion("1.28"), Default: false, PreRelease: Alpha},
{Version: mustParseVersion("1.30"), Default: true, PreRelease: Beta},
},
}

type featureOptions struct {
AEnabled bool
AHasCapabilityZ bool
BEnabled bool
BHandler func()
}

func newFeatureOptions(featureGate FeatureGate) featureOptions {
opts := featureOptions{}
if featureGate.Enabled(FeatureA) {
opts.AEnabled = true
}
if featureGate.CompatibilityVersion() > "1.29" {
opts.AHasCapabilityZ = true
}

if featureGate.Enabled(FeatureB) {
opts.BEnabled = true
}
if featureGate.CompatibilityVersion() > "1.28" {
opts.BHandler = newHandler
} else {
opts.BHandler = oldHandler
}
return opts
}

// in client.go
func ClientFunction() {
// ...
featureOpts := newFeatureOptions(utilfeature.DefaultFeatureGate)
if featureOpts.AEnabled {
// ...
if featureOpts.AHasCapabilityZ {
// run CapabilityZ
}
}
if featureOpts.BEnabled {
featureOpts.BHandler()
}
// ...
}

```
### CEL Environment Compatibility Versioning
CEL environments already [support a compatibility
Expand Down
1 change: 1 addition & 0 deletions keps/sig-architecture/4330-compatibility-versions/kep.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ authors:
- "@logicalhan"
- "@jpbetz"
- "@liggitt"
- "@siyuanfoundation"
owning-sig: sig-api-machinery
participating-sigs:
- sig-architecture
Expand Down

0 comments on commit 92be63c

Please sign in to comment.