info_test.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. package system // import "github.com/docker/docker/integration/system"
  2. import (
  3. "context"
  4. "fmt"
  5. "sort"
  6. "testing"
  7. "github.com/docker/docker/api/types/registry"
  8. "github.com/docker/docker/testutil/daemon"
  9. "gotest.tools/v3/assert"
  10. is "gotest.tools/v3/assert/cmp"
  11. "gotest.tools/v3/skip"
  12. )
  13. func TestInfoAPI(t *testing.T) {
  14. defer setupTest(t)()
  15. client := testEnv.APIClient()
  16. info, err := client.Info(context.Background())
  17. assert.NilError(t, err)
  18. // always shown fields
  19. stringsToCheck := []string{
  20. "ID",
  21. "Containers",
  22. "ContainersRunning",
  23. "ContainersPaused",
  24. "ContainersStopped",
  25. "Images",
  26. "LoggingDriver",
  27. "OperatingSystem",
  28. "NCPU",
  29. "OSType",
  30. "Architecture",
  31. "MemTotal",
  32. "KernelVersion",
  33. "Driver",
  34. "ServerVersion",
  35. "SecurityOptions"}
  36. out := fmt.Sprintf("%+v", info)
  37. for _, linePrefix := range stringsToCheck {
  38. assert.Check(t, is.Contains(out, linePrefix))
  39. }
  40. }
  41. func TestInfoAPIWarnings(t *testing.T) {
  42. skip.If(t, testEnv.IsRemoteDaemon, "cannot run daemon when remote daemon")
  43. skip.If(t, testEnv.DaemonInfo.OSType == "windows", "FIXME")
  44. d := daemon.New(t)
  45. c := d.NewClientT(t)
  46. d.Start(t, "-H=0.0.0.0:23756", "-H="+d.Sock())
  47. defer d.Stop(t)
  48. info, err := c.Info(context.Background())
  49. assert.NilError(t, err)
  50. stringsToCheck := []string{
  51. "Access to the remote API is equivalent to root access",
  52. "http://0.0.0.0:23756",
  53. }
  54. out := fmt.Sprintf("%+v", info)
  55. for _, linePrefix := range stringsToCheck {
  56. assert.Check(t, is.Contains(out, linePrefix))
  57. }
  58. }
  59. func TestInfoDebug(t *testing.T) {
  60. skip.If(t, testEnv.IsRemoteDaemon, "cannot run daemon when remote daemon")
  61. skip.If(t, testEnv.DaemonInfo.OSType == "windows", "FIXME: test starts daemon with -H unix://.....")
  62. d := daemon.New(t)
  63. d.Start(t, "--debug")
  64. defer d.Stop(t)
  65. info := d.Info(t)
  66. assert.Equal(t, info.Debug, true)
  67. // Note that the information below is not tied to debug-mode being enabled.
  68. assert.Check(t, info.NFd != 0)
  69. // TODO need a stable way to generate event listeners
  70. // assert.Check(t, info.NEventsListener != 0)
  71. assert.Check(t, info.NGoroutines != 0)
  72. assert.Check(t, info.SystemTime != "")
  73. assert.Equal(t, info.DockerRootDir, d.Root)
  74. }
  75. func TestInfoInsecureRegistries(t *testing.T) {
  76. skip.If(t, testEnv.IsRemoteDaemon, "cannot run daemon when remote daemon")
  77. skip.If(t, testEnv.DaemonInfo.OSType == "windows", "FIXME: test starts daemon with -H unix://.....")
  78. const (
  79. registryCIDR = "192.168.1.0/24"
  80. registryHost = "insecurehost.com:5000"
  81. )
  82. d := daemon.New(t)
  83. d.Start(t, "--insecure-registry="+registryCIDR, "--insecure-registry="+registryHost)
  84. defer d.Stop(t)
  85. info := d.Info(t)
  86. assert.Assert(t, is.Len(info.RegistryConfig.InsecureRegistryCIDRs, 2))
  87. cidrs := []string{
  88. info.RegistryConfig.InsecureRegistryCIDRs[0].String(),
  89. info.RegistryConfig.InsecureRegistryCIDRs[1].String(),
  90. }
  91. assert.Assert(t, is.Contains(cidrs, registryCIDR))
  92. assert.Assert(t, is.Contains(cidrs, "127.0.0.0/8"))
  93. assert.DeepEqual(t, *info.RegistryConfig.IndexConfigs["docker.io"], registry.IndexInfo{Name: "docker.io", Mirrors: []string{}, Secure: true, Official: true})
  94. assert.DeepEqual(t, *info.RegistryConfig.IndexConfigs[registryHost], registry.IndexInfo{Name: registryHost, Mirrors: []string{}, Secure: false, Official: false})
  95. }
  96. func TestInfoRegistryMirrors(t *testing.T) {
  97. skip.If(t, testEnv.IsRemoteDaemon, "cannot run daemon when remote daemon")
  98. skip.If(t, testEnv.DaemonInfo.OSType == "windows", "FIXME: test starts daemon with -H unix://.....")
  99. const (
  100. registryMirror1 = "https://192.168.1.2"
  101. registryMirror2 = "http://registry-mirror.example.com:5000"
  102. )
  103. d := daemon.New(t)
  104. d.Start(t, "--registry-mirror="+registryMirror1, "--registry-mirror="+registryMirror2)
  105. defer d.Stop(t)
  106. info := d.Info(t)
  107. sort.Strings(info.RegistryConfig.Mirrors)
  108. assert.DeepEqual(t, info.RegistryConfig.Mirrors, []string{registryMirror2 + "/", registryMirror1 + "/"})
  109. }