aboutsummaryrefslogtreecommitdiff
path: root/vendor/github.com/Microsoft/hcsshim/internal/timeout/timeout.go
blob: eaf39fa513274829b2ca8ea3a8d40d19bda45b6c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
package timeout

import (
	"os"
	"strconv"
	"time"
)

var (
	// defaultTimeout is the timeout for most operations that is not overridden.
	defaultTimeout = 4 * time.Minute

	// defaultTimeoutTestdRetry is the retry loop timeout for testd to respond
	// for a disk to come online in LCOW.
	defaultTimeoutTestdRetry = 5 * time.Second
)

// External variables for HCSShim consumers to use.
var (
	// SystemCreate is the timeout for creating a compute system
	SystemCreate time.Duration = defaultTimeout

	// SystemStart is the timeout for starting a compute system
	SystemStart time.Duration = defaultTimeout

	// SystemPause is the timeout for pausing a compute system
	SystemPause time.Duration = defaultTimeout

	// SystemResume is the timeout for resuming a compute system
	SystemResume time.Duration = defaultTimeout

	// SystemSave is the timeout for saving a compute system
	SystemSave time.Duration = defaultTimeout

	// SyscallWatcher is the timeout before warning of a potential stuck platform syscall.
	SyscallWatcher time.Duration = defaultTimeout

	// Tar2VHD is the timeout for the tar2vhd operation to complete
	Tar2VHD time.Duration = defaultTimeout

	// ExternalCommandToStart is the timeout for external commands to start
	ExternalCommandToStart = defaultTimeout

	// ExternalCommandToComplete is the timeout for external commands to complete.
	// Generally this means copying data from their stdio pipes.
	ExternalCommandToComplete = defaultTimeout

	// TestDRetryLoop is the timeout for testd retry loop when onlining a SCSI disk in LCOW
	TestDRetryLoop = defaultTimeoutTestdRetry
)

func init() {
	SystemCreate = durationFromEnvironment("HCSSHIM_TIMEOUT_SYSTEMCREATE", SystemCreate)
	SystemStart = durationFromEnvironment("HCSSHIM_TIMEOUT_SYSTEMSTART", SystemStart)
	SystemPause = durationFromEnvironment("HCSSHIM_TIMEOUT_SYSTEMPAUSE", SystemPause)
	SystemResume = durationFromEnvironment("HCSSHIM_TIMEOUT_SYSTEMRESUME", SystemResume)
	SystemSave = durationFromEnvironment("HCSSHIM_TIMEOUT_SYSTEMSAVE", SystemSave)
	SyscallWatcher = durationFromEnvironment("HCSSHIM_TIMEOUT_SYSCALLWATCHER", SyscallWatcher)
	Tar2VHD = durationFromEnvironment("HCSSHIM_TIMEOUT_TAR2VHD", Tar2VHD)
	ExternalCommandToStart = durationFromEnvironment("HCSSHIM_TIMEOUT_EXTERNALCOMMANDSTART", ExternalCommandToStart)
	ExternalCommandToComplete = durationFromEnvironment("HCSSHIM_TIMEOUT_EXTERNALCOMMANDCOMPLETE", ExternalCommandToComplete)
	TestDRetryLoop = durationFromEnvironment("HCSSHIM_TIMEOUT_TESTDRETRYLOOP", TestDRetryLoop)
}

func durationFromEnvironment(env string, defaultValue time.Duration) time.Duration {
	envTimeout := os.Getenv(env)
	if len(envTimeout) > 0 {
		e, err := strconv.Atoi(envTimeout)
		if err == nil && e > 0 {
			return time.Second * time.Duration(e)
		}
	}
	return defaultValue
}