mirror of
https://github.com/moby/moby.git
synced 2025-12-09 10:01:25 +03:00
Add --log-level support
Next steps, in another PR, would be: - make all logging go through the logrus stuff - I'd like to see if we can remove the env var stuff (like DEBUG) but we'll see Closes #5198 Signed-off-by: Doug Davis <dug@us.ibm.com>
This commit is contained in:
@@ -41,7 +41,7 @@ func NewDaemon(t *testing.T) *Daemon {
|
||||
t.Fatal("Please set the DEST environment variable")
|
||||
}
|
||||
|
||||
dir := filepath.Join(dest, fmt.Sprintf("daemon%d", time.Now().Unix()))
|
||||
dir := filepath.Join(dest, fmt.Sprintf("daemon%d", time.Now().UnixNano()%100000000))
|
||||
daemonFolder, err := filepath.Abs(dir)
|
||||
if err != nil {
|
||||
t.Fatalf("Could not make %q an absolute path: %v", dir, err)
|
||||
@@ -69,10 +69,23 @@ func (d *Daemon) Start(arg ...string) error {
|
||||
|
||||
args := []string{
|
||||
"--host", d.sock(),
|
||||
"--daemon", "--debug",
|
||||
"--daemon",
|
||||
"--graph", fmt.Sprintf("%s/graph", d.folder),
|
||||
"--pidfile", fmt.Sprintf("%s/docker.pid", d.folder),
|
||||
}
|
||||
|
||||
// If we don't explicitly set the log-level or debug flag(-D) then
|
||||
// turn on debug mode
|
||||
foundIt := false
|
||||
for _, a := range arg {
|
||||
if strings.Contains(a, "--log-level") || strings.Contains(a, "-D") {
|
||||
foundIt = true
|
||||
}
|
||||
}
|
||||
if !foundIt {
|
||||
args = append(args, "--debug")
|
||||
}
|
||||
|
||||
if d.storageDriver != "" {
|
||||
args = append(args, "--storage-driver", d.storageDriver)
|
||||
}
|
||||
@@ -83,7 +96,7 @@ func (d *Daemon) Start(arg ...string) error {
|
||||
args = append(args, arg...)
|
||||
d.cmd = exec.Command(dockerBinary, args...)
|
||||
|
||||
d.logFile, err = os.OpenFile(filepath.Join(d.folder, "docker.log"), os.O_WRONLY|os.O_CREATE|os.O_APPEND, 0600)
|
||||
d.logFile, err = os.OpenFile(filepath.Join(d.folder, "docker.log"), os.O_RDWR|os.O_CREATE|os.O_APPEND, 0600)
|
||||
if err != nil {
|
||||
d.t.Fatalf("Could not create %s/docker.log: %v", d.folder, err)
|
||||
}
|
||||
@@ -107,8 +120,13 @@ func (d *Daemon) Start(arg ...string) error {
|
||||
|
||||
tick := time.Tick(500 * time.Millisecond)
|
||||
// make sure daemon is ready to receive requests
|
||||
startTime := time.Now().Unix()
|
||||
for {
|
||||
d.t.Log("waiting for daemon to start")
|
||||
if time.Now().Unix()-startTime > 5 {
|
||||
// After 5 seconds, give up
|
||||
return errors.New("Daemon exited and never started")
|
||||
}
|
||||
select {
|
||||
case <-time.After(2 * time.Second):
|
||||
return errors.New("timeout: daemon does not respond")
|
||||
|
||||
Reference in New Issue
Block a user