client_test.go 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  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 []serviceResource
  35. ep := serviceResource{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("services?name=%s", mockServiceName)) {
  56. rsp = string(mockServiceListJSON)
  57. } else if strings.Contains(path, "services?name=") {
  58. rsp = "[]"
  59. } else if strings.Contains(path, fmt.Sprintf("services?partial-id=%s", mockServiceID)) {
  60. rsp = string(mockServiceListJSON)
  61. } else if strings.Contains(path, "services?partial-id=") {
  62. rsp = "[]"
  63. } else if strings.HasSuffix(path, "services") {
  64. rsp = string(mockServiceListJSON)
  65. } else if strings.HasSuffix(path, "services/"+mockServiceID) {
  66. rsp = string(mockServiceJSON)
  67. } else if strings.Contains(path, "containers") {
  68. return nopCloser{bytes.NewBufferString("")}, 400, fmt.Errorf("Bad Request")
  69. }
  70. case "POST":
  71. var data []byte
  72. if strings.HasSuffix(path, "networks") {
  73. data, _ = json.Marshal(mockNwID)
  74. } else if strings.HasSuffix(path, "services") {
  75. data, _ = json.Marshal(mockServiceID)
  76. } else if strings.HasSuffix(path, "backend") {
  77. data, _ = json.Marshal(mockContainerID)
  78. }
  79. rsp = string(data)
  80. case "PUT":
  81. case "DELETE":
  82. rsp = ""
  83. }
  84. return nopCloser{bytes.NewBufferString(rsp)}, 200, nil
  85. }
  86. }
  87. func TestClientDummyCommand(t *testing.T) {
  88. var out, errOut bytes.Buffer
  89. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  90. err := cli.Cmd("docker", "dummy")
  91. if err == nil {
  92. t.Fatalf("Incorrect Command must fail")
  93. }
  94. }
  95. func TestClientNetworkInvalidCommand(t *testing.T) {
  96. var out, errOut bytes.Buffer
  97. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  98. err := cli.Cmd("docker", "network", "invalid")
  99. if err == nil {
  100. t.Fatalf("Passing invalid commands must fail")
  101. }
  102. }
  103. func TestClientNetworkCreate(t *testing.T) {
  104. var out, errOut bytes.Buffer
  105. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  106. err := cli.Cmd("docker", "network", "create", mockNwName)
  107. if err != nil {
  108. t.Fatal(err.Error())
  109. }
  110. }
  111. func TestClientNetworkCreateWithDriver(t *testing.T) {
  112. var out, errOut bytes.Buffer
  113. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  114. err := cli.Cmd("docker", "network", "create", "-f=dummy", mockNwName)
  115. if err == nil {
  116. t.Fatalf("Passing incorrect flags to the create command must fail")
  117. }
  118. err = cli.Cmd("docker", "network", "create", "-d=dummy", mockNwName)
  119. if err != nil {
  120. t.Fatalf(err.Error())
  121. }
  122. }
  123. func TestClientNetworkRm(t *testing.T) {
  124. var out, errOut bytes.Buffer
  125. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  126. err := cli.Cmd("docker", "network", "rm", mockNwName)
  127. if err != nil {
  128. t.Fatal(err.Error())
  129. }
  130. }
  131. func TestClientNetworkLs(t *testing.T) {
  132. var out, errOut bytes.Buffer
  133. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  134. err := cli.Cmd("docker", "network", "ls")
  135. if err != nil {
  136. t.Fatal(err.Error())
  137. }
  138. }
  139. func TestClientNetworkInfo(t *testing.T) {
  140. var out, errOut bytes.Buffer
  141. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  142. err := cli.Cmd("docker", "network", "info", mockNwName)
  143. if err != nil {
  144. t.Fatal(err.Error())
  145. }
  146. }
  147. func TestClientNetworkInfoById(t *testing.T) {
  148. var out, errOut bytes.Buffer
  149. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  150. err := cli.Cmd("docker", "network", "info", mockNwID)
  151. if err != nil {
  152. t.Fatal(err.Error())
  153. }
  154. }
  155. // Docker Flag processing in flag.go uses os.Exit() frequently, even for --help
  156. // TODO : Handle the --help test-case in the IT when CLI is available
  157. /*
  158. func TestClientNetworkServiceCreateHelp(t *testing.T) {
  159. var out, errOut bytes.Buffer
  160. cFunc := func(method, path string, data interface{}, headers map[string][]string) (io.ReadCloser, int, error) {
  161. return nil, 0, nil
  162. }
  163. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  164. err := cli.Cmd("docker", "network", "create", "--help")
  165. if err != nil {
  166. t.Fatalf(err.Error())
  167. }
  168. }
  169. */
  170. // Docker flag processing in flag.go uses os.Exit(1) for incorrect parameter case.
  171. // TODO : Handle the missing argument case in the IT when CLI is available
  172. /*
  173. func TestClientNetworkServiceCreateMissingArgument(t *testing.T) {
  174. var out, errOut bytes.Buffer
  175. cFunc := func(method, path string, data interface{}, headers map[string][]string) (io.ReadCloser, int, error) {
  176. return nil, 0, nil
  177. }
  178. cli := NewNetworkCli(&out, &errOut, callbackFunc)
  179. err := cli.Cmd("docker", "network", "create")
  180. if err != nil {
  181. t.Fatal(err.Error())
  182. }
  183. }
  184. */