api_test.go 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569
  1. package api
  2. import (
  3. "bytes"
  4. "encoding/json"
  5. "errors"
  6. "fmt"
  7. "io"
  8. "net/http"
  9. "os"
  10. "runtime"
  11. "testing"
  12. "github.com/docker/docker/pkg/reexec"
  13. "github.com/docker/libnetwork"
  14. "github.com/docker/libnetwork/netlabel"
  15. "github.com/docker/libnetwork/netutils"
  16. "github.com/docker/libnetwork/options"
  17. "github.com/docker/libnetwork/types"
  18. )
  19. const (
  20. bridgeNetType = "bridge"
  21. bridgeName = "docker0"
  22. )
  23. func getEmptyGenericOption() map[string]interface{} {
  24. genericOption := make(map[string]interface{})
  25. genericOption[netlabel.GenericData] = options.Generic{}
  26. return genericOption
  27. }
  28. func i2s(i interface{}) string {
  29. s, ok := i.(string)
  30. if !ok {
  31. panic(fmt.Sprintf("Failed i2s for %v", i))
  32. }
  33. return s
  34. }
  35. func i2e(i interface{}) *endpointResource {
  36. s, ok := i.(*endpointResource)
  37. if !ok {
  38. panic(fmt.Sprintf("Failed i2e for %v", i))
  39. }
  40. return s
  41. }
  42. func i2eL(i interface{}) []*endpointResource {
  43. s, ok := i.([]*endpointResource)
  44. if !ok {
  45. panic(fmt.Sprintf("Failed i2eL for %v", i))
  46. }
  47. return s
  48. }
  49. func i2n(i interface{}) *networkResource {
  50. s, ok := i.(*networkResource)
  51. if !ok {
  52. panic(fmt.Sprintf("Failed i2n for %v", i))
  53. }
  54. return s
  55. }
  56. func i2nL(i interface{}) []*networkResource {
  57. s, ok := i.([]*networkResource)
  58. if !ok {
  59. panic(fmt.Sprintf("Failed i2nL for %v", i))
  60. }
  61. return s
  62. }
  63. func createTestNetwork(t *testing.T, network string) (libnetwork.NetworkController, libnetwork.Network) {
  64. c, err := libnetwork.New("")
  65. if err != nil {
  66. t.Fatal(err)
  67. }
  68. err = c.ConfigureNetworkDriver(bridgeNetType, nil)
  69. if err != nil {
  70. t.Fatal(err)
  71. }
  72. nw, err := c.NewNetwork(bridgeNetType, network, nil)
  73. if err != nil {
  74. t.Fatal(err)
  75. }
  76. return c, nw
  77. }
  78. func TestMain(m *testing.M) {
  79. if reexec.Init() {
  80. return
  81. }
  82. os.Exit(m.Run())
  83. }
  84. func TestJoinOptionParser(t *testing.T) {
  85. hn := "host1"
  86. dn := "docker.com"
  87. hp := "/etc/hosts"
  88. rc := "/etc/resolv.conf"
  89. dnss := []string{"8.8.8.8", "172.28.34.5"}
  90. ehs := []endpointExtraHost{endpointExtraHost{Name: "extra1", Address: "172.28.9.1"}, endpointExtraHost{Name: "extra2", Address: "172.28.9.2"}}
  91. pus := []endpointParentUpdate{endpointParentUpdate{EndpointID: "abc123def456", Name: "serv1", Address: "172.28.30.123"}}
  92. ej := endpointJoin{
  93. HostName: hn,
  94. DomainName: dn,
  95. HostsPath: hp,
  96. ResolvConfPath: rc,
  97. DNS: dnss,
  98. ExtraHosts: ehs,
  99. ParentUpdates: pus,
  100. UseDefaultSandbox: true,
  101. }
  102. if len(ej.parseOptions()) != 10 {
  103. t.Fatalf("Failed to generate all libnetwork.EndpointJoinOption methods libnetwork.EndpointJoinOption method")
  104. }
  105. }
  106. func TestJson(t *testing.T) {
  107. nc := networkCreate{NetworkType: bridgeNetType}
  108. b, err := json.Marshal(nc)
  109. if err != nil {
  110. t.Fatal(err)
  111. }
  112. var ncp networkCreate
  113. err = json.Unmarshal(b, &ncp)
  114. if err != nil {
  115. t.Fatal(err)
  116. }
  117. if nc.NetworkType != ncp.NetworkType {
  118. t.Fatalf("Incorrect networkCreate after json encoding/deconding: %v", ncp)
  119. }
  120. jl := endpointJoin{ContainerID: "abcdef456789"}
  121. b, err = json.Marshal(jl)
  122. if err != nil {
  123. t.Fatal(err)
  124. }
  125. var jld endpointJoin
  126. err = json.Unmarshal(b, &jld)
  127. if err != nil {
  128. t.Fatal(err)
  129. }
  130. if jl.ContainerID != jld.ContainerID {
  131. t.Fatalf("Incorrect endpointJoin after json encoding/deconding: %v", jld)
  132. }
  133. }
  134. func TestCreateDeleteNetwork(t *testing.T) {
  135. defer netutils.SetupTestNetNS(t)()
  136. c, err := libnetwork.New("")
  137. if err != nil {
  138. t.Fatal(err)
  139. }
  140. err = c.ConfigureNetworkDriver(bridgeNetType, nil)
  141. if err != nil {
  142. t.Fatal(err)
  143. }
  144. badBody, err := json.Marshal("bad body")
  145. if err != nil {
  146. t.Fatal(err)
  147. }
  148. vars := make(map[string]string)
  149. _, errRsp := procCreateNetwork(c, nil, badBody)
  150. if errRsp == &createdResponse {
  151. t.Fatalf("Expected to fail but succeeded")
  152. }
  153. if errRsp.StatusCode != http.StatusBadRequest {
  154. t.Fatalf("Expected StatusBadRequest status code, got: %v", errRsp)
  155. }
  156. incompleteBody, err := json.Marshal(networkCreate{})
  157. if err != nil {
  158. t.Fatal(err)
  159. }
  160. _, errRsp = procCreateNetwork(c, vars, incompleteBody)
  161. if errRsp == &createdResponse {
  162. t.Fatalf("Expected to fail but succeeded")
  163. }
  164. if errRsp.StatusCode != http.StatusBadRequest {
  165. t.Fatalf("Expected StatusBadRequest status code, got: %v", errRsp)
  166. }
  167. ops := options.Generic{
  168. netlabel.EnableIPv6: true,
  169. netlabel.GenericData: map[string]string{
  170. "BridgeName": "abc",
  171. "AllowNonDefaultBridge": "true",
  172. "FixedCIDRv6": "fe80::1/64",
  173. "AddressIP": "172.28.30.254/24",
  174. },
  175. }
  176. nc := networkCreate{Name: "network_1", NetworkType: bridgeNetType, Options: ops}
  177. goodBody, err := json.Marshal(nc)
  178. if err != nil {
  179. t.Fatal(err)
  180. }
  181. _, errRsp = procCreateNetwork(c, vars, goodBody)
  182. if errRsp != &createdResponse {
  183. t.Fatalf("Unexepected failure: %v", errRsp)
  184. }
  185. vars[urlNwName] = ""
  186. _, errRsp = procDeleteNetwork(c, vars, nil)
  187. if errRsp == &successResponse {
  188. t.Fatalf("Expected to fail but succeeded")
  189. }
  190. vars[urlNwName] = "abc"
  191. _, errRsp = procDeleteNetwork(c, vars, nil)
  192. if errRsp == &successResponse {
  193. t.Fatalf("Expected to fail but succeeded")
  194. }
  195. vars[urlNwName] = "network_1"
  196. _, errRsp = procDeleteNetwork(c, vars, nil)
  197. if errRsp != &successResponse {
  198. t.Fatalf("Unexepected failure: %v", errRsp)
  199. }
  200. }
  201. func TestGetNetworksAndEndpoints(t *testing.T) {
  202. defer netutils.SetupTestNetNS(t)()
  203. c, err := libnetwork.New("")
  204. if err != nil {
  205. t.Fatal(err)
  206. }
  207. err = c.ConfigureNetworkDriver(bridgeNetType, nil)
  208. if err != nil {
  209. t.Fatal(err)
  210. }
  211. ops := options.Generic{
  212. netlabel.GenericData: map[string]string{
  213. "BridgeName": "api_test_nw",
  214. "AllowNonDefaultBridge": "true",
  215. },
  216. }
  217. nc := networkCreate{Name: "sh", NetworkType: bridgeNetType, Options: ops}
  218. body, err := json.Marshal(nc)
  219. if err != nil {
  220. t.Fatal(err)
  221. }
  222. vars := make(map[string]string)
  223. inid, errRsp := procCreateNetwork(c, vars, body)
  224. if errRsp != &createdResponse {
  225. t.Fatalf("Unexepected failure: %v", errRsp)
  226. }
  227. nid, ok := inid.(string)
  228. if !ok {
  229. t.FailNow()
  230. }
  231. ec1 := endpointCreate{
  232. Name: "ep1",
  233. ExposedPorts: []types.TransportPort{
  234. types.TransportPort{Proto: types.TCP, Port: uint16(5000)},
  235. types.TransportPort{Proto: types.UDP, Port: uint16(400)},
  236. types.TransportPort{Proto: types.TCP, Port: uint16(600)},
  237. },
  238. PortMapping: []types.PortBinding{
  239. types.PortBinding{Proto: types.TCP, Port: uint16(230), HostPort: uint16(23000)},
  240. types.PortBinding{Proto: types.UDP, Port: uint16(200), HostPort: uint16(22000)},
  241. types.PortBinding{Proto: types.TCP, Port: uint16(120), HostPort: uint16(12000)},
  242. },
  243. }
  244. b1, err := json.Marshal(ec1)
  245. if err != nil {
  246. t.Fatal(err)
  247. }
  248. ec2 := endpointCreate{Name: "ep2"}
  249. b2, err := json.Marshal(ec2)
  250. if err != nil {
  251. t.Fatal(err)
  252. }
  253. vars[urlNwName] = "sh"
  254. vars[urlEpName] = "ep1"
  255. ieid1, errRsp := procCreateEndpoint(c, vars, b1)
  256. if errRsp != &createdResponse {
  257. t.Fatalf("Unexepected failure: %v", errRsp)
  258. }
  259. eid1 := i2s(ieid1)
  260. vars[urlEpName] = "ep2"
  261. ieid2, errRsp := procCreateEndpoint(c, vars, b2)
  262. if errRsp != &createdResponse {
  263. t.Fatalf("Unexepected failure: %v", errRsp)
  264. }
  265. eid2 := i2s(ieid2)
  266. vars[urlNwName] = ""
  267. vars[urlEpName] = "ep1"
  268. _, errRsp = procGetEndpoint(c, vars, nil)
  269. if errRsp == &successResponse {
  270. t.Fatalf("Expected failure but succeeded: %v", errRsp)
  271. }
  272. if errRsp.StatusCode != http.StatusBadRequest {
  273. t.Fatalf("Expected to fail with http.StatusBadRequest, but got: %d", errRsp.StatusCode)
  274. }
  275. vars = make(map[string]string)
  276. vars[urlNwName] = "sh"
  277. vars[urlEpID] = ""
  278. _, errRsp = procGetEndpoint(c, vars, nil)
  279. if errRsp == &successResponse {
  280. t.Fatalf("Expected failure but succeeded: %v", errRsp)
  281. }
  282. if errRsp.StatusCode != http.StatusBadRequest {
  283. t.Fatalf("Expected to fail with http.StatusBadRequest, but got: %d", errRsp.StatusCode)
  284. }
  285. vars = make(map[string]string)
  286. vars[urlNwID] = ""
  287. vars[urlEpID] = eid1
  288. _, errRsp = procGetEndpoint(c, vars, nil)
  289. if errRsp == &successResponse {
  290. t.Fatalf("Expected failure but succeeded: %v", errRsp)
  291. }
  292. if errRsp.StatusCode != http.StatusBadRequest {
  293. t.Fatalf("Expected to fail with http.StatusBadRequest, but got: %d", errRsp.StatusCode)
  294. }
  295. // nw by name and ep by id
  296. vars[urlNwName] = "sh"
  297. i1, errRsp := procGetEndpoint(c, vars, nil)
  298. if errRsp != &successResponse {
  299. t.Fatalf("Unexepected failure: %v", errRsp)
  300. }
  301. // nw by name and ep by name
  302. delete(vars, urlEpID)
  303. vars[urlEpName] = "ep1"
  304. i2, errRsp := procGetEndpoint(c, vars, nil)
  305. if errRsp != &successResponse {
  306. t.Fatalf("Unexepected failure: %v", errRsp)
  307. }
  308. // nw by id and ep by name
  309. delete(vars, urlNwName)
  310. vars[urlNwID] = nid
  311. i3, errRsp := procGetEndpoint(c, vars, nil)
  312. if errRsp != &successResponse {
  313. t.Fatalf("Unexepected failure: %v", errRsp)
  314. }
  315. // nw by id and ep by id
  316. delete(vars, urlEpName)
  317. vars[urlEpID] = eid1
  318. i4, errRsp := procGetEndpoint(c, vars, nil)
  319. if errRsp != &successResponse {
  320. t.Fatalf("Unexepected failure: %v", errRsp)
  321. }
  322. id1 := i2e(i1).ID
  323. if id1 != i2e(i2).ID || id1 != i2e(i3).ID || id1 != i2e(i4).ID {
  324. t.Fatalf("Endpoints retireved via different query parameters differ: %v, %v, %v, %v", i1, i2, i3, i4)
  325. }
  326. vars[urlNwName] = ""
  327. _, errRsp = procGetEndpoints(c, vars, nil)
  328. if errRsp == &successResponse {
  329. t.Fatalf("Expected failure, got: %v", errRsp)
  330. }
  331. delete(vars, urlNwName)
  332. vars[urlNwID] = "fakeID"
  333. _, errRsp = procGetEndpoints(c, vars, nil)
  334. if errRsp == &successResponse {
  335. t.Fatalf("Expected failure, got: %v", errRsp)
  336. }
  337. vars[urlNwID] = nid
  338. _, errRsp = procGetEndpoints(c, vars, nil)
  339. if errRsp != &successResponse {
  340. t.Fatalf("Unexepected failure: %v", errRsp)
  341. }
  342. vars[urlNwName] = "sh"
  343. iepList, errRsp := procGetEndpoints(c, vars, nil)
  344. if errRsp != &successResponse {
  345. t.Fatalf("Unexepected failure: %v", errRsp)
  346. }
  347. epList := i2eL(iepList)
  348. if len(epList) != 2 {
  349. t.Fatalf("Did not return the expected number (2) of endpoint resources: %d", len(epList))
  350. }
  351. if "sh" != epList[0].Network || "sh" != epList[1].Network {
  352. t.Fatalf("Did not find expected network name in endpoint resources")
  353. }
  354. vars = make(map[string]string)
  355. vars[urlNwName] = ""
  356. _, errRsp = procGetNetwork(c, vars, nil)
  357. if errRsp == &successResponse {
  358. t.Fatalf("Exepected failure, got: %v", errRsp)
  359. }
  360. vars[urlNwName] = "shhhhh"
  361. _, errRsp = procGetNetwork(c, vars, nil)
  362. if errRsp == &successResponse {
  363. t.Fatalf("Exepected failure, got: %v", errRsp)
  364. }
  365. vars[urlNwName] = "sh"
  366. inr1, errRsp := procGetNetwork(c, vars, nil)
  367. if errRsp != &successResponse {
  368. t.Fatalf("Unexepected failure: %v", errRsp)
  369. }
  370. nr1 := i2n(inr1)
  371. delete(vars, urlNwName)
  372. vars[urlNwID] = "cacca"
  373. _, errRsp = procGetNetwork(c, vars, nil)
  374. if errRsp == &successResponse {
  375. t.Fatalf("Unexepected failure: %v", errRsp)
  376. }
  377. vars[urlNwID] = nid
  378. inr2, errRsp := procGetNetwork(c, vars, nil)
  379. if errRsp != &successResponse {
  380. t.Fatalf("procgetNetworkByName() != procgetNetworkById(), %v vs %v", inr1, inr2)
  381. }
  382. nr2 := i2n(inr2)
  383. if nr1.Name != nr2.Name || nr1.Type != nr2.Type || nr1.ID != nr2.ID || len(nr1.Endpoints) != len(nr2.Endpoints) {
  384. t.Fatalf("Get by name and Get failure: %v", errRsp)
  385. }
  386. if len(nr1.Endpoints) != 2 {
  387. t.Fatalf("Did not find the expected number (2) of endpoint resources in the network resource: %d", len(nr1.Endpoints))
  388. }
  389. for _, er := range nr1.Endpoints {
  390. if er.ID != eid1 && er.ID != eid2 {
  391. t.Fatalf("Did not find the expected endpoint resources in the network resource: %v", nr1.Endpoints)
  392. }
  393. }
  394. iList, errRsp := procGetNetworks(c, nil, nil)
  395. if errRsp != &successResponse {
  396. t.Fatalf("Unexepected failure: %v", errRsp)
  397. }
  398. netList := i2nL(iList)
  399. if len(netList) != 1 {
  400. t.Fatalf("Did not return the expected number of network resources")
  401. }
  402. if nid != netList[0].ID {
  403. t.Fatalf("Did not find expected network %s: %v", nid, netList)
  404. }
  405. _, errRsp = procDeleteNetwork(c, vars, nil)
  406. if errRsp == &successResponse {
  407. t.Fatalf("Exepected failure, got: %v", errRsp)
  408. }
  409. vars[urlEpName] = "ep1"
  410. _, errRsp = procDeleteEndpoint(c, vars, nil)
  411. if errRsp != &successResponse {
  412. t.Fatalf("Unexepected failure: %v", errRsp)
  413. }
  414. delete(vars, urlEpName)
  415. iepList, errRsp = procGetEndpoints(c, vars, nil)
  416. if errRsp != &successResponse {
  417. t.Fatalf("Unexepected failure: %v", errRsp)
  418. }
  419. epList = i2eL(iepList)
  420. if len(epList) != 1 {
  421. t.Fatalf("Did not return the expected number (1) of endpoint resources: %d", len(epList))
  422. }
  423. vars[urlEpName] = "ep2"
  424. _, errRsp = procDeleteEndpoint(c, vars, nil)
  425. if errRsp != &successResponse {
  426. t.Fatalf("Unexepected failure: %v", errRsp)
  427. }
  428. iepList, errRsp = procGetEndpoints(c, vars, nil)
  429. if errRsp != &successResponse {
  430. t.Fatalf("Unexepected failure: %v", errRsp)
  431. }
  432. epList = i2eL(iepList)
  433. if len(epList) != 0 {
  434. t.Fatalf("Did not return the expected number (0) of endpoint resources: %d", len(epList))
  435. }
  436. _, errRsp = procDeleteNetwork(c, vars, nil)
  437. if errRsp != &successResponse {
  438. t.Fatalf("Unexepected failure: %v", errRsp)
  439. }
  440. iList, errRsp = procGetNetworks(c, nil, nil)
  441. if errRsp != &successResponse {
  442. t.Fatalf("Unexepected failure: %v", errRsp)
  443. }
  444. netList = i2nL(iList)
  445. if len(netList) != 0 {
  446. t.Fatalf("Did not return the expected number of network resources")
  447. }
  448. }
  449. func TestDetectGetNetworksInvalidQueryComposition(t *testing.T) {
  450. c, err := libnetwork.New("")
  451. if err != nil {
  452. t.Fatal(err)
  453. }
  454. vars := map[string]string{urlNwName: "x", urlNwPID: "y"}
  455. _, errRsp := procGetNetworks(c, vars, nil)
  456. if errRsp.StatusCode != http.StatusBadRequest {
  457. t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
  458. }
  459. }
  460. func TestDetectGetEndpointsInvalidQueryComposition(t *testing.T) {
  461. defer netutils.SetupTestNetNS(t)()
  462. c, _ := createTestNetwork(t, "network")
  463. vars := map[string]string{urlNwName: "network", urlEpName: "x", urlEpPID: "y"}
  464. _, errRsp := procGetEndpoints(c, vars, nil)
  465. if errRsp.StatusCode != http.StatusBadRequest {
  466. t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
  467. }
  468. }
  469. func TestFindNetworkUtil(t *testing.T) {
  470. defer netutils.SetupTestNetNS(t)()
  471. c, nw := createTestNetwork(t, "network")
  472. nid := nw.ID()
  473. defer checkPanic(t)
  474. findNetwork(c, "", -1)
  475. _, errRsp := findNetwork(c, "", byName)
  476. if errRsp == &successResponse {
  477. t.Fatalf("Expected to fail but succeeded")
  478. }
  479. if errRsp.StatusCode != http.StatusBadRequest {
  480. t.Fatalf("Expected %d, but got: %d", http.StatusBadRequest, errRsp.StatusCode)
  481. }
  482. n, errRsp := findNetwork(c, nid, byID)
  483. if errRsp != &successResponse {
  484. t.Fatalf("Unexpected failure: %v", errRsp)
  485. }
  486. if n == nil {
  487. t.Fatalf("Unexpected nil libnetwork.Network")
  488. }
  489. if nid != n.ID() {
  490. t.Fatalf("Incorrect libnetwork.Network resource. It has different id: %v", n)
  491. }
  492. if "network" != n.Name() {
  493. t.Fatalf("Incorrect libnetwork.Network resource. It has different name: %v", n)
  494. }
  495. n, errRsp = findNetwork(c, "network", byName)
  496. if errRsp != &successResponse {
  497. t.Fatalf("Unexpected failure: %v", errRsp)
  498. }
  499. if n == nil {
  500. t.Fatalf("Unexpected nil libnetwork.Network")
  501. }
  502. if nid != n.ID() {
  503. t.Fatalf("Incorrect libnetwork.Network resource. It has different id: %v", n)
  504. }
  505. if "network" != n.Name() {
  506. t.Fatalf("Incorrect libnetwork.Network resource. It has different name: %v", n)
  507. }
  508. n.Delete()
  509. _, errRsp = findNetwork(c, nid, byID)
  510. if errRsp == &successResponse {
  511. t.Fatalf("Expected to fail but succeeded")
  512. }
  513. if errRsp.StatusCode != http.StatusNotFound {
  514. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  515. }
  516. _, errRsp = findNetwork(c, "network", byName)
  517. if errRsp == &successResponse {
  518. t.Fatalf("Expected to fail but succeeded")
  519. }
  520. if errRsp.StatusCode != http.StatusNotFound {
  521. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  522. }
  523. }
  524. func TestCreateDeleteEndpoints(t *testing.T) {
  525. defer netutils.SetupTestNetNS(t)()
  526. c, err := libnetwork.New("")
  527. if err != nil {
  528. t.Fatal(err)
  529. }
  530. err = c.ConfigureNetworkDriver(bridgeNetType, nil)
  531. if err != nil {
  532. t.Fatal(err)
  533. }
  534. nc := networkCreate{Name: "firstNet", NetworkType: bridgeNetType}
  535. body, err := json.Marshal(nc)
  536. if err != nil {
  537. t.Fatal(err)
  538. }
  539. vars := make(map[string]string)
  540. i, errRsp := procCreateNetwork(c, vars, body)
  541. if errRsp != &createdResponse {
  542. t.Fatalf("Unexepected failure: %v", errRsp)
  543. }
  544. nid := i2s(i)
  545. vbad, err := json.Marshal("bad endppoint create data")
  546. if err != nil {
  547. t.Fatal(err)
  548. }
  549. vars[urlNwName] = "firstNet"
  550. _, errRsp = procCreateEndpoint(c, vars, vbad)
  551. if errRsp == &createdResponse {
  552. t.Fatalf("Expected to fail but succeeded")
  553. }
  554. b, err := json.Marshal(endpointCreate{Name: ""})
  555. if err != nil {
  556. t.Fatal(err)
  557. }
  558. vars[urlNwName] = "secondNet"
  559. _, errRsp = procCreateEndpoint(c, vars, b)
  560. if errRsp == &createdResponse {
  561. t.Fatalf("Expected to fail but succeeded")
  562. }
  563. vars[urlNwName] = "firstNet"
  564. _, errRsp = procCreateEndpoint(c, vars, b)
  565. if errRsp == &successResponse {
  566. t.Fatalf("Expected failure but succeeded: %v", errRsp)
  567. }
  568. b, err = json.Marshal(endpointCreate{Name: "firstEp"})
  569. if err != nil {
  570. t.Fatal(err)
  571. }
  572. i, errRsp = procCreateEndpoint(c, vars, b)
  573. if errRsp != &createdResponse {
  574. t.Fatalf("Unexepected failure: %v", errRsp)
  575. }
  576. eid := i2s(i)
  577. _, errRsp = findEndpoint(c, "myNet", "firstEp", byName, byName)
  578. if errRsp == &successResponse {
  579. t.Fatalf("Expected failure but succeeded: %v", errRsp)
  580. }
  581. ep0, errRsp := findEndpoint(c, nid, "firstEp", byID, byName)
  582. if errRsp != &successResponse {
  583. t.Fatalf("Unexepected failure: %v", errRsp)
  584. }
  585. ep1, errRsp := findEndpoint(c, "firstNet", "firstEp", byName, byName)
  586. if errRsp != &successResponse {
  587. t.Fatalf("Unexepected failure: %v", errRsp)
  588. }
  589. ep2, errRsp := findEndpoint(c, nid, eid, byID, byID)
  590. if errRsp != &successResponse {
  591. t.Fatalf("Unexepected failure: %v", errRsp)
  592. }
  593. ep3, errRsp := findEndpoint(c, "firstNet", eid, byName, byID)
  594. if errRsp != &successResponse {
  595. t.Fatalf("Unexepected failure: %v", errRsp)
  596. }
  597. if ep0.ID() != ep1.ID() || ep0.ID() != ep2.ID() || ep0.ID() != ep3.ID() {
  598. t.Fatalf("Diffenrent queries returned different endpoints: \nep0: %v\nep1: %v\nep2: %v\nep3: %v", ep0, ep1, ep2, ep3)
  599. }
  600. vars = make(map[string]string)
  601. vars[urlNwName] = ""
  602. vars[urlEpName] = "ep1"
  603. _, errRsp = procDeleteEndpoint(c, vars, nil)
  604. if errRsp == &successResponse {
  605. t.Fatalf("Expected failure, got: %v", errRsp)
  606. }
  607. vars[urlNwName] = "firstNet"
  608. vars[urlEpName] = ""
  609. _, errRsp = procDeleteEndpoint(c, vars, nil)
  610. if errRsp == &successResponse {
  611. t.Fatalf("Expected failure, got: %v", errRsp)
  612. }
  613. vars[urlEpName] = "ep2"
  614. _, errRsp = procDeleteEndpoint(c, vars, nil)
  615. if errRsp == &successResponse {
  616. t.Fatalf("Expected failure, got: %v", errRsp)
  617. }
  618. vars[urlEpName] = "firstEp"
  619. _, errRsp = procDeleteEndpoint(c, vars, nil)
  620. if errRsp != &successResponse {
  621. t.Fatalf("Unexepected failure: %v", errRsp)
  622. }
  623. _, errRsp = findEndpoint(c, "firstNet", "firstEp", byName, byName)
  624. if errRsp == &successResponse {
  625. t.Fatalf("Expected failure, got: %v", errRsp)
  626. }
  627. }
  628. func TestJoinLeave(t *testing.T) {
  629. defer netutils.SetupTestNetNS(t)()
  630. c, err := libnetwork.New("")
  631. if err != nil {
  632. t.Fatal(err)
  633. }
  634. err = c.ConfigureNetworkDriver(bridgeNetType, nil)
  635. if err != nil {
  636. t.Fatal(err)
  637. }
  638. nb, err := json.Marshal(networkCreate{Name: "network", NetworkType: bridgeNetType})
  639. if err != nil {
  640. t.Fatal(err)
  641. }
  642. vars := make(map[string]string)
  643. _, errRsp := procCreateNetwork(c, vars, nb)
  644. if errRsp != &createdResponse {
  645. t.Fatalf("Unexepected failure: %v", errRsp)
  646. }
  647. eb, err := json.Marshal(endpointCreate{Name: "endpoint"})
  648. if err != nil {
  649. t.Fatal(err)
  650. }
  651. vars[urlNwName] = "network"
  652. _, errRsp = procCreateEndpoint(c, vars, eb)
  653. if errRsp != &createdResponse {
  654. t.Fatalf("Unexepected failure: %v", errRsp)
  655. }
  656. vbad, err := json.Marshal("bad data")
  657. if err != nil {
  658. t.Fatal(err)
  659. }
  660. _, errRsp = procJoinEndpoint(c, vars, vbad)
  661. if errRsp == &successResponse {
  662. t.Fatalf("Expected failure, got: %v", errRsp)
  663. }
  664. vars[urlEpName] = "endpoint"
  665. bad, err := json.Marshal(endpointJoin{})
  666. if err != nil {
  667. t.Fatal(err)
  668. }
  669. _, errRsp = procJoinEndpoint(c, vars, bad)
  670. if errRsp == &successResponse {
  671. t.Fatalf("Expected failure, got: %v", errRsp)
  672. }
  673. cid := "abcdefghi"
  674. jl := endpointJoin{ContainerID: cid}
  675. jlb, err := json.Marshal(jl)
  676. if err != nil {
  677. t.Fatal(err)
  678. }
  679. vars = make(map[string]string)
  680. vars[urlNwName] = ""
  681. vars[urlEpName] = ""
  682. _, errRsp = procJoinEndpoint(c, vars, jlb)
  683. if errRsp == &successResponse {
  684. t.Fatalf("Expected failure, got: %v", errRsp)
  685. }
  686. vars[urlNwName] = "network"
  687. vars[urlEpName] = ""
  688. _, errRsp = procJoinEndpoint(c, vars, jlb)
  689. if errRsp == &successResponse {
  690. t.Fatalf("Expected failure, got: %v", errRsp)
  691. }
  692. vars[urlEpName] = "epoint"
  693. _, errRsp = procJoinEndpoint(c, vars, jlb)
  694. if errRsp == &successResponse {
  695. t.Fatalf("Expected failure, got: %v", errRsp)
  696. }
  697. vars[urlEpName] = "endpoint"
  698. key, errRsp := procJoinEndpoint(c, vars, jlb)
  699. if errRsp != &successResponse {
  700. t.Fatalf("Expected failure, got: %v", errRsp)
  701. }
  702. keyStr := i2s(key)
  703. if keyStr == "" {
  704. t.Fatalf("Empty sandbox key")
  705. }
  706. _, errRsp = procDeleteEndpoint(c, vars, nil)
  707. if errRsp == &successResponse {
  708. t.Fatalf("Expected failure, got: %v", errRsp)
  709. }
  710. vars[urlNwName] = "network2"
  711. _, errRsp = procLeaveEndpoint(c, vars, vbad)
  712. if errRsp == &successResponse {
  713. t.Fatalf("Expected failure, got: %v", errRsp)
  714. }
  715. _, errRsp = procLeaveEndpoint(c, vars, bad)
  716. if errRsp == &successResponse {
  717. t.Fatalf("Expected failure, got: %v", errRsp)
  718. }
  719. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  720. if errRsp == &successResponse {
  721. t.Fatalf("Expected failure, got: %v", errRsp)
  722. }
  723. vars = make(map[string]string)
  724. vars[urlNwName] = ""
  725. vars[urlEpName] = ""
  726. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  727. if errRsp == &successResponse {
  728. t.Fatalf("Expected failure, got: %v", errRsp)
  729. }
  730. vars[urlNwName] = "network"
  731. vars[urlEpName] = ""
  732. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  733. if errRsp == &successResponse {
  734. t.Fatalf("Expected failure, got: %v", errRsp)
  735. }
  736. vars[urlEpName] = "2epoint"
  737. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  738. if errRsp == &successResponse {
  739. t.Fatalf("Expected failure, got: %v", errRsp)
  740. }
  741. vars[urlEpName] = "epoint"
  742. vars[urlCnID] = "who"
  743. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  744. if errRsp == &successResponse {
  745. t.Fatalf("Expected failure, got: %v", errRsp)
  746. }
  747. delete(vars, urlCnID)
  748. vars[urlEpName] = "endpoint"
  749. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  750. if errRsp == &successResponse {
  751. t.Fatalf("Expected failure, got: %v", errRsp)
  752. }
  753. vars[urlCnID] = cid
  754. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  755. if errRsp != &successResponse {
  756. t.Fatalf("Unexepected failure: %v", errRsp)
  757. }
  758. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  759. if errRsp == &successResponse {
  760. t.Fatalf("Expected failure, got: %v", errRsp)
  761. }
  762. _, errRsp = procDeleteEndpoint(c, vars, nil)
  763. if errRsp != &successResponse {
  764. t.Fatalf("Unexepected failure: %v", errRsp)
  765. }
  766. }
  767. func TestFindEndpointUtil(t *testing.T) {
  768. defer netutils.SetupTestNetNS(t)()
  769. c, nw := createTestNetwork(t, "network")
  770. nid := nw.ID()
  771. ep, err := nw.CreateEndpoint("secondEp", nil)
  772. if err != nil {
  773. t.Fatal(err)
  774. }
  775. eid := ep.ID()
  776. defer checkPanic(t)
  777. findEndpoint(c, nid, "", byID, -1)
  778. _, errRsp := findEndpoint(c, nid, "", byID, byName)
  779. if errRsp == &successResponse {
  780. t.Fatalf("Expected failure, but got: %v", errRsp)
  781. }
  782. if errRsp.StatusCode != http.StatusBadRequest {
  783. t.Fatalf("Expected %d, but got: %d", http.StatusBadRequest, errRsp.StatusCode)
  784. }
  785. ep0, errRsp := findEndpoint(c, nid, "secondEp", byID, byName)
  786. if errRsp != &successResponse {
  787. t.Fatalf("Unexepected failure: %v", errRsp)
  788. }
  789. ep1, errRsp := findEndpoint(c, "second", "secondEp", byName, byName)
  790. if errRsp != &successResponse {
  791. t.Fatalf("Unexepected failure: %v", errRsp)
  792. }
  793. ep2, errRsp := findEndpoint(c, nid, eid, byID, byID)
  794. if errRsp != &successResponse {
  795. t.Fatalf("Unexepected failure: %v", errRsp)
  796. }
  797. ep3, errRsp := findEndpoint(c, "second", eid, byName, byID)
  798. if errRsp != &successResponse {
  799. t.Fatalf("Unexepected failure: %v", errRsp)
  800. }
  801. if ep0 != ep1 || ep0 != ep2 || ep0 != ep3 {
  802. t.Fatalf("Diffenrent queries returned different endpoints")
  803. }
  804. ep.Delete()
  805. _, errRsp = findEndpoint(c, nid, "secondEp", byID, byName)
  806. if errRsp == &successResponse {
  807. t.Fatalf("Expected failure, but got: %v", errRsp)
  808. }
  809. if errRsp.StatusCode != http.StatusNotFound {
  810. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  811. }
  812. _, errRsp = findEndpoint(c, "second", "secondEp", byName, byName)
  813. if errRsp == &successResponse {
  814. t.Fatalf("Expected failure, but got: %v", errRsp)
  815. }
  816. if errRsp.StatusCode != http.StatusNotFound {
  817. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  818. }
  819. _, errRsp = findEndpoint(c, nid, eid, byID, byID)
  820. if errRsp == &successResponse {
  821. t.Fatalf("Expected failure, but got: %v", errRsp)
  822. }
  823. if errRsp.StatusCode != http.StatusNotFound {
  824. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  825. }
  826. _, errRsp = findEndpoint(c, "second", eid, byName, byID)
  827. if errRsp == &successResponse {
  828. t.Fatalf("Expected failure, but got: %v", errRsp)
  829. }
  830. if errRsp.StatusCode != http.StatusNotFound {
  831. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  832. }
  833. }
  834. func checkPanic(t *testing.T) {
  835. if r := recover(); r != nil {
  836. if _, ok := r.(runtime.Error); ok {
  837. panic(r)
  838. }
  839. } else {
  840. t.Fatalf("Expected to panic, but suceeded")
  841. }
  842. }
  843. func TestDetectNetworkTargetPanic(t *testing.T) {
  844. defer checkPanic(t)
  845. vars := make(map[string]string)
  846. detectNetworkTarget(vars)
  847. }
  848. func TestDetectEndpointTargetPanic(t *testing.T) {
  849. defer checkPanic(t)
  850. vars := make(map[string]string)
  851. detectEndpointTarget(vars)
  852. }
  853. func TestResponseStatus(t *testing.T) {
  854. list := []int{
  855. http.StatusBadGateway,
  856. http.StatusBadRequest,
  857. http.StatusConflict,
  858. http.StatusContinue,
  859. http.StatusExpectationFailed,
  860. http.StatusForbidden,
  861. http.StatusFound,
  862. http.StatusGatewayTimeout,
  863. http.StatusGone,
  864. http.StatusHTTPVersionNotSupported,
  865. http.StatusInternalServerError,
  866. http.StatusLengthRequired,
  867. http.StatusMethodNotAllowed,
  868. http.StatusMovedPermanently,
  869. http.StatusMultipleChoices,
  870. http.StatusNoContent,
  871. http.StatusNonAuthoritativeInfo,
  872. http.StatusNotAcceptable,
  873. http.StatusNotFound,
  874. http.StatusNotModified,
  875. http.StatusPartialContent,
  876. http.StatusPaymentRequired,
  877. http.StatusPreconditionFailed,
  878. http.StatusProxyAuthRequired,
  879. http.StatusRequestEntityTooLarge,
  880. http.StatusRequestTimeout,
  881. http.StatusRequestURITooLong,
  882. http.StatusRequestedRangeNotSatisfiable,
  883. http.StatusResetContent,
  884. http.StatusServiceUnavailable,
  885. http.StatusSwitchingProtocols,
  886. http.StatusTemporaryRedirect,
  887. http.StatusUnauthorized,
  888. http.StatusUnsupportedMediaType,
  889. http.StatusUseProxy,
  890. }
  891. for _, c := range list {
  892. r := responseStatus{StatusCode: c}
  893. if r.isOK() {
  894. t.Fatalf("isOK() returned true for code% d", c)
  895. }
  896. }
  897. r := responseStatus{StatusCode: http.StatusOK}
  898. if !r.isOK() {
  899. t.Fatalf("isOK() failed")
  900. }
  901. r = responseStatus{StatusCode: http.StatusCreated}
  902. if !r.isOK() {
  903. t.Fatalf("isOK() failed")
  904. }
  905. }
  906. // Local structs for end to end testing of api.go
  907. type localReader struct {
  908. data []byte
  909. beBad bool
  910. }
  911. func newLocalReader(data []byte) *localReader {
  912. lr := &localReader{data: make([]byte, len(data))}
  913. copy(lr.data, data)
  914. return lr
  915. }
  916. func (l *localReader) Read(p []byte) (n int, err error) {
  917. if l.beBad {
  918. return 0, errors.New("I am a bad reader")
  919. }
  920. if p == nil {
  921. return -1, fmt.Errorf("nil buffer passed")
  922. }
  923. if l.data == nil || len(l.data) == 0 {
  924. return 0, io.EOF
  925. }
  926. copy(p[:], l.data[:])
  927. return len(l.data), io.EOF
  928. }
  929. type localResponseWriter struct {
  930. body []byte
  931. statusCode int
  932. }
  933. func newWriter() *localResponseWriter {
  934. return &localResponseWriter{}
  935. }
  936. func (f *localResponseWriter) Header() http.Header {
  937. return make(map[string][]string, 0)
  938. }
  939. func (f *localResponseWriter) Write(data []byte) (int, error) {
  940. if data == nil {
  941. return -1, fmt.Errorf("nil data passed")
  942. }
  943. f.body = make([]byte, len(data))
  944. copy(f.body, data)
  945. return len(f.body), nil
  946. }
  947. func (f *localResponseWriter) WriteHeader(c int) {
  948. f.statusCode = c
  949. }
  950. func TestwriteJSON(t *testing.T) {
  951. testCode := 55
  952. testData, err := json.Marshal("test data")
  953. if err != nil {
  954. t.Fatal(err)
  955. }
  956. rsp := newWriter()
  957. writeJSON(rsp, testCode, testData)
  958. if rsp.statusCode != testCode {
  959. t.Fatalf("writeJSON() failed to set the status code. Expected %d. Got %d", testCode, rsp.statusCode)
  960. }
  961. if !bytes.Equal(testData, rsp.body) {
  962. t.Fatalf("writeJSON() failed to set the body. Expected %s. Got %s", testData, rsp.body)
  963. }
  964. }
  965. func TestHttpHandlerUninit(t *testing.T) {
  966. defer netutils.SetupTestNetNS(t)()
  967. c, err := libnetwork.New("")
  968. if err != nil {
  969. t.Fatal(err)
  970. }
  971. h := &httpHandler{c: c}
  972. h.initRouter()
  973. if h.r == nil {
  974. t.Fatalf("initRouter() did not initialize the router")
  975. }
  976. rsp := newWriter()
  977. req, err := http.NewRequest("GET", "/v1.19/networks", nil)
  978. if err != nil {
  979. t.Fatal(err)
  980. }
  981. handleRequest := NewHTTPHandler(nil)
  982. handleRequest(rsp, req)
  983. if rsp.statusCode != http.StatusServiceUnavailable {
  984. t.Fatalf("Expected (%d). Got (%d): %s", http.StatusServiceUnavailable, rsp.statusCode, rsp.body)
  985. }
  986. handleRequest = NewHTTPHandler(c)
  987. handleRequest(rsp, req)
  988. if rsp.statusCode != http.StatusOK {
  989. t.Fatalf("Expected (%d). Got: (%d): %s", http.StatusOK, rsp.statusCode, rsp.body)
  990. }
  991. var list []*networkResource
  992. err = json.Unmarshal(rsp.body, &list)
  993. if err != nil {
  994. t.Fatal(err)
  995. }
  996. if len(list) != 0 {
  997. t.Fatalf("Expected empty list. Got %v", list)
  998. }
  999. n, err := c.NewNetwork(bridgeNetType, "didietro", nil)
  1000. if err != nil {
  1001. t.Fatal(err)
  1002. }
  1003. nwr := buildNetworkResource(n)
  1004. expected, err := json.Marshal([]*networkResource{nwr})
  1005. if err != nil {
  1006. t.Fatal(err)
  1007. }
  1008. handleRequest(rsp, req)
  1009. if rsp.statusCode != http.StatusOK {
  1010. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1011. }
  1012. if len(rsp.body) == 0 {
  1013. t.Fatalf("Empty list of networks")
  1014. }
  1015. if bytes.Equal(rsp.body, expected) {
  1016. t.Fatalf("Incorrect list of networks in response's body")
  1017. }
  1018. }
  1019. func TestHttpHandlerBadBody(t *testing.T) {
  1020. defer netutils.SetupTestNetNS(t)()
  1021. rsp := newWriter()
  1022. c, err := libnetwork.New("")
  1023. if err != nil {
  1024. t.Fatal(err)
  1025. }
  1026. handleRequest := NewHTTPHandler(c)
  1027. req, err := http.NewRequest("POST", "/v1.19/networks", &localReader{beBad: true})
  1028. if err != nil {
  1029. t.Fatal(err)
  1030. }
  1031. handleRequest(rsp, req)
  1032. if rsp.statusCode != http.StatusBadRequest {
  1033. t.Fatalf("Unexpected status code. Expected (%d). Got (%d): %s.", http.StatusBadRequest, rsp.statusCode, string(rsp.body))
  1034. }
  1035. body := []byte{}
  1036. lr := newLocalReader(body)
  1037. req, err = http.NewRequest("POST", "/v1.19/networks", lr)
  1038. if err != nil {
  1039. t.Fatal(err)
  1040. }
  1041. handleRequest(rsp, req)
  1042. if rsp.statusCode != http.StatusBadRequest {
  1043. t.Fatalf("Unexpected status code. Expected (%d). Got (%d): %s.", http.StatusBadRequest, rsp.statusCode, string(rsp.body))
  1044. }
  1045. }
  1046. func TestEndToEnd(t *testing.T) {
  1047. defer netutils.SetupTestNetNS(t)()
  1048. rsp := newWriter()
  1049. c, err := libnetwork.New("")
  1050. if err != nil {
  1051. t.Fatal(err)
  1052. }
  1053. handleRequest := NewHTTPHandler(c)
  1054. ops := options.Generic{
  1055. netlabel.EnableIPv6: true,
  1056. netlabel.GenericData: map[string]string{
  1057. "BridgeName": "cdef",
  1058. "FixedCIDRv6": "fe80:2000::1/64",
  1059. "EnableIPv6": "true",
  1060. "Mtu": "1460",
  1061. "EnableIPTables": "true",
  1062. "AddressIP": "172.28.30.254/16",
  1063. "EnableUserlandProxy": "true",
  1064. "AllowNonDefaultBridge": "true",
  1065. },
  1066. }
  1067. // Create network
  1068. nc := networkCreate{Name: "network-fiftyfive", NetworkType: bridgeNetType, Options: ops}
  1069. body, err := json.Marshal(nc)
  1070. if err != nil {
  1071. t.Fatal(err)
  1072. }
  1073. lr := newLocalReader(body)
  1074. req, err := http.NewRequest("POST", "/v1.19/networks", lr)
  1075. if err != nil {
  1076. t.Fatal(err)
  1077. }
  1078. handleRequest(rsp, req)
  1079. if rsp.statusCode != http.StatusCreated {
  1080. t.Fatalf("Unexpectded status code. Expected (%d). Got (%d): %s.", http.StatusCreated, rsp.statusCode, string(rsp.body))
  1081. }
  1082. if len(rsp.body) == 0 {
  1083. t.Fatalf("Empty response body")
  1084. }
  1085. var nid string
  1086. err = json.Unmarshal(rsp.body, &nid)
  1087. if err != nil {
  1088. t.Fatal(err)
  1089. }
  1090. // Query networks collection
  1091. req, err = http.NewRequest("GET", "/v1.19/networks", nil)
  1092. if err != nil {
  1093. t.Fatal(err)
  1094. }
  1095. handleRequest(rsp, req)
  1096. if rsp.statusCode != http.StatusOK {
  1097. t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
  1098. }
  1099. b0 := make([]byte, len(rsp.body))
  1100. copy(b0, rsp.body)
  1101. req, err = http.NewRequest("GET", "/v1.19/networks?name=network-fiftyfive", nil)
  1102. if err != nil {
  1103. t.Fatal(err)
  1104. }
  1105. handleRequest(rsp, req)
  1106. if rsp.statusCode != http.StatusOK {
  1107. t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
  1108. }
  1109. if !bytes.Equal(b0, rsp.body) {
  1110. t.Fatalf("Expected same body from GET /networks and GET /networks?name=<nw> when only network <nw> exist.")
  1111. }
  1112. // Query network by name
  1113. req, err = http.NewRequest("GET", "/v1.19/networks?name=culo", nil)
  1114. if err != nil {
  1115. t.Fatal(err)
  1116. }
  1117. handleRequest(rsp, req)
  1118. if rsp.statusCode != http.StatusOK {
  1119. t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
  1120. }
  1121. var list []*networkResource
  1122. err = json.Unmarshal(rsp.body, &list)
  1123. if err != nil {
  1124. t.Fatal(err)
  1125. }
  1126. if len(list) != 0 {
  1127. t.Fatalf("Expected empty list. Got %v", list)
  1128. }
  1129. req, err = http.NewRequest("GET", "/v1.19/networks?name=network-fiftyfive", nil)
  1130. if err != nil {
  1131. t.Fatal(err)
  1132. }
  1133. handleRequest(rsp, req)
  1134. if rsp.statusCode != http.StatusOK {
  1135. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1136. }
  1137. err = json.Unmarshal(rsp.body, &list)
  1138. if err != nil {
  1139. t.Fatal(err)
  1140. }
  1141. if len(list) == 0 {
  1142. t.Fatalf("Expected non empty list")
  1143. }
  1144. if list[0].Name != "network-fiftyfive" || nid != list[0].ID {
  1145. t.Fatalf("Incongruent resource found: %v", list[0])
  1146. }
  1147. // Query network by partial id
  1148. chars := []byte(nid)
  1149. partial := string(chars[0 : len(chars)/2])
  1150. req, err = http.NewRequest("GET", "/v1.19/networks?partial-id="+partial, nil)
  1151. if err != nil {
  1152. t.Fatal(err)
  1153. }
  1154. handleRequest(rsp, req)
  1155. if rsp.statusCode != http.StatusOK {
  1156. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1157. }
  1158. err = json.Unmarshal(rsp.body, &list)
  1159. if err != nil {
  1160. t.Fatal(err)
  1161. }
  1162. if len(list) == 0 {
  1163. t.Fatalf("Expected non empty list")
  1164. }
  1165. if list[0].Name != "network-fiftyfive" || nid != list[0].ID {
  1166. t.Fatalf("Incongruent resource found: %v", list[0])
  1167. }
  1168. // Get network by id
  1169. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid, nil)
  1170. if err != nil {
  1171. t.Fatal(err)
  1172. }
  1173. handleRequest(rsp, req)
  1174. if rsp.statusCode != http.StatusOK {
  1175. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1176. }
  1177. var nwr networkResource
  1178. err = json.Unmarshal(rsp.body, &nwr)
  1179. if err != nil {
  1180. t.Fatal(err)
  1181. }
  1182. if nwr.Name != "network-fiftyfive" || nid != nwr.ID {
  1183. t.Fatalf("Incongruent resource found: %v", nwr)
  1184. }
  1185. // Create endpoint
  1186. eb, err := json.Marshal(endpointCreate{Name: "ep-TwentyTwo"})
  1187. if err != nil {
  1188. t.Fatal(err)
  1189. }
  1190. lr = newLocalReader(eb)
  1191. req, err = http.NewRequest("POST", "/v1.19/networks/"+nid+"/endpoints", lr)
  1192. if err != nil {
  1193. t.Fatal(err)
  1194. }
  1195. handleRequest(rsp, req)
  1196. if rsp.statusCode != http.StatusCreated {
  1197. t.Fatalf("Unexpectded status code. Expected (%d). Got (%d): %s.", http.StatusCreated, rsp.statusCode, string(rsp.body))
  1198. }
  1199. if len(rsp.body) == 0 {
  1200. t.Fatalf("Empty response body")
  1201. }
  1202. var eid string
  1203. err = json.Unmarshal(rsp.body, &eid)
  1204. if err != nil {
  1205. t.Fatal(err)
  1206. }
  1207. // Query endpoint(s)
  1208. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints", nil)
  1209. if err != nil {
  1210. t.Fatal(err)
  1211. }
  1212. handleRequest(rsp, req)
  1213. if rsp.statusCode != http.StatusOK {
  1214. t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
  1215. }
  1216. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints?name=bla", nil)
  1217. if err != nil {
  1218. t.Fatal(err)
  1219. }
  1220. handleRequest(rsp, req)
  1221. if rsp.statusCode != http.StatusOK {
  1222. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1223. }
  1224. var epList []*endpointResource
  1225. err = json.Unmarshal(rsp.body, &epList)
  1226. if err != nil {
  1227. t.Fatal(err)
  1228. }
  1229. if len(epList) != 0 {
  1230. t.Fatalf("Expected empty list. Got %v", epList)
  1231. }
  1232. // Query endpoint by name
  1233. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints?name=ep-TwentyTwo", nil)
  1234. if err != nil {
  1235. t.Fatal(err)
  1236. }
  1237. handleRequest(rsp, req)
  1238. if rsp.statusCode != http.StatusOK {
  1239. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1240. }
  1241. err = json.Unmarshal(rsp.body, &epList)
  1242. if err != nil {
  1243. t.Fatal(err)
  1244. }
  1245. if len(epList) == 0 {
  1246. t.Fatalf("Empty response body")
  1247. }
  1248. if epList[0].Name != "ep-TwentyTwo" || eid != epList[0].ID {
  1249. t.Fatalf("Incongruent resource found: %v", epList[0])
  1250. }
  1251. // Query endpoint by partial id
  1252. chars = []byte(eid)
  1253. partial = string(chars[0 : len(chars)/2])
  1254. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints?partial-id="+partial, nil)
  1255. if err != nil {
  1256. t.Fatal(err)
  1257. }
  1258. handleRequest(rsp, req)
  1259. if rsp.statusCode != http.StatusOK {
  1260. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1261. }
  1262. err = json.Unmarshal(rsp.body, &epList)
  1263. if err != nil {
  1264. t.Fatal(err)
  1265. }
  1266. if len(epList) == 0 {
  1267. t.Fatalf("Empty response body")
  1268. }
  1269. if epList[0].Name != "ep-TwentyTwo" || eid != epList[0].ID {
  1270. t.Fatalf("Incongruent resource found: %v", epList[0])
  1271. }
  1272. // Get endpoint by id
  1273. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints/"+eid, nil)
  1274. if err != nil {
  1275. t.Fatal(err)
  1276. }
  1277. handleRequest(rsp, req)
  1278. if rsp.statusCode != http.StatusOK {
  1279. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1280. }
  1281. var epr endpointResource
  1282. err = json.Unmarshal(rsp.body, &epr)
  1283. if err != nil {
  1284. t.Fatal(err)
  1285. }
  1286. if epr.Name != "ep-TwentyTwo" || epr.ID != eid {
  1287. t.Fatalf("Incongruent resource found: %v", epr)
  1288. }
  1289. }
  1290. type bre struct{}
  1291. func (b *bre) Error() string {
  1292. return "I am a bad request error"
  1293. }
  1294. func (b *bre) BadRequest() {}
  1295. type nfe struct{}
  1296. func (n *nfe) Error() string {
  1297. return "I am a not found error"
  1298. }
  1299. func (n *nfe) NotFound() {}
  1300. type forb struct{}
  1301. func (f *forb) Error() string {
  1302. return "I am a bad request error"
  1303. }
  1304. func (f *forb) Forbidden() {}
  1305. type notimpl struct{}
  1306. func (nip *notimpl) Error() string {
  1307. return "I am a not implemented error"
  1308. }
  1309. func (nip *notimpl) NotImplemented() {}
  1310. type inter struct{}
  1311. func (it *inter) Error() string {
  1312. return "I am a internal error"
  1313. }
  1314. func (it *inter) Internal() {}
  1315. type tout struct{}
  1316. func (to *tout) Error() string {
  1317. return "I am a timeout error"
  1318. }
  1319. func (to *tout) Timeout() {}
  1320. type noserv struct{}
  1321. func (nos *noserv) Error() string {
  1322. return "I am a no service error"
  1323. }
  1324. func (nos *noserv) NoService() {}
  1325. type notclassified struct{}
  1326. func (noc *notclassified) Error() string {
  1327. return "I am a non classified error"
  1328. }
  1329. func TestErrorConversion(t *testing.T) {
  1330. if convertNetworkError(new(bre)).StatusCode != http.StatusBadRequest {
  1331. t.Fatalf("Failed to recognize BadRequest error")
  1332. }
  1333. if convertNetworkError(new(nfe)).StatusCode != http.StatusNotFound {
  1334. t.Fatalf("Failed to recognize NotFound error")
  1335. }
  1336. if convertNetworkError(new(forb)).StatusCode != http.StatusForbidden {
  1337. t.Fatalf("Failed to recognize Forbidden error")
  1338. }
  1339. if convertNetworkError(new(notimpl)).StatusCode != http.StatusNotImplemented {
  1340. t.Fatalf("Failed to recognize NotImplemented error")
  1341. }
  1342. if convertNetworkError(new(inter)).StatusCode != http.StatusInternalServerError {
  1343. t.Fatalf("Failed to recognize Internal error")
  1344. }
  1345. if convertNetworkError(new(tout)).StatusCode != http.StatusRequestTimeout {
  1346. t.Fatalf("Failed to recognize Timeout error")
  1347. }
  1348. if convertNetworkError(new(noserv)).StatusCode != http.StatusServiceUnavailable {
  1349. t.Fatalf("Failed to recognize No Service error")
  1350. }
  1351. if convertNetworkError(new(notclassified)).StatusCode != http.StatusInternalServerError {
  1352. t.Fatalf("Failed to recognize not classified error as Internal error")
  1353. }
  1354. }