mirror of https://github.com/docker/docs.git
Merge pull request #1646 from mohitsoni/master
- Runtime: Fix uname -r kernel version parsing
This commit is contained in:
commit
d4c7340131
|
@ -515,9 +515,7 @@ func FindCgroupMountpoint(cgroupType string) (string, error) {
|
||||||
|
|
||||||
func GetKernelVersion() (*KernelVersionInfo, error) {
|
func GetKernelVersion() (*KernelVersionInfo, error) {
|
||||||
var (
|
var (
|
||||||
flavor string
|
err error
|
||||||
kernel, major, minor int
|
|
||||||
err error
|
|
||||||
)
|
)
|
||||||
|
|
||||||
uts, err := uname()
|
uts, err := uname()
|
||||||
|
@ -536,8 +534,18 @@ func GetKernelVersion() (*KernelVersionInfo, error) {
|
||||||
// Remove the \x00 from the release for Atoi to parse correctly
|
// Remove the \x00 from the release for Atoi to parse correctly
|
||||||
release = release[:bytes.IndexByte(release, 0)]
|
release = release[:bytes.IndexByte(release, 0)]
|
||||||
|
|
||||||
tmp := strings.SplitN(string(release), "-", 2)
|
return ParseRelease(string(release))
|
||||||
tmp2 := strings.SplitN(tmp[0], ".", 3)
|
}
|
||||||
|
|
||||||
|
func ParseRelease(release string) (*KernelVersionInfo, error) {
|
||||||
|
var (
|
||||||
|
flavor string
|
||||||
|
kernel, major, minor int
|
||||||
|
err error
|
||||||
|
)
|
||||||
|
|
||||||
|
tmp := strings.SplitN(release, "-", 2)
|
||||||
|
tmp2 := strings.Split(tmp[0], ".")
|
||||||
|
|
||||||
if len(tmp2) > 0 {
|
if len(tmp2) > 0 {
|
||||||
kernel, err = strconv.Atoi(tmp2[0])
|
kernel, err = strconv.Atoi(tmp2[0])
|
||||||
|
|
|
@ -337,3 +337,21 @@ search dotcloud.net`: true,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func assertParseRelease(t *testing.T, release string, b *KernelVersionInfo, result int) {
|
||||||
|
var (
|
||||||
|
a *KernelVersionInfo
|
||||||
|
)
|
||||||
|
a, _ = ParseRelease(release)
|
||||||
|
|
||||||
|
if r := CompareKernelVersion(a, b); r != result {
|
||||||
|
t.Fatalf("Unexpected kernel version comparison result. Found %d, expected %d", r, result)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestParseRelease(t *testing.T) {
|
||||||
|
assertParseRelease(t, "3.8.0", &KernelVersionInfo{Kernel: 3, Major: 8, Minor: 0}, 0)
|
||||||
|
assertParseRelease(t, "3.4.54.longterm-1", &KernelVersionInfo{Kernel: 3, Major: 4, Minor: 54}, 0)
|
||||||
|
assertParseRelease(t, "3.4.54.longterm-1", &KernelVersionInfo{Kernel: 3, Major: 4, Minor: 54, Flavor: "1"}, 0)
|
||||||
|
assertParseRelease(t, "3.8.0-19-generic", &KernelVersionInfo{Kernel: 3, Major: 8, Minor: 0, Flavor: "19-generic"}, 0)
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue