info_test.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  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. }
  37. out := fmt.Sprintf("%+v", info)
  38. for _, linePrefix := range stringsToCheck {
  39. assert.Check(t, is.Contains(out, linePrefix))
  40. }
  41. }
  42. func TestInfoAPIWarnings(t *testing.T) {
  43. skip.If(t, testEnv.IsRemoteDaemon, "cannot run daemon when remote daemon")
  44. skip.If(t, testEnv.DaemonInfo.OSType == "windows", "FIXME")
  45. d := daemon.New(t)
  46. c := d.NewClientT(t)
  47. d.Start(t, "-H=0.0.0.0:23756", "-H="+d.Sock())
  48. defer d.Stop(t)
  49. info, err := c.Info(context.Background())
  50. assert.NilError(t, err)
  51. stringsToCheck := []string{
  52. "Access to the remote API is equivalent to root access",
  53. "http://0.0.0.0:23756",
  54. }
  55. out := fmt.Sprintf("%+v", info)
  56. for _, linePrefix := range stringsToCheck {
  57. assert.Check(t, is.Contains(out, linePrefix))
  58. }
  59. }
  60. func TestInfoDebug(t *testing.T) {
  61. skip.If(t, testEnv.IsRemoteDaemon, "cannot run daemon when remote daemon")
  62. skip.If(t, testEnv.DaemonInfo.OSType == "windows", "FIXME: test starts daemon with -H unix://.....")
  63. d := daemon.New(t)
  64. d.Start(t, "--debug")
  65. defer d.Stop(t)
  66. info := d.Info(t)
  67. assert.Equal(t, info.Debug, true)
  68. // Note that the information below is not tied to debug-mode being enabled.
  69. assert.Check(t, info.NFd != 0)
  70. // TODO need a stable way to generate event listeners
  71. // assert.Check(t, info.NEventsListener != 0)
  72. assert.Check(t, info.NGoroutines != 0)
  73. assert.Check(t, info.SystemTime != "")
  74. assert.Equal(t, info.DockerRootDir, d.Root)
  75. }
  76. func TestInfoInsecureRegistries(t *testing.T) {
  77. skip.If(t, testEnv.IsRemoteDaemon, "cannot run daemon when remote daemon")
  78. skip.If(t, testEnv.DaemonInfo.OSType == "windows", "FIXME: test starts daemon with -H unix://.....")
  79. const (
  80. registryCIDR = "192.168.1.0/24"
  81. registryHost = "insecurehost.com:5000"
  82. )
  83. d := daemon.New(t)
  84. d.Start(t, "--insecure-registry="+registryCIDR, "--insecure-registry="+registryHost)
  85. defer d.Stop(t)
  86. info := d.Info(t)
  87. assert.Assert(t, is.Len(info.RegistryConfig.InsecureRegistryCIDRs, 2))
  88. cidrs := []string{
  89. info.RegistryConfig.InsecureRegistryCIDRs[0].String(),
  90. info.RegistryConfig.InsecureRegistryCIDRs[1].String(),
  91. }
  92. assert.Assert(t, is.Contains(cidrs, registryCIDR))
  93. assert.Assert(t, is.Contains(cidrs, "127.0.0.0/8"))
  94. assert.DeepEqual(t, *info.RegistryConfig.IndexConfigs["docker.io"], registry.IndexInfo{Name: "docker.io", Mirrors: []string{}, Secure: true, Official: true})
  95. assert.DeepEqual(t, *info.RegistryConfig.IndexConfigs[registryHost], registry.IndexInfo{Name: registryHost, Mirrors: []string{}, Secure: false, Official: false})
  96. }
  97. func TestInfoRegistryMirrors(t *testing.T) {
  98. skip.If(t, testEnv.IsRemoteDaemon, "cannot run daemon when remote daemon")
  99. skip.If(t, testEnv.DaemonInfo.OSType == "windows", "FIXME: test starts daemon with -H unix://.....")
  100. const (
  101. registryMirror1 = "https://192.168.1.2"
  102. registryMirror2 = "http://registry-mirror.example.com:5000"
  103. )
  104. d := daemon.New(t)
  105. d.Start(t, "--registry-mirror="+registryMirror1, "--registry-mirror="+registryMirror2)
  106. defer d.Stop(t)
  107. info := d.Info(t)
  108. sort.Strings(info.RegistryConfig.Mirrors)
  109. assert.DeepEqual(t, info.RegistryConfig.Mirrors, []string{registryMirror2 + "/", registryMirror1 + "/"})
  110. }