api_test.go 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566
  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 TestDetectGetNetworksInvalidQueryComposition(t *testing.T) {
  429. c, err := libnetwork.New()
  430. if err != nil {
  431. t.Fatal(err)
  432. }
  433. vars := map[string]string{urlNwName: "x", urlNwPID: "y"}
  434. _, errRsp := procGetNetworks(c, vars, nil)
  435. if errRsp.StatusCode != http.StatusBadRequest {
  436. t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
  437. }
  438. }
  439. func TestDetectGetEndpointsInvalidQueryComposition(t *testing.T) {
  440. defer netutils.SetupTestNetNS(t)()
  441. c, err := libnetwork.New()
  442. if err != nil {
  443. t.Fatal(err)
  444. }
  445. err = c.ConfigureNetworkDriver(bridgeNetType, nil)
  446. if err != nil {
  447. t.Fatal(err)
  448. }
  449. _, err = c.NewNetwork(bridgeNetType, "network", nil)
  450. if err != nil {
  451. t.Fatal(err)
  452. }
  453. vars := map[string]string{urlNwName: "network", urlEpName: "x", urlEpPID: "y"}
  454. _, errRsp := procGetEndpoints(c, vars, nil)
  455. if errRsp.StatusCode != http.StatusBadRequest {
  456. t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
  457. }
  458. }
  459. func TestFindNetworkUtil(t *testing.T) {
  460. defer netutils.SetupTestNetNS(t)()
  461. c, err := libnetwork.New()
  462. if err != nil {
  463. t.Fatal(err)
  464. }
  465. err = c.ConfigureNetworkDriver(bridgeNetType, nil)
  466. if err != nil {
  467. t.Fatal(err)
  468. }
  469. nw, err := c.NewNetwork(bridgeNetType, "network", nil)
  470. if err != nil {
  471. t.Fatal(err)
  472. }
  473. nid := nw.ID()
  474. defer checkPanic(t)
  475. findNetwork(c, "", -1)
  476. _, errRsp := findNetwork(c, "", byName)
  477. if errRsp == &successResponse {
  478. t.Fatalf("Expected to fail but succeeded")
  479. }
  480. if errRsp.StatusCode != http.StatusBadRequest {
  481. t.Fatalf("Expected %d, but got: %d", http.StatusBadRequest, errRsp.StatusCode)
  482. }
  483. n, errRsp := findNetwork(c, nid, byID)
  484. if errRsp != &successResponse {
  485. t.Fatalf("Unexpected failure: %v", errRsp)
  486. }
  487. if n == nil {
  488. t.Fatalf("Unexpected nil libnetwork.Network")
  489. }
  490. if nid != n.ID() {
  491. t.Fatalf("Incorrect libnetwork.Network resource. It has different id: %v", n)
  492. }
  493. if "network" != n.Name() {
  494. t.Fatalf("Incorrect libnetwork.Network resource. It has different name: %v", n)
  495. }
  496. n, errRsp = findNetwork(c, "network", byName)
  497. if errRsp != &successResponse {
  498. t.Fatalf("Unexpected failure: %v", errRsp)
  499. }
  500. if n == nil {
  501. t.Fatalf("Unexpected nil libnetwork.Network")
  502. }
  503. if nid != n.ID() {
  504. t.Fatalf("Incorrect libnetwork.Network resource. It has different id: %v", n)
  505. }
  506. if "network" != n.Name() {
  507. t.Fatalf("Incorrect libnetwork.Network resource. It has different name: %v", n)
  508. }
  509. n.Delete()
  510. _, errRsp = findNetwork(c, nid, byID)
  511. if errRsp == &successResponse {
  512. t.Fatalf("Expected to fail but succeeded")
  513. }
  514. if errRsp.StatusCode != http.StatusNotFound {
  515. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  516. }
  517. _, errRsp = findNetwork(c, "network", byName)
  518. if errRsp == &successResponse {
  519. t.Fatalf("Expected to fail but succeeded")
  520. }
  521. if errRsp.StatusCode != http.StatusNotFound {
  522. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  523. }
  524. }
  525. func TestCreateDeleteEndpoints(t *testing.T) {
  526. defer netutils.SetupTestNetNS(t)()
  527. c, err := libnetwork.New()
  528. if err != nil {
  529. t.Fatal(err)
  530. }
  531. err = c.ConfigureNetworkDriver(bridgeNetType, nil)
  532. if err != nil {
  533. t.Fatal(err)
  534. }
  535. nc := networkCreate{Name: "firstNet", NetworkType: bridgeNetType}
  536. body, err := json.Marshal(nc)
  537. if err != nil {
  538. t.Fatal(err)
  539. }
  540. vars := make(map[string]string)
  541. i, errRsp := procCreateNetwork(c, vars, body)
  542. if errRsp != &createdResponse {
  543. t.Fatalf("Unexepected failure: %v", errRsp)
  544. }
  545. nid := i2s(i)
  546. vbad, err := json.Marshal("bad endppoint create data")
  547. if err != nil {
  548. t.Fatal(err)
  549. }
  550. vars[urlNwName] = "firstNet"
  551. _, errRsp = procCreateEndpoint(c, vars, vbad)
  552. if errRsp == &createdResponse {
  553. t.Fatalf("Expected to fail but succeeded")
  554. }
  555. b, err := json.Marshal(endpointCreate{Name: ""})
  556. if err != nil {
  557. t.Fatal(err)
  558. }
  559. vars[urlNwName] = "secondNet"
  560. _, errRsp = procCreateEndpoint(c, vars, b)
  561. if errRsp == &createdResponse {
  562. t.Fatalf("Expected to fail but succeeded")
  563. }
  564. vars[urlNwName] = "firstNet"
  565. _, errRsp = procCreateEndpoint(c, vars, b)
  566. if errRsp == &successResponse {
  567. t.Fatalf("Expected failure but succeeded: %v", errRsp)
  568. }
  569. b, err = json.Marshal(endpointCreate{Name: "firstEp"})
  570. if err != nil {
  571. t.Fatal(err)
  572. }
  573. i, errRsp = procCreateEndpoint(c, vars, b)
  574. if errRsp != &createdResponse {
  575. t.Fatalf("Unexepected failure: %v", errRsp)
  576. }
  577. eid := i2s(i)
  578. _, errRsp = findEndpoint(c, "myNet", "firstEp", byName, byName)
  579. if errRsp == &successResponse {
  580. t.Fatalf("Expected failure but succeeded: %v", errRsp)
  581. }
  582. ep0, errRsp := findEndpoint(c, nid, "firstEp", byID, byName)
  583. if errRsp != &successResponse {
  584. t.Fatalf("Unexepected failure: %v", errRsp)
  585. }
  586. ep1, errRsp := findEndpoint(c, "firstNet", "firstEp", byName, byName)
  587. if errRsp != &successResponse {
  588. t.Fatalf("Unexepected failure: %v", errRsp)
  589. }
  590. ep2, errRsp := findEndpoint(c, nid, eid, byID, byID)
  591. if errRsp != &successResponse {
  592. t.Fatalf("Unexepected failure: %v", errRsp)
  593. }
  594. ep3, errRsp := findEndpoint(c, "firstNet", eid, byName, byID)
  595. if errRsp != &successResponse {
  596. t.Fatalf("Unexepected failure: %v", errRsp)
  597. }
  598. if ep0.ID() != ep1.ID() || ep0.ID() != ep2.ID() || ep0.ID() != ep3.ID() {
  599. t.Fatalf("Diffenrent queries returned different endpoints: \nep0: %v\nep1: %v\nep2: %v\nep3: %v", ep0, ep1, ep2, ep3)
  600. }
  601. vars = make(map[string]string)
  602. vars[urlNwName] = ""
  603. vars[urlEpName] = "ep1"
  604. _, errRsp = procDeleteEndpoint(c, vars, nil)
  605. if errRsp == &successResponse {
  606. t.Fatalf("Expected failure, got: %v", errRsp)
  607. }
  608. vars[urlNwName] = "firstNet"
  609. vars[urlEpName] = ""
  610. _, errRsp = procDeleteEndpoint(c, vars, nil)
  611. if errRsp == &successResponse {
  612. t.Fatalf("Expected failure, got: %v", errRsp)
  613. }
  614. vars[urlEpName] = "ep2"
  615. _, errRsp = procDeleteEndpoint(c, vars, nil)
  616. if errRsp == &successResponse {
  617. t.Fatalf("Expected failure, got: %v", errRsp)
  618. }
  619. vars[urlEpName] = "firstEp"
  620. _, errRsp = procDeleteEndpoint(c, vars, nil)
  621. if errRsp != &successResponse {
  622. t.Fatalf("Unexepected failure: %v", errRsp)
  623. }
  624. _, errRsp = findEndpoint(c, "firstNet", "firstEp", byName, byName)
  625. if errRsp == &successResponse {
  626. t.Fatalf("Expected failure, got: %v", errRsp)
  627. }
  628. }
  629. func TestJoinLeave(t *testing.T) {
  630. defer netutils.SetupTestNetNS(t)()
  631. c, err := libnetwork.New()
  632. if err != nil {
  633. t.Fatal(err)
  634. }
  635. err = c.ConfigureNetworkDriver(bridgeNetType, nil)
  636. if err != nil {
  637. t.Fatal(err)
  638. }
  639. nb, err := json.Marshal(networkCreate{Name: "network", NetworkType: bridgeNetType})
  640. if err != nil {
  641. t.Fatal(err)
  642. }
  643. vars := make(map[string]string)
  644. _, errRsp := procCreateNetwork(c, vars, nb)
  645. if errRsp != &createdResponse {
  646. t.Fatalf("Unexepected failure: %v", errRsp)
  647. }
  648. eb, err := json.Marshal(endpointCreate{Name: "endpoint"})
  649. if err != nil {
  650. t.Fatal(err)
  651. }
  652. vars[urlNwName] = "network"
  653. _, errRsp = procCreateEndpoint(c, vars, eb)
  654. if errRsp != &createdResponse {
  655. t.Fatalf("Unexepected failure: %v", errRsp)
  656. }
  657. vbad, err := json.Marshal("bad data")
  658. if err != nil {
  659. t.Fatal(err)
  660. }
  661. _, errRsp = procJoinEndpoint(c, vars, vbad)
  662. if errRsp == &successResponse {
  663. t.Fatalf("Expected failure, got: %v", errRsp)
  664. }
  665. vars[urlEpName] = "endpoint"
  666. bad, err := json.Marshal(endpointJoin{})
  667. if err != nil {
  668. t.Fatal(err)
  669. }
  670. _, errRsp = procJoinEndpoint(c, vars, bad)
  671. if errRsp == &successResponse {
  672. t.Fatalf("Expected failure, got: %v", errRsp)
  673. }
  674. cid := "abcdefghi"
  675. jl := endpointJoin{ContainerID: cid}
  676. jlb, err := json.Marshal(jl)
  677. if err != nil {
  678. t.Fatal(err)
  679. }
  680. vars = make(map[string]string)
  681. vars[urlNwName] = ""
  682. vars[urlEpName] = ""
  683. _, errRsp = procJoinEndpoint(c, vars, jlb)
  684. if errRsp == &successResponse {
  685. t.Fatalf("Expected failure, got: %v", errRsp)
  686. }
  687. vars[urlNwName] = "network"
  688. vars[urlEpName] = ""
  689. _, errRsp = procJoinEndpoint(c, vars, jlb)
  690. if errRsp == &successResponse {
  691. t.Fatalf("Expected failure, got: %v", errRsp)
  692. }
  693. vars[urlEpName] = "epoint"
  694. _, errRsp = procJoinEndpoint(c, vars, jlb)
  695. if errRsp == &successResponse {
  696. t.Fatalf("Expected failure, got: %v", errRsp)
  697. }
  698. vars[urlEpName] = "endpoint"
  699. cdi, errRsp := procJoinEndpoint(c, vars, jlb)
  700. if errRsp != &successResponse {
  701. t.Fatalf("Expected failure, got: %v", errRsp)
  702. }
  703. cd := i2c(cdi)
  704. if cd.SandboxKey == "" {
  705. t.Fatalf("Empty sandbox key")
  706. }
  707. _, errRsp = procDeleteEndpoint(c, vars, nil)
  708. if errRsp == &successResponse {
  709. t.Fatalf("Expected failure, got: %v", errRsp)
  710. }
  711. vars[urlNwName] = "network2"
  712. _, errRsp = procLeaveEndpoint(c, vars, vbad)
  713. if errRsp == &successResponse {
  714. t.Fatalf("Expected failure, got: %v", errRsp)
  715. }
  716. _, errRsp = procLeaveEndpoint(c, vars, bad)
  717. if errRsp == &successResponse {
  718. t.Fatalf("Expected failure, got: %v", errRsp)
  719. }
  720. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  721. if errRsp == &successResponse {
  722. t.Fatalf("Expected failure, got: %v", errRsp)
  723. }
  724. vars = make(map[string]string)
  725. vars[urlNwName] = ""
  726. vars[urlEpName] = ""
  727. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  728. if errRsp == &successResponse {
  729. t.Fatalf("Expected failure, got: %v", errRsp)
  730. }
  731. vars[urlNwName] = "network"
  732. vars[urlEpName] = ""
  733. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  734. if errRsp == &successResponse {
  735. t.Fatalf("Expected failure, got: %v", errRsp)
  736. }
  737. vars[urlEpName] = "2epoint"
  738. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  739. if errRsp == &successResponse {
  740. t.Fatalf("Expected failure, got: %v", errRsp)
  741. }
  742. vars[urlEpName] = "epoint"
  743. vars[urlCnID] = "who"
  744. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  745. if errRsp == &successResponse {
  746. t.Fatalf("Expected failure, got: %v", errRsp)
  747. }
  748. delete(vars, urlCnID)
  749. vars[urlEpName] = "endpoint"
  750. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  751. if errRsp == &successResponse {
  752. t.Fatalf("Expected failure, got: %v", errRsp)
  753. }
  754. vars[urlCnID] = cid
  755. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  756. if errRsp != &successResponse {
  757. t.Fatalf("Unexepected failure: %v", errRsp)
  758. }
  759. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  760. if errRsp == &successResponse {
  761. t.Fatalf("Expected failure, got: %v", errRsp)
  762. }
  763. _, errRsp = procDeleteEndpoint(c, vars, nil)
  764. if errRsp != &successResponse {
  765. t.Fatalf("Unexepected failure: %v", errRsp)
  766. }
  767. }
  768. func TestFindEndpointUtil(t *testing.T) {
  769. defer netutils.SetupTestNetNS(t)()
  770. c, err := libnetwork.New()
  771. if err != nil {
  772. t.Fatal(err)
  773. }
  774. err = c.ConfigureNetworkDriver(bridgeNetType, nil)
  775. if err != nil {
  776. t.Fatal(err)
  777. }
  778. nw, err := c.NewNetwork(bridgeNetType, "second", nil)
  779. if err != nil {
  780. t.Fatal(err)
  781. }
  782. nid := nw.ID()
  783. ep, err := nw.CreateEndpoint("secondEp", nil)
  784. if err != nil {
  785. t.Fatal(err)
  786. }
  787. eid := ep.ID()
  788. defer checkPanic(t)
  789. findEndpoint(c, nid, "", byID, -1)
  790. _, errRsp := findEndpoint(c, nid, "", byID, byName)
  791. if errRsp == &successResponse {
  792. t.Fatalf("Expected failure, but got: %v", errRsp)
  793. }
  794. if errRsp.StatusCode != http.StatusBadRequest {
  795. t.Fatalf("Expected %d, but got: %d", http.StatusBadRequest, errRsp.StatusCode)
  796. }
  797. ep0, errRsp := findEndpoint(c, nid, "secondEp", byID, byName)
  798. if errRsp != &successResponse {
  799. t.Fatalf("Unexepected failure: %v", errRsp)
  800. }
  801. ep1, errRsp := findEndpoint(c, "second", "secondEp", byName, byName)
  802. if errRsp != &successResponse {
  803. t.Fatalf("Unexepected failure: %v", errRsp)
  804. }
  805. ep2, errRsp := findEndpoint(c, nid, eid, byID, byID)
  806. if errRsp != &successResponse {
  807. t.Fatalf("Unexepected failure: %v", errRsp)
  808. }
  809. ep3, errRsp := findEndpoint(c, "second", eid, byName, byID)
  810. if errRsp != &successResponse {
  811. t.Fatalf("Unexepected failure: %v", errRsp)
  812. }
  813. if ep0 != ep1 || ep0 != ep2 || ep0 != ep3 {
  814. t.Fatalf("Diffenrent queries returned different endpoints")
  815. }
  816. ep.Delete()
  817. _, errRsp = findEndpoint(c, nid, "secondEp", byID, byName)
  818. if errRsp == &successResponse {
  819. t.Fatalf("Expected failure, but got: %v", errRsp)
  820. }
  821. if errRsp.StatusCode != http.StatusNotFound {
  822. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  823. }
  824. _, errRsp = findEndpoint(c, "second", "secondEp", byName, byName)
  825. if errRsp == &successResponse {
  826. t.Fatalf("Expected failure, but got: %v", errRsp)
  827. }
  828. if errRsp.StatusCode != http.StatusNotFound {
  829. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  830. }
  831. _, errRsp = findEndpoint(c, nid, eid, byID, byID)
  832. if errRsp == &successResponse {
  833. t.Fatalf("Expected failure, but got: %v", errRsp)
  834. }
  835. if errRsp.StatusCode != http.StatusNotFound {
  836. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  837. }
  838. _, errRsp = findEndpoint(c, "second", eid, byName, byID)
  839. if errRsp == &successResponse {
  840. t.Fatalf("Expected failure, but got: %v", errRsp)
  841. }
  842. if errRsp.StatusCode != http.StatusNotFound {
  843. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  844. }
  845. }
  846. func checkPanic(t *testing.T) {
  847. if r := recover(); r != nil {
  848. if _, ok := r.(runtime.Error); ok {
  849. panic(r)
  850. }
  851. } else {
  852. t.Fatalf("Expected to panic, but suceeded")
  853. }
  854. }
  855. func TestDetectNetworkTargetPanic(t *testing.T) {
  856. defer checkPanic(t)
  857. vars := make(map[string]string)
  858. detectNetworkTarget(vars)
  859. }
  860. func TestDetectEndpointTargetPanic(t *testing.T) {
  861. defer checkPanic(t)
  862. vars := make(map[string]string)
  863. detectEndpointTarget(vars)
  864. }
  865. func TestResponseStatus(t *testing.T) {
  866. list := []int{
  867. http.StatusBadGateway,
  868. http.StatusBadRequest,
  869. http.StatusConflict,
  870. http.StatusContinue,
  871. http.StatusExpectationFailed,
  872. http.StatusForbidden,
  873. http.StatusFound,
  874. http.StatusGatewayTimeout,
  875. http.StatusGone,
  876. http.StatusHTTPVersionNotSupported,
  877. http.StatusInternalServerError,
  878. http.StatusLengthRequired,
  879. http.StatusMethodNotAllowed,
  880. http.StatusMovedPermanently,
  881. http.StatusMultipleChoices,
  882. http.StatusNoContent,
  883. http.StatusNonAuthoritativeInfo,
  884. http.StatusNotAcceptable,
  885. http.StatusNotFound,
  886. http.StatusNotModified,
  887. http.StatusPartialContent,
  888. http.StatusPaymentRequired,
  889. http.StatusPreconditionFailed,
  890. http.StatusProxyAuthRequired,
  891. http.StatusRequestEntityTooLarge,
  892. http.StatusRequestTimeout,
  893. http.StatusRequestURITooLong,
  894. http.StatusRequestedRangeNotSatisfiable,
  895. http.StatusResetContent,
  896. http.StatusServiceUnavailable,
  897. http.StatusSwitchingProtocols,
  898. http.StatusTemporaryRedirect,
  899. http.StatusUnauthorized,
  900. http.StatusUnsupportedMediaType,
  901. http.StatusUseProxy,
  902. }
  903. for _, c := range list {
  904. r := responseStatus{StatusCode: c}
  905. if r.isOK() {
  906. t.Fatalf("isOK() returned true for code% d", c)
  907. }
  908. }
  909. r := responseStatus{StatusCode: http.StatusOK}
  910. if !r.isOK() {
  911. t.Fatalf("isOK() failed")
  912. }
  913. r = responseStatus{StatusCode: http.StatusCreated}
  914. if !r.isOK() {
  915. t.Fatalf("isOK() failed")
  916. }
  917. }
  918. // Local structs for end to end testing of api.go
  919. type localReader struct {
  920. data []byte
  921. beBad bool
  922. }
  923. func newLocalReader(data []byte) *localReader {
  924. lr := &localReader{data: make([]byte, len(data))}
  925. copy(lr.data, data)
  926. return lr
  927. }
  928. func (l *localReader) Read(p []byte) (n int, err error) {
  929. if l.beBad {
  930. return 0, errors.New("I am a bad reader")
  931. }
  932. if p == nil {
  933. return -1, fmt.Errorf("nil buffer passed")
  934. }
  935. if l.data == nil || len(l.data) == 0 {
  936. return 0, io.EOF
  937. }
  938. copy(p[:], l.data[:])
  939. return len(l.data), io.EOF
  940. }
  941. type localResponseWriter struct {
  942. body []byte
  943. statusCode int
  944. }
  945. func newWriter() *localResponseWriter {
  946. return &localResponseWriter{}
  947. }
  948. func (f *localResponseWriter) Header() http.Header {
  949. return make(map[string][]string, 0)
  950. }
  951. func (f *localResponseWriter) Write(data []byte) (int, error) {
  952. if data == nil {
  953. return -1, fmt.Errorf("nil data passed")
  954. }
  955. f.body = make([]byte, len(data))
  956. copy(f.body, data)
  957. return len(f.body), nil
  958. }
  959. func (f *localResponseWriter) WriteHeader(c int) {
  960. f.statusCode = c
  961. }
  962. func TestwriteJSON(t *testing.T) {
  963. testCode := 55
  964. testData, err := json.Marshal("test data")
  965. if err != nil {
  966. t.Fatal(err)
  967. }
  968. rsp := newWriter()
  969. writeJSON(rsp, testCode, testData)
  970. if rsp.statusCode != testCode {
  971. t.Fatalf("writeJSON() failed to set the status code. Expected %d. Got %d", testCode, rsp.statusCode)
  972. }
  973. if !bytes.Equal(testData, rsp.body) {
  974. t.Fatalf("writeJSON() failed to set the body. Expected %s. Got %s", testData, rsp.body)
  975. }
  976. }
  977. func TestHttpHandlerUninit(t *testing.T) {
  978. defer netutils.SetupTestNetNS(t)()
  979. c, err := libnetwork.New()
  980. if err != nil {
  981. t.Fatal(err)
  982. }
  983. h := &httpHandler{c: c}
  984. h.initRouter()
  985. if h.r == nil {
  986. t.Fatalf("initRouter() did not initialize the router")
  987. }
  988. rsp := newWriter()
  989. req, err := http.NewRequest("GET", "/v1.19/networks", nil)
  990. if err != nil {
  991. t.Fatal(err)
  992. }
  993. handleRequest := NewHTTPHandler(nil)
  994. handleRequest(rsp, req)
  995. if rsp.statusCode != http.StatusServiceUnavailable {
  996. t.Fatalf("Expected (%d). Got (%d): %s", http.StatusServiceUnavailable, rsp.statusCode, rsp.body)
  997. }
  998. handleRequest = NewHTTPHandler(c)
  999. handleRequest(rsp, req)
  1000. if rsp.statusCode != http.StatusOK {
  1001. t.Fatalf("Expected (%d). Got: (%d): %s", http.StatusOK, rsp.statusCode, rsp.body)
  1002. }
  1003. var list []*networkResource
  1004. err = json.Unmarshal(rsp.body, &list)
  1005. if err != nil {
  1006. t.Fatal(err)
  1007. }
  1008. if len(list) != 0 {
  1009. t.Fatalf("Expected empty list. Got %v", list)
  1010. }
  1011. n, err := c.NewNetwork(bridgeNetType, "didietro", nil)
  1012. if err != nil {
  1013. t.Fatal(err)
  1014. }
  1015. nwr := buildNetworkResource(n)
  1016. expected, err := json.Marshal([]*networkResource{nwr})
  1017. if err != nil {
  1018. t.Fatal(err)
  1019. }
  1020. handleRequest(rsp, req)
  1021. if rsp.statusCode != http.StatusOK {
  1022. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1023. }
  1024. if len(rsp.body) == 0 {
  1025. t.Fatalf("Empty list of networks")
  1026. }
  1027. if bytes.Equal(rsp.body, expected) {
  1028. t.Fatalf("Incorrect list of networks in response's body")
  1029. }
  1030. }
  1031. func TestHttpHandlerBadBody(t *testing.T) {
  1032. defer netutils.SetupTestNetNS(t)()
  1033. rsp := newWriter()
  1034. c, err := libnetwork.New()
  1035. if err != nil {
  1036. t.Fatal(err)
  1037. }
  1038. handleRequest := NewHTTPHandler(c)
  1039. req, err := http.NewRequest("POST", "/v1.19/networks", &localReader{beBad: true})
  1040. if err != nil {
  1041. t.Fatal(err)
  1042. }
  1043. handleRequest(rsp, req)
  1044. if rsp.statusCode != http.StatusBadRequest {
  1045. t.Fatalf("Unexpected status code. Expected (%d). Got (%d): %s.", http.StatusBadRequest, rsp.statusCode, string(rsp.body))
  1046. }
  1047. body := []byte{}
  1048. lr := newLocalReader(body)
  1049. req, err = http.NewRequest("POST", "/v1.19/networks", lr)
  1050. if err != nil {
  1051. t.Fatal(err)
  1052. }
  1053. handleRequest(rsp, req)
  1054. if rsp.statusCode != http.StatusBadRequest {
  1055. t.Fatalf("Unexpected status code. Expected (%d). Got (%d): %s.", http.StatusBadRequest, rsp.statusCode, string(rsp.body))
  1056. }
  1057. }
  1058. func TestEndToEnd(t *testing.T) {
  1059. defer netutils.SetupTestNetNS(t)()
  1060. rsp := newWriter()
  1061. c, err := libnetwork.New()
  1062. if err != nil {
  1063. t.Fatal(err)
  1064. }
  1065. handleRequest := NewHTTPHandler(c)
  1066. // Create network
  1067. nc := networkCreate{Name: "network-fiftyfive", NetworkType: bridgeNetType}
  1068. body, err := json.Marshal(nc)
  1069. if err != nil {
  1070. t.Fatal(err)
  1071. }
  1072. lr := newLocalReader(body)
  1073. req, err := http.NewRequest("POST", "/v1.19/networks", lr)
  1074. if err != nil {
  1075. t.Fatal(err)
  1076. }
  1077. handleRequest(rsp, req)
  1078. if rsp.statusCode != http.StatusCreated {
  1079. t.Fatalf("Unexpectded status code. Expected (%d). Got (%d): %s.", http.StatusCreated, rsp.statusCode, string(rsp.body))
  1080. }
  1081. if len(rsp.body) == 0 {
  1082. t.Fatalf("Empty response body")
  1083. }
  1084. var nid string
  1085. err = json.Unmarshal(rsp.body, &nid)
  1086. if err != nil {
  1087. t.Fatal(err)
  1088. }
  1089. // Query networks collection
  1090. req, err = http.NewRequest("GET", "/v1.19/networks", nil)
  1091. if err != nil {
  1092. t.Fatal(err)
  1093. }
  1094. handleRequest(rsp, req)
  1095. if rsp.statusCode != http.StatusOK {
  1096. t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
  1097. }
  1098. b0 := make([]byte, len(rsp.body))
  1099. copy(b0, rsp.body)
  1100. req, err = http.NewRequest("GET", "/v1.19/networks?name=network-fiftyfive", nil)
  1101. if err != nil {
  1102. t.Fatal(err)
  1103. }
  1104. handleRequest(rsp, req)
  1105. if rsp.statusCode != http.StatusOK {
  1106. t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
  1107. }
  1108. if !bytes.Equal(b0, rsp.body) {
  1109. t.Fatalf("Expected same body from GET /networks and GET /networks?name=<nw> when only network <nw> exist.")
  1110. }
  1111. // Query network by name
  1112. req, err = http.NewRequest("GET", "/v1.19/networks?name=culo", nil)
  1113. if err != nil {
  1114. t.Fatal(err)
  1115. }
  1116. handleRequest(rsp, req)
  1117. if rsp.statusCode != http.StatusOK {
  1118. t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
  1119. }
  1120. var list []*networkResource
  1121. err = json.Unmarshal(rsp.body, &list)
  1122. if err != nil {
  1123. t.Fatal(err)
  1124. }
  1125. if len(list) != 0 {
  1126. t.Fatalf("Expected empty list. Got %v", list)
  1127. }
  1128. req, err = http.NewRequest("GET", "/v1.19/networks?name=network-fiftyfive", nil)
  1129. if err != nil {
  1130. t.Fatal(err)
  1131. }
  1132. handleRequest(rsp, req)
  1133. if rsp.statusCode != http.StatusOK {
  1134. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1135. }
  1136. err = json.Unmarshal(rsp.body, &list)
  1137. if err != nil {
  1138. t.Fatal(err)
  1139. }
  1140. if len(list) == 0 {
  1141. t.Fatalf("Expected non empty list")
  1142. }
  1143. if list[0].Name != "network-fiftyfive" || nid != list[0].ID {
  1144. t.Fatalf("Incongruent resource found: %v", list[0])
  1145. }
  1146. // Query network by partial id
  1147. chars := []byte(nid)
  1148. partial := string(chars[0 : len(chars)/2])
  1149. req, err = http.NewRequest("GET", "/v1.19/networks?partial-id="+partial, nil)
  1150. if err != nil {
  1151. t.Fatal(err)
  1152. }
  1153. handleRequest(rsp, req)
  1154. if rsp.statusCode != http.StatusOK {
  1155. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1156. }
  1157. err = json.Unmarshal(rsp.body, &list)
  1158. if err != nil {
  1159. t.Fatal(err)
  1160. }
  1161. if len(list) == 0 {
  1162. t.Fatalf("Expected non empty list")
  1163. }
  1164. if list[0].Name != "network-fiftyfive" || nid != list[0].ID {
  1165. t.Fatalf("Incongruent resource found: %v", list[0])
  1166. }
  1167. // Get network by id
  1168. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid, nil)
  1169. if err != nil {
  1170. t.Fatal(err)
  1171. }
  1172. handleRequest(rsp, req)
  1173. if rsp.statusCode != http.StatusOK {
  1174. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1175. }
  1176. var nwr networkResource
  1177. err = json.Unmarshal(rsp.body, &nwr)
  1178. if err != nil {
  1179. t.Fatal(err)
  1180. }
  1181. if nwr.Name != "network-fiftyfive" || nid != nwr.ID {
  1182. t.Fatalf("Incongruent resource found: %v", nwr)
  1183. }
  1184. // Create endpoint
  1185. eb, err := json.Marshal(endpointCreate{Name: "ep-TwentyTwo"})
  1186. if err != nil {
  1187. t.Fatal(err)
  1188. }
  1189. lr = newLocalReader(eb)
  1190. req, err = http.NewRequest("POST", "/v1.19/networks/"+nid+"/endpoints", lr)
  1191. if err != nil {
  1192. t.Fatal(err)
  1193. }
  1194. handleRequest(rsp, req)
  1195. if rsp.statusCode != http.StatusCreated {
  1196. t.Fatalf("Unexpectded status code. Expected (%d). Got (%d): %s.", http.StatusCreated, rsp.statusCode, string(rsp.body))
  1197. }
  1198. if len(rsp.body) == 0 {
  1199. t.Fatalf("Empty response body")
  1200. }
  1201. var eid string
  1202. err = json.Unmarshal(rsp.body, &eid)
  1203. if err != nil {
  1204. t.Fatal(err)
  1205. }
  1206. // Query endpoint(s)
  1207. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints", nil)
  1208. if err != nil {
  1209. t.Fatal(err)
  1210. }
  1211. handleRequest(rsp, req)
  1212. if rsp.statusCode != http.StatusOK {
  1213. t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
  1214. }
  1215. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints?name=bla", nil)
  1216. if err != nil {
  1217. t.Fatal(err)
  1218. }
  1219. handleRequest(rsp, req)
  1220. if rsp.statusCode != http.StatusOK {
  1221. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1222. }
  1223. var epList []*endpointResource
  1224. err = json.Unmarshal(rsp.body, &epList)
  1225. if err != nil {
  1226. t.Fatal(err)
  1227. }
  1228. if len(epList) != 0 {
  1229. t.Fatalf("Expected empty list. Got %v", epList)
  1230. }
  1231. // Query endpoint by name
  1232. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints?name=ep-TwentyTwo", nil)
  1233. if err != nil {
  1234. t.Fatal(err)
  1235. }
  1236. handleRequest(rsp, req)
  1237. if rsp.statusCode != http.StatusOK {
  1238. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1239. }
  1240. err = json.Unmarshal(rsp.body, &epList)
  1241. if err != nil {
  1242. t.Fatal(err)
  1243. }
  1244. if len(epList) == 0 {
  1245. t.Fatalf("Empty response body")
  1246. }
  1247. if epList[0].Name != "ep-TwentyTwo" || eid != epList[0].ID {
  1248. t.Fatalf("Incongruent resource found: %v", epList[0])
  1249. }
  1250. // Query endpoint by partial id
  1251. chars = []byte(eid)
  1252. partial = string(chars[0 : len(chars)/2])
  1253. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints?partial-id="+partial, nil)
  1254. if err != nil {
  1255. t.Fatal(err)
  1256. }
  1257. handleRequest(rsp, req)
  1258. if rsp.statusCode != http.StatusOK {
  1259. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1260. }
  1261. err = json.Unmarshal(rsp.body, &epList)
  1262. if err != nil {
  1263. t.Fatal(err)
  1264. }
  1265. if len(epList) == 0 {
  1266. t.Fatalf("Empty response body")
  1267. }
  1268. if epList[0].Name != "ep-TwentyTwo" || eid != epList[0].ID {
  1269. t.Fatalf("Incongruent resource found: %v", epList[0])
  1270. }
  1271. // Get endpoint by id
  1272. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints/"+eid, nil)
  1273. if err != nil {
  1274. t.Fatal(err)
  1275. }
  1276. handleRequest(rsp, req)
  1277. if rsp.statusCode != http.StatusOK {
  1278. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1279. }
  1280. var epr endpointResource
  1281. err = json.Unmarshal(rsp.body, &epr)
  1282. if err != nil {
  1283. t.Fatal(err)
  1284. }
  1285. if epr.Name != "ep-TwentyTwo" || epr.ID != eid {
  1286. t.Fatalf("Incongruent resource found: %v", epr)
  1287. }
  1288. }
  1289. type bre struct{}
  1290. func (b *bre) Error() string {
  1291. return "I am a bad request error"
  1292. }
  1293. func (b *bre) BadRequest() {}
  1294. type nfe struct{}
  1295. func (n *nfe) Error() string {
  1296. return "I am a not found error"
  1297. }
  1298. func (n *nfe) NotFound() {}
  1299. type forb struct{}
  1300. func (f *forb) Error() string {
  1301. return "I am a bad request error"
  1302. }
  1303. func (f *forb) Forbidden() {}
  1304. type notimpl struct{}
  1305. func (nip *notimpl) Error() string {
  1306. return "I am a not implemented error"
  1307. }
  1308. func (nip *notimpl) NotImplemented() {}
  1309. type inter struct{}
  1310. func (it *inter) Error() string {
  1311. return "I am a internal error"
  1312. }
  1313. func (it *inter) Internal() {}
  1314. type tout struct{}
  1315. func (to *tout) Error() string {
  1316. return "I am a timeout error"
  1317. }
  1318. func (to *tout) Timeout() {}
  1319. type noserv struct{}
  1320. func (nos *noserv) Error() string {
  1321. return "I am a no service error"
  1322. }
  1323. func (nos *noserv) NoService() {}
  1324. type notclassified struct{}
  1325. func (noc *notclassified) Error() string {
  1326. return "I am a non classified error"
  1327. }
  1328. func TestErrorConversion(t *testing.T) {
  1329. if convertNetworkError(new(bre)).StatusCode != http.StatusBadRequest {
  1330. t.Fatalf("Failed to recognize BadRequest error")
  1331. }
  1332. if convertNetworkError(new(nfe)).StatusCode != http.StatusNotFound {
  1333. t.Fatalf("Failed to recognize NotFound error")
  1334. }
  1335. if convertNetworkError(new(forb)).StatusCode != http.StatusForbidden {
  1336. t.Fatalf("Failed to recognize Forbidden error")
  1337. }
  1338. if convertNetworkError(new(notimpl)).StatusCode != http.StatusNotImplemented {
  1339. t.Fatalf("Failed to recognize NotImplemented error")
  1340. }
  1341. if convertNetworkError(new(inter)).StatusCode != http.StatusInternalServerError {
  1342. t.Fatalf("Failed to recognize Internal error")
  1343. }
  1344. if convertNetworkError(new(tout)).StatusCode != http.StatusRequestTimeout {
  1345. t.Fatalf("Failed to recognize Timeout error")
  1346. }
  1347. if convertNetworkError(new(noserv)).StatusCode != http.StatusServiceUnavailable {
  1348. t.Fatalf("Failed to recognize No Service error")
  1349. }
  1350. if convertNetworkError(new(notclassified)).StatusCode != http.StatusInternalServerError {
  1351. t.Fatalf("Failed to recognize not classified error as Internal error")
  1352. }
  1353. }