client_test.go 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. package client
  2. import (
  3. "bytes"
  4. "encoding/json"
  5. "fmt"
  6. "io"
  7. "os"
  8. "strings"
  9. "testing"
  10. _ "github.com/docker/libnetwork/netutils"
  11. )
  12. // nopCloser is used to provide a dummy CallFunc for Cmd()
  13. type nopCloser struct {
  14. io.Reader
  15. }
  16. func (nopCloser) Close() error { return nil }
  17. func TestMain(m *testing.M) {
  18. setupMockHTTPCallback()
  19. os.Exit(m.Run())
  20. }
  21. var callbackFunc func(method, path string, data interface{}, headers map[string][]string) (io.ReadCloser, int, error)
  22. var mockNwJSON, mockNwListJSON, mockServiceJSON, mockServiceListJSON []byte
  23. var mockNwName = "test"
  24. var mockNwID = "2a3456789"
  25. var mockServiceName = "testSrv"
  26. var mockServiceID = "2a3456789"
  27. var mockContainerID = "2a3456789"
  28. func setupMockHTTPCallback() {
  29. var list []networkResource
  30. nw := networkResource{Name: mockNwName, ID: mockNwID}
  31. mockNwJSON, _ = json.Marshal(nw)
  32. list = append(list, nw)
  33. mockNwListJSON, _ = json.Marshal(list)
  34. var srvList []endpointResource
  35. ep := endpointResource{Name: mockServiceName, ID: mockServiceID, Network: mockNwName}
  36. mockServiceJSON, _ = json.Marshal(ep)
  37. srvList = append(srvList, ep)
  38. mockServiceListJSON, _ = json.Marshal(srvList)
  39. callbackFunc = func(method, path string, data interface{}, headers map[string][]string) (io.ReadCloser, int, error) {
  40. var rsp string
  41. switch method {
  42. case "GET":
  43. if strings.Contains(path, fmt.Sprintf("networks?name=%s", mockNwName)) {
  44. rsp = string(mockNwListJSON)
  45. } else if strings.Contains(path, "networks?name=") {
  46. rsp = "[]"
  47. } else if strings.Contains(path, fmt.Sprintf("networks?partial-id=%s", mockNwID)) {
  48. rsp = string(mockNwListJSON)
  49. } else if strings.Contains(path, "networks?partial-id=") {
  50. rsp = "[]"
  51. } else if strings.HasSuffix(path, "networks") {
  52. rsp = string(mockNwListJSON)
  53. } else if strings.HasSuffix(path, "networks/"+mockNwID) {
  54. rsp = string(mockNwJSON)
  55. } else if strings.Contains(path, fmt.Sprintf("endpoints?name=%s", mockServiceName)) {
  56. rsp = string(mockServiceListJSON)
  57. } else if strings.Contains(path, "endpoints?name=") {
  58. rsp = "[]"
  59. } else if strings.Contains(path, fmt.Sprintf("endpoints?partial-id=%s", mockServiceID)) {
  60. rsp = string(mockServiceListJSON)
  61. } else if strings.Contains(path, "endpoints?partial-id=") {
  62. rsp = "[]"
  63. } else if strings.HasSuffix(path, "endpoints") {
  64. rsp = string(mockServiceListJSON)
  65. } else if strings.HasSuffix(path, "endpoints/"+mockServiceID) {
  66. rsp = string(mockServiceJSON)
  67. }
  68. case "POST":
  69. var data []byte
  70. if strings.HasSuffix(path, "networks") {
  71. data, _ = json.Marshal(mockNwID)
  72. } else if strings.HasSuffix(path, "endpoints") {
  73. data, _ = json.Marshal(mockServiceID)
  74. } else if strings.HasSuffix(path, "containers") {
  75. data, _ = json.Marshal(mockContainerID)
  76. }
  77. rsp = string(data)
  78. case "PUT":
  79. case "DELETE":
  80. rsp = ""
  81. }
  82. return nopCloser{bytes.NewBufferString(rsp)}, 200, nil
  83. }
  84. }
  85. func TestClientDummyCommand(t *testing.T) {
  86. var out, errOut bytes.Buffer
  87. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  88. err := cli.Cmd("docker", "dummy")
  89. if err == nil {
  90. t.Fatalf("Incorrect Command must fail")
  91. }
  92. }
  93. func TestClientNetworkInvalidCommand(t *testing.T) {
  94. var out, errOut bytes.Buffer
  95. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  96. err := cli.Cmd("docker", "network", "invalid")
  97. if err == nil {
  98. t.Fatalf("Passing invalid commands must fail")
  99. }
  100. }
  101. func TestClientNetworkCreate(t *testing.T) {
  102. var out, errOut bytes.Buffer
  103. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  104. err := cli.Cmd("docker", "network", "create", mockNwName)
  105. if err != nil {
  106. t.Fatal(err.Error())
  107. }
  108. }
  109. func TestClientNetworkCreateWithDriver(t *testing.T) {
  110. var out, errOut bytes.Buffer
  111. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  112. err := cli.Cmd("docker", "network", "create", "-f=dummy", mockNwName)
  113. if err == nil {
  114. t.Fatalf("Passing incorrect flags to the create command must fail")
  115. }
  116. err = cli.Cmd("docker", "network", "create", "-d=dummy", mockNwName)
  117. if err != nil {
  118. t.Fatalf(err.Error())
  119. }
  120. }
  121. func TestClientNetworkRm(t *testing.T) {
  122. var out, errOut bytes.Buffer
  123. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  124. err := cli.Cmd("docker", "network", "rm", mockNwName)
  125. if err != nil {
  126. t.Fatal(err.Error())
  127. }
  128. }
  129. func TestClientNetworkLs(t *testing.T) {
  130. var out, errOut bytes.Buffer
  131. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  132. err := cli.Cmd("docker", "network", "ls")
  133. if err != nil {
  134. t.Fatal(err.Error())
  135. }
  136. }
  137. func TestClientNetworkInfo(t *testing.T) {
  138. var out, errOut bytes.Buffer
  139. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  140. err := cli.Cmd("docker", "network", "info", mockNwName)
  141. if err != nil {
  142. t.Fatal(err.Error())
  143. }
  144. }
  145. func TestClientNetworkInfoById(t *testing.T) {
  146. var out, errOut bytes.Buffer
  147. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  148. err := cli.Cmd("docker", "network", "info", mockNwID)
  149. if err != nil {
  150. t.Fatal(err.Error())
  151. }
  152. }
  153. // Docker Flag processing in flag.go uses os.Exit() frequently, even for --help
  154. // TODO : Handle the --help test-case in the IT when CLI is available
  155. /*
  156. func TestClientNetworkServiceCreateHelp(t *testing.T) {
  157. var out, errOut bytes.Buffer
  158. cFunc := func(method, path string, data interface{}, headers map[string][]string) (io.ReadCloser, int, error) {
  159. return nil, 0, nil
  160. }
  161. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  162. err := cli.Cmd("docker", "network", "create", "--help")
  163. if err != nil {
  164. t.Fatalf(err.Error())
  165. }
  166. }
  167. */
  168. // Docker flag processing in flag.go uses os.Exit(1) for incorrect parameter case.
  169. // TODO : Handle the missing argument case in the IT when CLI is available
  170. /*
  171. func TestClientNetworkServiceCreateMissingArgument(t *testing.T) {
  172. var out, errOut bytes.Buffer
  173. cFunc := func(method, path string, data interface{}, headers map[string][]string) (io.ReadCloser, int, error) {
  174. return nil, 0, nil
  175. }
  176. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  177. err := cli.Cmd("docker", "network", "create")
  178. if err != nil {
  179. t.Fatal(err.Error())
  180. }
  181. }
  182. */