Skip to content

Commit

Permalink
config: merge runtime and workload allowed annotations
Browse files Browse the repository at this point in the history
to allow for a more smooth transition between workloads and runtime class level allowed annotations

Signed-off-by: Peter Hunt <[email protected]>
  • Loading branch information
haircommander committed Nov 17, 2021
1 parent 518dd42 commit 5fb7618
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 42 deletions.
33 changes: 0 additions & 33 deletions pkg/config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -961,10 +961,6 @@ func (c *RuntimeConfig) Validate(systemContext *types.SystemContext, onExecution
return errors.Wrap(err, "runtime validation")
}

if err := c.ValidateAllowedAnnotations(); err != nil {
return errors.Wrap(err, "allowed annotations validation")
}

// Validate the system registries configuration
if _, err := sysregistriesv2.GetRegistries(systemContext); err != nil {
return errors.Wrap(err, "invalid registries")
Expand Down Expand Up @@ -1305,35 +1301,6 @@ func validateAllowedAndGenerateDisallowedAnnotations(allowed []string) (disallow
return disallowed, nil
}

// In the interim between adding workload level allowed annotations
// and disabling runtime level allowed annotations, we need to do a separate
// validation step to ensure neither list are stepping on the other's toes.
// Instead of complicated logic, declare workload level allowed annotations to
// always overwrite runtime level ones.
func (c *RuntimeConfig) ValidateAllowedAnnotations() error {
var workloadHasAnnotation bool
for _, wl := range c.Workloads {
if len(wl.AllowedAnnotations) != 0 {
workloadHasAnnotation = true
}
}
if !workloadHasAnnotation {
for _, wl := range c.Workloads {
wl.AllowedAnnotations = []string{}
wl.DisallowedAnnotations = []string{}
}
logrus.Infof("Workload does not have an allowed annotation configured. Clearing allowed annotations from runtimes")
return nil
}
logrus.Infof("Workload has an allowed annotation configured. Clearing allowed annotations from runtimes")
for name, rh := range c.Runtimes {
logrus.Infof("Clearing allowed annotations from %s", name)
rh.AllowedAnnotations = []string{}
rh.DisallowedAnnotations = []string{}
}
return nil
}

// CNIPlugin returns the network configuration CNI plugin
func (c *NetworkConfig) CNIPlugin() ocicni.CNIPlugin {
return c.cniManager.Plugin()
Expand Down
8 changes: 3 additions & 5 deletions server/utils.go
Original file line number Diff line number Diff line change
Expand Up @@ -221,14 +221,12 @@ func (s *Server) FilterDisallowedAnnotations(toFind, toFilter map[string]string,
// When runtime level allowed annotations are deprecated, this will be dropped.
// TODO: eventually, this should be in the container package, but it's going through a lot of churn
// and SpecAddAnnotations is already passed too many arguments
rtAllowed, err := s.Runtime().AllowedAnnotations(runtimeHandler)
allowed, err := s.Runtime().AllowedAnnotations(runtimeHandler)
if err != nil {
return err
}
allowed := s.config.Workloads.AllowedAnnotations(toFind)
if len(allowed) == 0 {
allowed = rtAllowed
}
allowed = append(allowed, s.config.Workloads.AllowedAnnotations(toFind)...)
logrus.Warnf("Allowed annotations are specified for workload %v %s", allowed, runtimeHandler)

return s.config.Workloads.FilterDisallowedAnnotations(allowed, toFilter)
}
17 changes: 13 additions & 4 deletions test/workloads.bats
Original file line number Diff line number Diff line change
Expand Up @@ -293,20 +293,29 @@ function check_conmon_fields() {
[[ "$df" != *'16384'* ]]
}

@test "test workload allowed annotation overrides runtime" {
create_workload_with_allowed_annotation "io.kubernetes.cri-o.userns-mode"
@test "test workload allowed annotation appended with runtime" {
if test -n "$CONTAINER_UID_MAPPINGS"; then
skip "userNS enabled"
fi
create_workload_with_allowed_annotation "io.kubernetes.cri-o.Devices"
create_runtime_with_allowed_annotation "shmsize" "io.kubernetes.cri-o.ShmSize"

start_crio

jq '.annotations."io.kubernetes.cri-o.ShmSize" = "16Mi"' \
jq --arg act "$activation" \
' .annotations[$act] = "true"
| .annotations."io.kubernetes.cri-o.ShmSize" = "16Mi"
| .annotations."io.kubernetes.cri-o.Devices" = "/dev/null:/dev/peterfoo:rwm"' \
"$TESTDATA"/sandbox_config.json > "$sboxconfig"

ctrconfig="$TESTDATA"/container_sleep.json
ctr_id=$(crictl run "$ctrconfig" "$sboxconfig")

df=$(crictl exec --sync "$ctr_id" df | grep /dev/shm)
[[ "$df" != *'16384'* ]]
[[ "$df" == *'16384'* ]]

crictl exec --sync "$ctr_id" sh -c "head -n1 /dev/peterfoo"

}

@test "test workload allowed annotation works for pod" {
Expand Down

0 comments on commit 5fb7618

Please sign in to comment.