Merge pull request #361 from ofiliz/issue-360

invoke: Enable plugin file names with extensions
This commit is contained in:
Gabe Rosenhouse 2017-02-08 10:15:49 -08:00 committed by GitHub
commit 970de4b9e3
4 changed files with 73 additions and 14 deletions

View File

@ -30,18 +30,14 @@ func FindInPath(plugin string, paths []string) (string, error) {
return "", fmt.Errorf("no paths provided") return "", fmt.Errorf("no paths provided")
} }
var fullpath string
for _, path := range paths { for _, path := range paths {
full := filepath.Join(path, plugin) for _, fe := range ExecutableFileExtensions {
if fi, err := os.Stat(full); err == nil && fi.Mode().IsRegular() { fullpath := filepath.Join(path, plugin) + fe
fullpath = full if fi, err := os.Stat(fullpath); err == nil && fi.Mode().IsRegular() {
break
}
}
if fullpath == "" {
return "", fmt.Errorf("failed to find plugin %q in path %s", plugin, paths)
}
return fullpath, nil return fullpath, nil
}
}
}
return "", fmt.Errorf("failed to find plugin %q in path %s", plugin, paths)
} }

View File

@ -17,7 +17,9 @@ package invoke_test
import ( import (
"fmt" "fmt"
"io/ioutil" "io/ioutil"
"os"
"path/filepath" "path/filepath"
"strings"
"github.com/containernetworking/cni/pkg/invoke" "github.com/containernetworking/cni/pkg/invoke"
. "github.com/onsi/ginkgo" . "github.com/onsi/ginkgo"
@ -28,6 +30,8 @@ var _ = Describe("FindInPath", func() {
var ( var (
multiplePaths []string multiplePaths []string
pluginName string pluginName string
plugin2NameWithExt string
plugin2NameWithoutExt string
pluginDir string pluginDir string
anotherTempDir string anotherTempDir string
) )
@ -37,11 +41,24 @@ var _ = Describe("FindInPath", func() {
Expect(err).NotTo(HaveOccurred()) Expect(err).NotTo(HaveOccurred())
plugin, err := ioutil.TempFile(tempDir, "a-cni-plugin") plugin, err := ioutil.TempFile(tempDir, "a-cni-plugin")
Expect(err).NotTo(HaveOccurred())
plugin2Name := "a-plugin-with-extension" + invoke.ExecutableFileExtensions[0]
plugin2, err := os.Create(filepath.Join(tempDir, plugin2Name))
Expect(err).NotTo(HaveOccurred())
anotherTempDir, err = ioutil.TempDir("", "nothing-here") anotherTempDir, err = ioutil.TempDir("", "nothing-here")
Expect(err).NotTo(HaveOccurred())
multiplePaths = []string{anotherTempDir, tempDir} multiplePaths = []string{anotherTempDir, tempDir}
pluginDir, pluginName = filepath.Split(plugin.Name()) pluginDir, pluginName = filepath.Split(plugin.Name())
_, plugin2NameWithExt = filepath.Split(plugin2.Name())
plugin2NameWithoutExt = strings.Split(plugin2NameWithExt, ".")[0]
})
AfterEach(func() {
os.RemoveAll(pluginDir)
os.RemoveAll(anotherTempDir)
}) })
Context("when multiple paths are provided", func() { Context("when multiple paths are provided", func() {
@ -52,6 +69,14 @@ var _ = Describe("FindInPath", func() {
}) })
}) })
Context("when a plugin name without its file name extension is provided", func() {
It("returns the path to the plugin, including its extension", func() {
pluginPath, err := invoke.FindInPath(plugin2NameWithoutExt, multiplePaths)
Expect(err).NotTo(HaveOccurred())
Expect(pluginPath).To(Equal(filepath.Join(pluginDir, plugin2NameWithExt)))
})
})
Context("when an error occurs", func() { Context("when an error occurs", func() {
Context("when no paths are provided", func() { Context("when no paths are provided", func() {
It("returns an error noting no paths were provided", func() { It("returns an error noting no paths were provided", func() {

20
invoke/os_unix.go Normal file
View File

@ -0,0 +1,20 @@
// Copyright 2016 CNI 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.
// +build darwin dragonfly freebsd linux netbsd opensbd solaris
package invoke
// Valid file extensions for plugin executables.
var ExecutableFileExtensions = []string{""}

18
invoke/os_windows.go Normal file
View File

@ -0,0 +1,18 @@
// Copyright 2016 CNI 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 invoke
// Valid file extensions for plugin executables.
var ExecutableFileExtensions = []string{".exe", ""}