2014-02-25 11:17:48 -05:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"os/exec"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
// ensure docker version works
|
|
|
|
func TestVersionEnsureSucceeds(t *testing.T) {
|
|
|
|
versionCmd := exec.Command(dockerBinary, "version")
|
|
|
|
out, exitCode, err := runCommandWithOutput(versionCmd)
|
|
|
|
errorOut(err, t, fmt.Sprintf("encountered error while running docker version: %v", err))
|
|
|
|
|
|
|
|
if err != nil || exitCode != 0 {
|
|
|
|
t.Fatal("failed to execute docker version")
|
|
|
|
}
|
|
|
|
|
2014-04-01 20:30:02 -04:00
|
|
|
stringsToCheck := []string{
|
|
|
|
"Client version:",
|
|
|
|
"Client API version:",
|
|
|
|
"Go version (client):",
|
|
|
|
"Git commit (client):",
|
|
|
|
"Server version:",
|
|
|
|
"Server API version:",
|
|
|
|
"Go version (server):",
|
2014-05-17 20:49:58 -04:00
|
|
|
"Git commit (server):",
|
2014-04-01 20:30:02 -04:00
|
|
|
}
|
2014-02-25 11:17:48 -05:00
|
|
|
|
|
|
|
for _, linePrefix := range stringsToCheck {
|
|
|
|
if !strings.Contains(out, linePrefix) {
|
|
|
|
t.Errorf("couldn't find string %v in output", linePrefix)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
logDone("version - verify that it works and that the output is properly formatted")
|
|
|
|
}
|