addresses https://github.com/containerd/containerd/issues/6464 Return an error if a runtime provided is relative. Add context to the usage for `ctr run --runtime` indicating that absolute path to runtime binary must be provided. Signed-off-by: Gavin Inglis <giinglis@amazon.com>
		
			
				
	
	
		
			100 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
//go:build !windows && !darwin
 | 
						|
// +build !windows,!darwin
 | 
						|
 | 
						|
/*
 | 
						|
   Copyright The containerd Authors.
 | 
						|
 | 
						|
   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 v2
 | 
						|
 | 
						|
import (
 | 
						|
	"os"
 | 
						|
	"testing"
 | 
						|
)
 | 
						|
 | 
						|
// setupAbsoluteShimPath creates a temporary directory in $PATH with an empty
 | 
						|
// shim executable file in it to test the exec.LookPath branch of resolveRuntimePath
 | 
						|
func setupAbsoluteShimPath(t *testing.T) (string, error) {
 | 
						|
	tempShimDir := t.TempDir()
 | 
						|
 | 
						|
	_, err := os.Create(tempShimDir + "/containerd-shim-runc-v2")
 | 
						|
	if err != nil {
 | 
						|
		return "", err
 | 
						|
	}
 | 
						|
 | 
						|
	t.Setenv("PATH", tempShimDir+":"+os.Getenv("PATH"))
 | 
						|
	absoluteShimPath := tempShimDir + "/containerd-shim-runc-v2"
 | 
						|
 | 
						|
	err = os.Chmod(absoluteShimPath, 0777)
 | 
						|
	if err != nil {
 | 
						|
		return "", err
 | 
						|
	}
 | 
						|
 | 
						|
	return absoluteShimPath, nil
 | 
						|
}
 | 
						|
 | 
						|
func TestResolveRuntimePath(t *testing.T) {
 | 
						|
	sm := &ShimManager{}
 | 
						|
	absoluteShimPath, err := setupAbsoluteShimPath(t)
 | 
						|
	if err != nil {
 | 
						|
		t.Errorf("Failed to create temporary shim path: %q", err)
 | 
						|
	}
 | 
						|
 | 
						|
	tests := []struct {
 | 
						|
		runtime string
 | 
						|
		want    string
 | 
						|
	}{
 | 
						|
		{ // Absolute path
 | 
						|
			runtime: absoluteShimPath,
 | 
						|
			want:    absoluteShimPath,
 | 
						|
		},
 | 
						|
		{ // Binary name
 | 
						|
			runtime: "io.containerd.runc.v2",
 | 
						|
			want:    absoluteShimPath,
 | 
						|
		},
 | 
						|
		{ // Invalid absolute path
 | 
						|
			runtime: "/fake/abs/path",
 | 
						|
			want:    "",
 | 
						|
		},
 | 
						|
		{ // No name
 | 
						|
			runtime: "",
 | 
						|
			want:    "",
 | 
						|
		},
 | 
						|
		{ // Relative Path
 | 
						|
			runtime: "./containerd-shim-runc-v2",
 | 
						|
			want:    "",
 | 
						|
		},
 | 
						|
		{
 | 
						|
			runtime: "fake/containerd-shim-runc-v2",
 | 
						|
			want:    "",
 | 
						|
		},
 | 
						|
		{
 | 
						|
			runtime: "./fake/containerd-shim-runc-v2",
 | 
						|
			want:    "",
 | 
						|
		},
 | 
						|
		{ // Relative Path or Bad Binary Name
 | 
						|
			runtime: ".io.containerd.runc.v2",
 | 
						|
			want:    "",
 | 
						|
		},
 | 
						|
	}
 | 
						|
 | 
						|
	for _, c := range tests {
 | 
						|
		have, _ := sm.resolveRuntimePath(c.runtime)
 | 
						|
		if have != c.want {
 | 
						|
			t.Errorf("Expected %q, got %q", c.want, have)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 |