requirements_unix_test.go 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. //go:build !windows
  2. package main
  3. import (
  4. "os"
  5. "strings"
  6. "github.com/docker/docker/pkg/sysinfo"
  7. )
  8. var sysInfo *sysinfo.SysInfo
  9. func setupLocalInfo() {
  10. sysInfo = sysinfo.New()
  11. }
  12. func cpuCfsPeriod() bool {
  13. return testEnv.DaemonInfo.CPUCfsPeriod
  14. }
  15. func cpuCfsQuota() bool {
  16. return testEnv.DaemonInfo.CPUCfsQuota
  17. }
  18. func cpuShare() bool {
  19. return testEnv.DaemonInfo.CPUShares
  20. }
  21. func oomControl() bool {
  22. return testEnv.DaemonInfo.OomKillDisable
  23. }
  24. func pidsLimit() bool {
  25. return sysInfo.PidsLimit
  26. }
  27. func memoryLimitSupport() bool {
  28. return testEnv.DaemonInfo.MemoryLimit
  29. }
  30. func memoryReservationSupport() bool {
  31. return sysInfo.MemoryReservation
  32. }
  33. func swapMemorySupport() bool {
  34. return testEnv.DaemonInfo.SwapLimit
  35. }
  36. func memorySwappinessSupport() bool {
  37. return testEnv.IsLocalDaemon() && sysInfo.MemorySwappiness
  38. }
  39. func blkioWeight() bool {
  40. return testEnv.IsLocalDaemon() && sysInfo.BlkioWeight
  41. }
  42. func cgroupCpuset() bool {
  43. return testEnv.DaemonInfo.CPUSet
  44. }
  45. func seccompEnabled() bool {
  46. return sysInfo.Seccomp
  47. }
  48. func bridgeNfIptables() bool {
  49. return !sysInfo.BridgeNFCallIPTablesDisabled
  50. }
  51. func unprivilegedUsernsClone() bool {
  52. content, err := os.ReadFile("/proc/sys/kernel/unprivileged_userns_clone")
  53. return err != nil || !strings.Contains(string(content), "0")
  54. }