api_test.go 35 KB

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