/** # Copyright (c) NVIDIA CORPORATION. All rights reserved. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. **/ package image import ( "testing" "github.com/opencontainers/runtime-spec/specs-go" "github.com/stretchr/testify/require" ) func TestIsPrivileged(t *testing.T) { var tests = []struct { spec specs.Spec expected bool }{ { specs.Spec{ Process: &specs.Process{ Capabilities: &specs.LinuxCapabilities{ Bounding: []string{"CAP_SYS_ADMIN"}, }, }, }, true, }, { specs.Spec{ Process: &specs.Process{ Capabilities: &specs.LinuxCapabilities{ Bounding: []string{"CAP_SYS_FOO"}, }, }, }, false, }, } for i, tc := range tests { privileged := IsPrivileged((*OCISpec)(&tc.spec)) require.Equal(t, tc.expected, privileged, "%d: %v", i, tc) } }