api_test.go 37 KB

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