api_test.go 59 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387
  1. package api
  2. import (
  3. "bytes"
  4. "encoding/json"
  5. "errors"
  6. "fmt"
  7. "io"
  8. "net/http"
  9. "os"
  10. "regexp"
  11. "runtime"
  12. "testing"
  13. "github.com/docker/docker/pkg/reexec"
  14. "github.com/docker/libnetwork"
  15. "github.com/docker/libnetwork/datastore"
  16. "github.com/docker/libnetwork/drivers/bridge"
  17. "github.com/docker/libnetwork/netlabel"
  18. "github.com/docker/libnetwork/options"
  19. "github.com/docker/libnetwork/testutils"
  20. "github.com/docker/libnetwork/types"
  21. )
  22. const (
  23. bridgeNetType = "bridge"
  24. bridgeName = "docker0"
  25. )
  26. func i2s(i interface{}) string {
  27. s, ok := i.(string)
  28. if !ok {
  29. panic(fmt.Sprintf("Failed i2s for %v", i))
  30. }
  31. return s
  32. }
  33. func i2e(i interface{}) *endpointResource {
  34. s, ok := i.(*endpointResource)
  35. if !ok {
  36. panic(fmt.Sprintf("Failed i2e for %v", i))
  37. }
  38. return s
  39. }
  40. func i2eL(i interface{}) []*endpointResource {
  41. s, ok := i.([]*endpointResource)
  42. if !ok {
  43. panic(fmt.Sprintf("Failed i2eL for %v", i))
  44. }
  45. return s
  46. }
  47. func i2n(i interface{}) *networkResource {
  48. s, ok := i.(*networkResource)
  49. if !ok {
  50. panic(fmt.Sprintf("Failed i2n for %v", i))
  51. }
  52. return s
  53. }
  54. func i2nL(i interface{}) []*networkResource {
  55. s, ok := i.([]*networkResource)
  56. if !ok {
  57. panic(fmt.Sprintf("Failed i2nL for %v", i))
  58. }
  59. return s
  60. }
  61. func i2sb(i interface{}) *sandboxResource {
  62. s, ok := i.(*sandboxResource)
  63. if !ok {
  64. panic(fmt.Sprintf("Failed i2sb for %v", i))
  65. }
  66. return s
  67. }
  68. func i2sbL(i interface{}) []*sandboxResource {
  69. s, ok := i.([]*sandboxResource)
  70. if !ok {
  71. panic(fmt.Sprintf("Failed i2sbL for %v", i))
  72. }
  73. return s
  74. }
  75. func createTestNetwork(t *testing.T, network string) (libnetwork.NetworkController, libnetwork.Network) {
  76. // Cleanup local datastore file
  77. os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
  78. c, err := libnetwork.New()
  79. if err != nil {
  80. t.Fatal(err)
  81. }
  82. netOption := options.Generic{
  83. netlabel.GenericData: options.Generic{
  84. "BridgeName": network,
  85. },
  86. }
  87. netGeneric := libnetwork.NetworkOptionGeneric(netOption)
  88. nw, err := c.NewNetwork(bridgeNetType, network, netGeneric)
  89. if err != nil {
  90. t.Fatal(err)
  91. }
  92. return c, nw
  93. }
  94. func getExposedPorts() []types.TransportPort {
  95. return []types.TransportPort{
  96. types.TransportPort{Proto: types.TCP, Port: uint16(5000)},
  97. types.TransportPort{Proto: types.UDP, Port: uint16(400)},
  98. types.TransportPort{Proto: types.TCP, Port: uint16(600)},
  99. }
  100. }
  101. func getPortMapping() []types.PortBinding {
  102. return []types.PortBinding{
  103. types.PortBinding{Proto: types.TCP, Port: uint16(230), HostPort: uint16(23000)},
  104. types.PortBinding{Proto: types.UDP, Port: uint16(200), HostPort: uint16(22000)},
  105. types.PortBinding{Proto: types.TCP, Port: uint16(120), HostPort: uint16(12000)},
  106. }
  107. }
  108. func TestMain(m *testing.M) {
  109. if reexec.Init() {
  110. return
  111. }
  112. os.Exit(m.Run())
  113. }
  114. func TestSandboxOptionParser(t *testing.T) {
  115. hn := "host1"
  116. dn := "docker.com"
  117. hp := "/etc/hosts"
  118. rc := "/etc/resolv.conf"
  119. dnss := []string{"8.8.8.8", "172.28.34.5"}
  120. ehs := []extraHost{extraHost{Name: "extra1", Address: "172.28.9.1"}, extraHost{Name: "extra2", Address: "172.28.9.2"}}
  121. sb := sandboxCreate{
  122. HostName: hn,
  123. DomainName: dn,
  124. HostsPath: hp,
  125. ResolvConfPath: rc,
  126. DNS: dnss,
  127. ExtraHosts: ehs,
  128. UseDefaultSandbox: true,
  129. }
  130. if len(sb.parseOptions()) != 9 {
  131. t.Fatalf("Failed to generate all libnetwork.SandboxOption methods")
  132. }
  133. }
  134. func TestJson(t *testing.T) {
  135. nc := networkCreate{NetworkType: bridgeNetType}
  136. b, err := json.Marshal(nc)
  137. if err != nil {
  138. t.Fatal(err)
  139. }
  140. var ncp networkCreate
  141. err = json.Unmarshal(b, &ncp)
  142. if err != nil {
  143. t.Fatal(err)
  144. }
  145. if nc.NetworkType != ncp.NetworkType {
  146. t.Fatalf("Incorrect networkCreate after json encoding/deconding: %v", ncp)
  147. }
  148. jl := endpointJoin{SandboxID: "abcdef456789"}
  149. b, err = json.Marshal(jl)
  150. if err != nil {
  151. t.Fatal(err)
  152. }
  153. var jld endpointJoin
  154. err = json.Unmarshal(b, &jld)
  155. if err != nil {
  156. t.Fatal(err)
  157. }
  158. if jl.SandboxID != jld.SandboxID {
  159. t.Fatalf("Incorrect endpointJoin after json encoding/deconding: %v", jld)
  160. }
  161. }
  162. func TestCreateDeleteNetwork(t *testing.T) {
  163. defer testutils.SetupTestOSContext(t)()
  164. // Cleanup local datastore file
  165. os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
  166. c, err := libnetwork.New()
  167. if err != nil {
  168. t.Fatal(err)
  169. }
  170. defer c.Stop()
  171. badBody, err := json.Marshal("bad body")
  172. if err != nil {
  173. t.Fatal(err)
  174. }
  175. vars := make(map[string]string)
  176. _, errRsp := procCreateNetwork(c, nil, badBody)
  177. if errRsp == &createdResponse {
  178. t.Fatalf("Expected to fail but succeeded")
  179. }
  180. if errRsp.StatusCode != http.StatusBadRequest {
  181. t.Fatalf("Expected StatusBadRequest status code, got: %v", errRsp)
  182. }
  183. incompleteBody, err := json.Marshal(networkCreate{})
  184. if err != nil {
  185. t.Fatal(err)
  186. }
  187. _, errRsp = procCreateNetwork(c, vars, incompleteBody)
  188. if errRsp == &createdResponse {
  189. t.Fatalf("Expected to fail but succeeded")
  190. }
  191. if errRsp.StatusCode != http.StatusBadRequest {
  192. t.Fatalf("Expected StatusBadRequest status code, got: %v", errRsp)
  193. }
  194. dops := map[string]string{
  195. bridge.BridgeName: "abc",
  196. }
  197. nops := map[string]string{
  198. netlabel.EnableIPv6: "true",
  199. }
  200. nc := networkCreate{Name: "network_1", NetworkType: bridgeNetType, DriverOpts: dops, NetworkOpts: nops}
  201. goodBody, err := json.Marshal(nc)
  202. if err != nil {
  203. t.Fatal(err)
  204. }
  205. _, errRsp = procCreateNetwork(c, vars, goodBody)
  206. if errRsp != &createdResponse {
  207. t.Fatalf("Unexepected failure: %v", errRsp)
  208. }
  209. vars[urlNwName] = ""
  210. _, errRsp = procDeleteNetwork(c, vars, nil)
  211. if errRsp == &successResponse {
  212. t.Fatalf("Expected to fail but succeeded")
  213. }
  214. vars[urlNwName] = "abc"
  215. _, errRsp = procDeleteNetwork(c, vars, nil)
  216. if errRsp == &successResponse {
  217. t.Fatalf("Expected to fail but succeeded")
  218. }
  219. vars[urlNwName] = "network_1"
  220. _, errRsp = procDeleteNetwork(c, vars, nil)
  221. if errRsp != &successResponse {
  222. t.Fatalf("Unexepected failure: %v", errRsp)
  223. }
  224. }
  225. func TestGetNetworksAndEndpoints(t *testing.T) {
  226. defer testutils.SetupTestOSContext(t)()
  227. // Cleanup local datastore file
  228. os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
  229. c, err := libnetwork.New()
  230. if err != nil {
  231. t.Fatal(err)
  232. }
  233. defer c.Stop()
  234. ops := map[string]string{
  235. bridge.BridgeName: "api_test_nw",
  236. }
  237. nc := networkCreate{Name: "sh", NetworkType: bridgeNetType, DriverOpts: ops}
  238. body, err := json.Marshal(nc)
  239. if err != nil {
  240. t.Fatal(err)
  241. }
  242. vars := make(map[string]string)
  243. inid, errRsp := procCreateNetwork(c, vars, body)
  244. if errRsp != &createdResponse {
  245. t.Fatalf("Unexepected failure: %v", errRsp)
  246. }
  247. nid, ok := inid.(string)
  248. if !ok {
  249. t.FailNow()
  250. }
  251. ec1 := endpointCreate{
  252. Name: "ep1",
  253. ExposedPorts: getExposedPorts(),
  254. PortMapping: getPortMapping(),
  255. }
  256. b1, err := json.Marshal(ec1)
  257. if err != nil {
  258. t.Fatal(err)
  259. }
  260. ec2 := endpointCreate{Name: "ep2"}
  261. b2, err := json.Marshal(ec2)
  262. if err != nil {
  263. t.Fatal(err)
  264. }
  265. vars[urlNwName] = "sh"
  266. vars[urlEpName] = "ep1"
  267. ieid1, errRsp := procCreateEndpoint(c, vars, b1)
  268. if errRsp != &createdResponse {
  269. t.Fatalf("Unexepected failure: %v", errRsp)
  270. }
  271. eid1 := i2s(ieid1)
  272. vars[urlEpName] = "ep2"
  273. ieid2, errRsp := procCreateEndpoint(c, vars, b2)
  274. if errRsp != &createdResponse {
  275. t.Fatalf("Unexepected failure: %v", errRsp)
  276. }
  277. eid2 := i2s(ieid2)
  278. vars[urlNwName] = ""
  279. vars[urlEpName] = "ep1"
  280. _, errRsp = procGetEndpoint(c, vars, nil)
  281. if errRsp == &successResponse {
  282. t.Fatalf("Expected failure but succeeded: %v", errRsp)
  283. }
  284. if errRsp.StatusCode != http.StatusBadRequest {
  285. t.Fatalf("Expected to fail with http.StatusBadRequest, but got: %d", errRsp.StatusCode)
  286. }
  287. vars = make(map[string]string)
  288. vars[urlNwName] = "sh"
  289. vars[urlEpID] = ""
  290. _, errRsp = procGetEndpoint(c, vars, nil)
  291. if errRsp == &successResponse {
  292. t.Fatalf("Expected failure but succeeded: %v", errRsp)
  293. }
  294. if errRsp.StatusCode != http.StatusBadRequest {
  295. t.Fatalf("Expected to fail with http.StatusBadRequest, but got: %d", errRsp.StatusCode)
  296. }
  297. vars = make(map[string]string)
  298. vars[urlNwID] = ""
  299. vars[urlEpID] = eid1
  300. _, errRsp = procGetEndpoint(c, vars, nil)
  301. if errRsp == &successResponse {
  302. t.Fatalf("Expected failure but succeeded: %v", errRsp)
  303. }
  304. if errRsp.StatusCode != http.StatusBadRequest {
  305. t.Fatalf("Expected to fail with http.StatusBadRequest, but got: %d", errRsp.StatusCode)
  306. }
  307. // nw by name and ep by id
  308. vars[urlNwName] = "sh"
  309. i1, errRsp := procGetEndpoint(c, vars, nil)
  310. if errRsp != &successResponse {
  311. t.Fatalf("Unexepected failure: %v", errRsp)
  312. }
  313. // nw by name and ep by name
  314. delete(vars, urlEpID)
  315. vars[urlEpName] = "ep1"
  316. i2, errRsp := procGetEndpoint(c, vars, nil)
  317. if errRsp != &successResponse {
  318. t.Fatalf("Unexepected failure: %v", errRsp)
  319. }
  320. // nw by id and ep by name
  321. delete(vars, urlNwName)
  322. vars[urlNwID] = nid
  323. i3, errRsp := procGetEndpoint(c, vars, nil)
  324. if errRsp != &successResponse {
  325. t.Fatalf("Unexepected failure: %v", errRsp)
  326. }
  327. // nw by id and ep by id
  328. delete(vars, urlEpName)
  329. vars[urlEpID] = eid1
  330. i4, errRsp := procGetEndpoint(c, vars, nil)
  331. if errRsp != &successResponse {
  332. t.Fatalf("Unexepected failure: %v", errRsp)
  333. }
  334. id1 := i2e(i1).ID
  335. if id1 != i2e(i2).ID || id1 != i2e(i3).ID || id1 != i2e(i4).ID {
  336. t.Fatalf("Endpoints retireved via different query parameters differ: %v, %v, %v, %v", i1, i2, i3, i4)
  337. }
  338. vars[urlNwName] = ""
  339. _, errRsp = procGetEndpoints(c, vars, nil)
  340. if errRsp == &successResponse {
  341. t.Fatalf("Expected failure, got: %v", errRsp)
  342. }
  343. delete(vars, urlNwName)
  344. vars[urlNwID] = "fakeID"
  345. _, errRsp = procGetEndpoints(c, vars, nil)
  346. if errRsp == &successResponse {
  347. t.Fatalf("Expected failure, got: %v", errRsp)
  348. }
  349. vars[urlNwID] = nid
  350. _, errRsp = procGetEndpoints(c, vars, nil)
  351. if errRsp != &successResponse {
  352. t.Fatalf("Unexepected failure: %v", errRsp)
  353. }
  354. vars[urlNwName] = "sh"
  355. iepList, errRsp := procGetEndpoints(c, vars, nil)
  356. if errRsp != &successResponse {
  357. t.Fatalf("Unexepected failure: %v", errRsp)
  358. }
  359. epList := i2eL(iepList)
  360. if len(epList) != 2 {
  361. t.Fatalf("Did not return the expected number (2) of endpoint resources: %d", len(epList))
  362. }
  363. if "sh" != epList[0].Network || "sh" != epList[1].Network {
  364. t.Fatalf("Did not find expected network name in endpoint resources")
  365. }
  366. vars = make(map[string]string)
  367. vars[urlNwName] = ""
  368. _, errRsp = procGetNetwork(c, vars, nil)
  369. if errRsp == &successResponse {
  370. t.Fatalf("Exepected failure, got: %v", errRsp)
  371. }
  372. vars[urlNwName] = "shhhhh"
  373. _, errRsp = procGetNetwork(c, vars, nil)
  374. if errRsp == &successResponse {
  375. t.Fatalf("Exepected failure, got: %v", errRsp)
  376. }
  377. vars[urlNwName] = "sh"
  378. inr1, errRsp := procGetNetwork(c, vars, nil)
  379. if errRsp != &successResponse {
  380. t.Fatalf("Unexepected failure: %v", errRsp)
  381. }
  382. nr1 := i2n(inr1)
  383. delete(vars, urlNwName)
  384. vars[urlNwID] = "acacac"
  385. _, errRsp = procGetNetwork(c, vars, nil)
  386. if errRsp == &successResponse {
  387. t.Fatalf("Expected failure. Got: %v", errRsp)
  388. }
  389. vars[urlNwID] = nid
  390. inr2, errRsp := procGetNetwork(c, vars, nil)
  391. if errRsp != &successResponse {
  392. t.Fatalf("procgetNetworkByName() != procgetNetworkById(), %v vs %v", inr1, inr2)
  393. }
  394. nr2 := i2n(inr2)
  395. if nr1.Name != nr2.Name || nr1.Type != nr2.Type || nr1.ID != nr2.ID || len(nr1.Endpoints) != len(nr2.Endpoints) {
  396. t.Fatalf("Get by name and Get failure: %v", errRsp)
  397. }
  398. if len(nr1.Endpoints) != 2 {
  399. t.Fatalf("Did not find the expected number (2) of endpoint resources in the network resource: %d", len(nr1.Endpoints))
  400. }
  401. for _, er := range nr1.Endpoints {
  402. if er.ID != eid1 && er.ID != eid2 {
  403. t.Fatalf("Did not find the expected endpoint resources in the network resource: %v", nr1.Endpoints)
  404. }
  405. }
  406. iList, errRsp := procGetNetworks(c, nil, nil)
  407. if errRsp != &successResponse {
  408. t.Fatalf("Unexepected failure: %v", errRsp)
  409. }
  410. netList := i2nL(iList)
  411. if len(netList) != 1 {
  412. t.Fatalf("Did not return the expected number of network resources")
  413. }
  414. if nid != netList[0].ID {
  415. t.Fatalf("Did not find expected network %s: %v", nid, netList)
  416. }
  417. _, errRsp = procDeleteNetwork(c, vars, nil)
  418. if errRsp == &successResponse {
  419. t.Fatalf("Exepected failure, got: %v", errRsp)
  420. }
  421. vars[urlEpName] = "ep1"
  422. _, errRsp = procDeleteEndpoint(c, vars, nil)
  423. if errRsp != &successResponse {
  424. t.Fatalf("Unexepected failure: %v", errRsp)
  425. }
  426. delete(vars, urlEpName)
  427. iepList, errRsp = procGetEndpoints(c, vars, nil)
  428. if errRsp != &successResponse {
  429. t.Fatalf("Unexepected failure: %v", errRsp)
  430. }
  431. epList = i2eL(iepList)
  432. if len(epList) != 1 {
  433. t.Fatalf("Did not return the expected number (1) of endpoint resources: %d", len(epList))
  434. }
  435. vars[urlEpName] = "ep2"
  436. _, errRsp = procDeleteEndpoint(c, vars, nil)
  437. if errRsp != &successResponse {
  438. t.Fatalf("Unexepected failure: %v", errRsp)
  439. }
  440. iepList, errRsp = procGetEndpoints(c, vars, nil)
  441. if errRsp != &successResponse {
  442. t.Fatalf("Unexepected failure: %v", errRsp)
  443. }
  444. epList = i2eL(iepList)
  445. if len(epList) != 0 {
  446. t.Fatalf("Did not return the expected number (0) of endpoint resources: %d", len(epList))
  447. }
  448. _, errRsp = procDeleteNetwork(c, vars, nil)
  449. if errRsp != &successResponse {
  450. t.Fatalf("Unexepected failure: %v", errRsp)
  451. }
  452. iList, errRsp = procGetNetworks(c, nil, nil)
  453. if errRsp != &successResponse {
  454. t.Fatalf("Unexepected failure: %v", errRsp)
  455. }
  456. netList = i2nL(iList)
  457. if len(netList) != 0 {
  458. t.Fatalf("Did not return the expected number of network resources")
  459. }
  460. }
  461. func TestProcGetServices(t *testing.T) {
  462. defer testutils.SetupTestOSContext(t)()
  463. // Cleanup local datastore file
  464. os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
  465. c, err := libnetwork.New()
  466. if err != nil {
  467. t.Fatal(err)
  468. }
  469. defer c.Stop()
  470. // Create 2 networks
  471. netName1 := "production"
  472. netOption := options.Generic{
  473. netlabel.GenericData: options.Generic{
  474. "BridgeName": netName1,
  475. },
  476. }
  477. nw1, err := c.NewNetwork(bridgeNetType, netName1, libnetwork.NetworkOptionGeneric(netOption))
  478. if err != nil {
  479. t.Fatal(err)
  480. }
  481. netName2 := "work-dev"
  482. netOption = options.Generic{
  483. netlabel.GenericData: options.Generic{
  484. "BridgeName": netName2,
  485. },
  486. }
  487. nw2, err := c.NewNetwork(bridgeNetType, netName2, libnetwork.NetworkOptionGeneric(netOption))
  488. if err != nil {
  489. t.Fatal(err)
  490. }
  491. vars := make(map[string]string)
  492. li, errRsp := procGetServices(c, vars, nil)
  493. if !errRsp.isOK() {
  494. t.Fatalf("Unexpected failure: %v", errRsp)
  495. }
  496. list := i2eL(li)
  497. if len(list) != 0 {
  498. t.Fatalf("Unexpected services in response: %v", list)
  499. }
  500. // Add a couple of services on one network and one on the other network
  501. ep11, err := nw1.CreateEndpoint("db-prod")
  502. if err != nil {
  503. t.Fatal(err)
  504. }
  505. ep12, err := nw1.CreateEndpoint("web-prod")
  506. if err != nil {
  507. t.Fatal(err)
  508. }
  509. ep21, err := nw2.CreateEndpoint("db-dev")
  510. if err != nil {
  511. t.Fatal(err)
  512. }
  513. li, errRsp = procGetServices(c, vars, nil)
  514. if !errRsp.isOK() {
  515. t.Fatalf("Unexpected failure: %v", errRsp)
  516. }
  517. list = i2eL(li)
  518. if len(list) != 3 {
  519. t.Fatalf("Unexpected services in response: %v", list)
  520. }
  521. // Filter by network
  522. vars[urlNwName] = netName1
  523. li, errRsp = procGetServices(c, vars, nil)
  524. if !errRsp.isOK() {
  525. t.Fatalf("Unexpected failure: %v", errRsp)
  526. }
  527. list = i2eL(li)
  528. if len(list) != 2 {
  529. t.Fatalf("Unexpected services in response: %v", list)
  530. }
  531. vars[urlNwName] = netName2
  532. li, errRsp = procGetServices(c, vars, nil)
  533. if !errRsp.isOK() {
  534. t.Fatalf("Unexpected failure: %v", errRsp)
  535. }
  536. list = i2eL(li)
  537. if len(list) != 1 {
  538. t.Fatalf("Unexpected services in response: %v", list)
  539. }
  540. vars[urlNwName] = "unknown-network"
  541. li, errRsp = procGetServices(c, vars, nil)
  542. if !errRsp.isOK() {
  543. t.Fatalf("Unexpected failure: %v", errRsp)
  544. }
  545. list = i2eL(li)
  546. if len(list) != 0 {
  547. t.Fatalf("Unexpected services in response: %v", list)
  548. }
  549. // Query by name
  550. delete(vars, urlNwName)
  551. vars[urlEpName] = "db-prod"
  552. li, errRsp = procGetServices(c, vars, nil)
  553. if !errRsp.isOK() {
  554. t.Fatalf("Unexpected failure: %v", errRsp)
  555. }
  556. list = i2eL(li)
  557. if len(list) != 1 {
  558. t.Fatalf("Unexpected services in response: %v", list)
  559. }
  560. vars[urlEpName] = "no-service"
  561. li, errRsp = procGetServices(c, vars, nil)
  562. if !errRsp.isOK() {
  563. t.Fatalf("Unexpected failure: %v", errRsp)
  564. }
  565. list = i2eL(li)
  566. if len(list) != 0 {
  567. t.Fatalf("Unexpected services in response: %v", list)
  568. }
  569. // Query by id or partial id
  570. delete(vars, urlEpName)
  571. vars[urlEpPID] = ep12.ID()
  572. li, errRsp = procGetServices(c, vars, nil)
  573. if !errRsp.isOK() {
  574. t.Fatalf("Unexpected failure: %v", errRsp)
  575. }
  576. list = i2eL(li)
  577. if len(list) != 1 {
  578. t.Fatalf("Unexpected services in response: %v", list)
  579. }
  580. if list[0].ID != ep12.ID() {
  581. t.Fatalf("Unexpected element in response: %v", list)
  582. }
  583. vars[urlEpPID] = "non-id"
  584. li, errRsp = procGetServices(c, vars, nil)
  585. if !errRsp.isOK() {
  586. t.Fatalf("Unexpected failure: %v", errRsp)
  587. }
  588. list = i2eL(li)
  589. if len(list) != 0 {
  590. t.Fatalf("Unexpected services in response: %v", list)
  591. }
  592. delete(vars, urlEpPID)
  593. err = ep11.Delete(false)
  594. if err != nil {
  595. t.Fatal(err)
  596. }
  597. err = ep12.Delete(false)
  598. if err != nil {
  599. t.Fatal(err)
  600. }
  601. err = ep21.Delete(false)
  602. if err != nil {
  603. t.Fatal(err)
  604. }
  605. li, errRsp = procGetServices(c, vars, nil)
  606. if !errRsp.isOK() {
  607. t.Fatalf("Unexpected failure: %v", errRsp)
  608. }
  609. list = i2eL(li)
  610. if len(list) != 0 {
  611. t.Fatalf("Unexpected services in response: %v", list)
  612. }
  613. }
  614. func TestProcGetService(t *testing.T) {
  615. defer testutils.SetupTestOSContext(t)()
  616. c, nw := createTestNetwork(t, "network")
  617. defer c.Stop()
  618. ep1, err := nw.CreateEndpoint("db")
  619. if err != nil {
  620. t.Fatal(err)
  621. }
  622. ep2, err := nw.CreateEndpoint("web")
  623. if err != nil {
  624. t.Fatal(err)
  625. }
  626. vars := map[string]string{urlEpID: ""}
  627. _, errRsp := procGetService(c, vars, nil)
  628. if errRsp.isOK() {
  629. t.Fatalf("Expected failure, but suceeded")
  630. }
  631. if errRsp.StatusCode != http.StatusBadRequest {
  632. t.Fatalf("Expected %d, but got: %d", http.StatusBadRequest, errRsp.StatusCode)
  633. }
  634. vars[urlEpID] = "unknown-service-id"
  635. _, errRsp = procGetService(c, vars, nil)
  636. if errRsp.isOK() {
  637. t.Fatalf("Expected failure, but suceeded")
  638. }
  639. if errRsp.StatusCode != http.StatusNotFound {
  640. t.Fatalf("Expected %d, but got: %d. (%v)", http.StatusNotFound, errRsp.StatusCode, errRsp)
  641. }
  642. vars[urlEpID] = ep1.ID()
  643. si, errRsp := procGetService(c, vars, nil)
  644. if !errRsp.isOK() {
  645. t.Fatalf("Unexpected failure: %v", errRsp)
  646. }
  647. sv := i2e(si)
  648. if sv.ID != ep1.ID() {
  649. t.Fatalf("Unexpected service resource returned: %v", sv)
  650. }
  651. vars[urlEpID] = ep2.ID()
  652. si, errRsp = procGetService(c, vars, nil)
  653. if !errRsp.isOK() {
  654. t.Fatalf("Unexpected failure: %v", errRsp)
  655. }
  656. sv = i2e(si)
  657. if sv.ID != ep2.ID() {
  658. t.Fatalf("Unexpected service resource returned: %v", sv)
  659. }
  660. }
  661. func TestProcPublishUnpublishService(t *testing.T) {
  662. defer testutils.SetupTestOSContext(t)()
  663. c, _ := createTestNetwork(t, "network")
  664. defer c.Stop()
  665. vars := make(map[string]string)
  666. vbad, err := json.Marshal("bad service create data")
  667. if err != nil {
  668. t.Fatal(err)
  669. }
  670. _, errRsp := procPublishService(c, vars, vbad)
  671. if errRsp == &createdResponse {
  672. t.Fatalf("Expected to fail but succeeded")
  673. }
  674. if errRsp.StatusCode != http.StatusBadRequest {
  675. t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
  676. }
  677. b, err := json.Marshal(servicePublish{Name: ""})
  678. if err != nil {
  679. t.Fatal(err)
  680. }
  681. _, errRsp = procPublishService(c, vars, b)
  682. if errRsp == &createdResponse {
  683. t.Fatalf("Expected to fail but succeeded")
  684. }
  685. if errRsp.StatusCode != http.StatusBadRequest {
  686. t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
  687. }
  688. b, err = json.Marshal(servicePublish{Name: "db"})
  689. if err != nil {
  690. t.Fatal(err)
  691. }
  692. _, errRsp = procPublishService(c, vars, b)
  693. if errRsp == &createdResponse {
  694. t.Fatalf("Expected to fail but succeeded")
  695. }
  696. if errRsp.StatusCode != http.StatusBadRequest {
  697. t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
  698. }
  699. b, err = json.Marshal(servicePublish{Name: "db", Network: "unknown-network"})
  700. if err != nil {
  701. t.Fatal(err)
  702. }
  703. _, errRsp = procPublishService(c, vars, b)
  704. if errRsp == &createdResponse {
  705. t.Fatalf("Expected to fail but succeeded")
  706. }
  707. if errRsp.StatusCode != http.StatusNotFound {
  708. t.Fatalf("Expected %d. Got: %v", http.StatusNotFound, errRsp)
  709. }
  710. b, err = json.Marshal(servicePublish{Name: "", Network: "network"})
  711. if err != nil {
  712. t.Fatal(err)
  713. }
  714. _, errRsp = procPublishService(c, vars, b)
  715. if errRsp == &createdResponse {
  716. t.Fatalf("Expected to fail but succeeded")
  717. }
  718. if errRsp.StatusCode != http.StatusBadRequest {
  719. t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
  720. }
  721. b, err = json.Marshal(servicePublish{Name: "db", Network: "network"})
  722. if err != nil {
  723. t.Fatal(err)
  724. }
  725. _, errRsp = procPublishService(c, vars, b)
  726. if errRsp != &createdResponse {
  727. t.Fatalf("Unexpected failure: %v", errRsp)
  728. }
  729. sp := servicePublish{
  730. Name: "web",
  731. Network: "network",
  732. ExposedPorts: getExposedPorts(),
  733. PortMapping: getPortMapping(),
  734. }
  735. b, err = json.Marshal(sp)
  736. if err != nil {
  737. t.Fatal(err)
  738. }
  739. si, errRsp := procPublishService(c, vars, b)
  740. if errRsp != &createdResponse {
  741. t.Fatalf("Unexpected failure: %v", errRsp)
  742. }
  743. sid := i2s(si)
  744. vars[urlEpID] = ""
  745. _, errRsp = procUnpublishService(c, vars, nil)
  746. if errRsp.isOK() {
  747. t.Fatalf("Expected failure but succeeded")
  748. }
  749. if errRsp.StatusCode != http.StatusBadRequest {
  750. t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
  751. }
  752. vars[urlEpID] = "unknown-service-id"
  753. _, errRsp = procUnpublishService(c, vars, nil)
  754. if errRsp.isOK() {
  755. t.Fatalf("Expected failure but succeeded")
  756. }
  757. if errRsp.StatusCode != http.StatusNotFound {
  758. t.Fatalf("Expected %d. Got: %v", http.StatusNotFound, errRsp)
  759. }
  760. vars[urlEpID] = sid
  761. _, errRsp = procUnpublishService(c, vars, nil)
  762. if !errRsp.isOK() {
  763. t.Fatalf("Unexpected failure: %v", errRsp)
  764. }
  765. _, errRsp = procGetService(c, vars, nil)
  766. if errRsp.isOK() {
  767. t.Fatalf("Expected failure, but suceeded")
  768. }
  769. if errRsp.StatusCode != http.StatusNotFound {
  770. t.Fatalf("Expected %d, but got: %d. (%v)", http.StatusNotFound, errRsp.StatusCode, errRsp)
  771. }
  772. }
  773. func TestAttachDetachBackend(t *testing.T) {
  774. defer testutils.SetupTestOSContext(t)()
  775. c, nw := createTestNetwork(t, "network")
  776. defer c.Stop()
  777. ep1, err := nw.CreateEndpoint("db")
  778. if err != nil {
  779. t.Fatal(err)
  780. }
  781. vars := make(map[string]string)
  782. vbad, err := json.Marshal("bad data")
  783. if err != nil {
  784. t.Fatal(err)
  785. }
  786. _, errRsp := procAttachBackend(c, vars, vbad)
  787. if errRsp == &successResponse {
  788. t.Fatalf("Expected failure, got: %v", errRsp)
  789. }
  790. vars[urlEpName] = "endpoint"
  791. bad, err := json.Marshal(endpointJoin{})
  792. if err != nil {
  793. t.Fatal(err)
  794. }
  795. _, errRsp = procAttachBackend(c, vars, bad)
  796. if errRsp == &successResponse {
  797. t.Fatalf("Expected failure, got: %v", errRsp)
  798. }
  799. if errRsp.StatusCode != http.StatusNotFound {
  800. t.Fatalf("Expected %d. Got: %v", http.StatusNotFound, errRsp)
  801. }
  802. vars[urlEpID] = "db"
  803. _, errRsp = procGetSandbox(c, vars, nil)
  804. if errRsp.isOK() {
  805. t.Fatalf("Expected failure. Got %v", errRsp)
  806. }
  807. if errRsp.StatusCode != http.StatusNotFound {
  808. t.Fatalf("Expected %d. Got: %v", http.StatusNotFound, errRsp)
  809. }
  810. vars[urlEpName] = "db"
  811. _, errRsp = procAttachBackend(c, vars, bad)
  812. if errRsp == &successResponse {
  813. t.Fatalf("Expected failure, got: %v", errRsp)
  814. }
  815. if errRsp.StatusCode != http.StatusBadRequest {
  816. t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
  817. }
  818. cid := "abcdefghi"
  819. sbox, err := c.NewSandbox(cid)
  820. sid := sbox.ID()
  821. defer sbox.Delete()
  822. jl := endpointJoin{SandboxID: sid}
  823. jlb, err := json.Marshal(jl)
  824. if err != nil {
  825. t.Fatal(err)
  826. }
  827. _, errRsp = procAttachBackend(c, vars, jlb)
  828. if errRsp != &successResponse {
  829. t.Fatalf("Unexpected failure, got: %v", errRsp)
  830. }
  831. sli, errRsp := procGetSandboxes(c, vars, nil)
  832. if errRsp != &successResponse {
  833. t.Fatalf("Unexpected failure, got: %v", errRsp)
  834. }
  835. sl := i2sbL(sli)
  836. if len(sl) != 1 {
  837. t.Fatalf("Did not find expected number of sandboxes attached to the service: %d", len(sl))
  838. }
  839. if sl[0].ContainerID != cid {
  840. t.Fatalf("Did not find expected sandbox attached to the service: %v", sl[0])
  841. }
  842. _, errRsp = procUnpublishService(c, vars, nil)
  843. if errRsp.isOK() {
  844. t.Fatalf("Expected failure but succeeded")
  845. }
  846. if errRsp.StatusCode != http.StatusForbidden {
  847. t.Fatalf("Expected %d. Got: %v", http.StatusForbidden, errRsp)
  848. }
  849. vars[urlEpName] = "endpoint"
  850. _, errRsp = procDetachBackend(c, vars, nil)
  851. if errRsp == &successResponse {
  852. t.Fatalf("Expected failure, got: %v", errRsp)
  853. }
  854. if errRsp.StatusCode != http.StatusNotFound {
  855. t.Fatalf("Expected %d. Got: %v", http.StatusNotFound, errRsp)
  856. }
  857. vars[urlEpName] = "db"
  858. _, errRsp = procDetachBackend(c, vars, nil)
  859. if errRsp == &successResponse {
  860. t.Fatalf("Expected failure, got: %v", errRsp)
  861. }
  862. if errRsp.StatusCode != http.StatusBadRequest {
  863. t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
  864. }
  865. vars[urlSbID] = sid
  866. _, errRsp = procDetachBackend(c, vars, nil)
  867. if errRsp != &successResponse {
  868. t.Fatalf("Unexpected failure, got: %v", errRsp)
  869. }
  870. delete(vars, urlEpID)
  871. si, errRsp := procGetSandbox(c, vars, nil)
  872. if errRsp != &successResponse {
  873. t.Fatalf("Unexpected failure, got: %v", errRsp)
  874. }
  875. sb := i2sb(si)
  876. if sb.ContainerID != cid {
  877. t.Fatalf("Did not find expected sandbox. Got %v", sb)
  878. }
  879. err = ep1.Delete(false)
  880. if err != nil {
  881. t.Fatal(err)
  882. }
  883. }
  884. func TestDetectGetNetworksInvalidQueryComposition(t *testing.T) {
  885. // Cleanup local datastore file
  886. os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
  887. c, err := libnetwork.New()
  888. if err != nil {
  889. t.Fatal(err)
  890. }
  891. defer c.Stop()
  892. vars := map[string]string{urlNwName: "x", urlNwPID: "y"}
  893. _, errRsp := procGetNetworks(c, vars, nil)
  894. if errRsp.StatusCode != http.StatusBadRequest {
  895. t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
  896. }
  897. }
  898. func TestDetectGetEndpointsInvalidQueryComposition(t *testing.T) {
  899. defer testutils.SetupTestOSContext(t)()
  900. c, _ := createTestNetwork(t, "network")
  901. defer c.Stop()
  902. vars := map[string]string{urlNwName: "network", urlEpName: "x", urlEpPID: "y"}
  903. _, errRsp := procGetEndpoints(c, vars, nil)
  904. if errRsp.StatusCode != http.StatusBadRequest {
  905. t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
  906. }
  907. }
  908. func TestDetectGetServicesInvalidQueryComposition(t *testing.T) {
  909. defer testutils.SetupTestOSContext(t)()
  910. c, _ := createTestNetwork(t, "network")
  911. defer c.Stop()
  912. vars := map[string]string{urlNwName: "network", urlEpName: "x", urlEpPID: "y"}
  913. _, errRsp := procGetServices(c, vars, nil)
  914. if errRsp.StatusCode != http.StatusBadRequest {
  915. t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
  916. }
  917. }
  918. func TestFindNetworkUtilPanic(t *testing.T) {
  919. defer checkPanic(t)
  920. findNetwork(nil, "", -1)
  921. }
  922. func TestFindNetworkUtil(t *testing.T) {
  923. defer testutils.SetupTestOSContext(t)()
  924. c, nw := createTestNetwork(t, "network")
  925. defer c.Stop()
  926. nid := nw.ID()
  927. _, errRsp := findNetwork(c, "", byName)
  928. if errRsp == &successResponse {
  929. t.Fatalf("Expected to fail but succeeded")
  930. }
  931. if errRsp.StatusCode != http.StatusBadRequest {
  932. t.Fatalf("Expected %d, but got: %d", http.StatusBadRequest, errRsp.StatusCode)
  933. }
  934. n, errRsp := findNetwork(c, nid, byID)
  935. if errRsp != &successResponse {
  936. t.Fatalf("Unexpected failure: %v", errRsp)
  937. }
  938. if n == nil {
  939. t.Fatalf("Unexpected nil libnetwork.Network")
  940. }
  941. if nid != n.ID() {
  942. t.Fatalf("Incorrect libnetwork.Network resource. It has different id: %v", n)
  943. }
  944. if "network" != n.Name() {
  945. t.Fatalf("Incorrect libnetwork.Network resource. It has different name: %v", n)
  946. }
  947. n, errRsp = findNetwork(c, "network", byName)
  948. if errRsp != &successResponse {
  949. t.Fatalf("Unexpected failure: %v", errRsp)
  950. }
  951. if n == nil {
  952. t.Fatalf("Unexpected nil libnetwork.Network")
  953. }
  954. if nid != n.ID() {
  955. t.Fatalf("Incorrect libnetwork.Network resource. It has different id: %v", n)
  956. }
  957. if "network" != n.Name() {
  958. t.Fatalf("Incorrect libnetwork.Network resource. It has different name: %v", n)
  959. }
  960. if err := n.Delete(); err != nil {
  961. t.Fatalf("Failed to delete the network: %s", err.Error())
  962. }
  963. _, errRsp = findNetwork(c, nid, byID)
  964. if errRsp == &successResponse {
  965. t.Fatalf("Expected to fail but succeeded")
  966. }
  967. if errRsp.StatusCode != http.StatusNotFound {
  968. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  969. }
  970. _, errRsp = findNetwork(c, "network", byName)
  971. if errRsp == &successResponse {
  972. t.Fatalf("Expected to fail but succeeded")
  973. }
  974. if errRsp.StatusCode != http.StatusNotFound {
  975. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  976. }
  977. }
  978. func TestCreateDeleteEndpoints(t *testing.T) {
  979. defer testutils.SetupTestOSContext(t)()
  980. // Cleanup local datastore file
  981. os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
  982. c, err := libnetwork.New()
  983. if err != nil {
  984. t.Fatal(err)
  985. }
  986. defer c.Stop()
  987. nc := networkCreate{Name: "firstNet", NetworkType: bridgeNetType}
  988. body, err := json.Marshal(nc)
  989. if err != nil {
  990. t.Fatal(err)
  991. }
  992. vars := make(map[string]string)
  993. i, errRsp := procCreateNetwork(c, vars, body)
  994. if errRsp != &createdResponse {
  995. t.Fatalf("Unexepected failure: %v", errRsp)
  996. }
  997. nid := i2s(i)
  998. vbad, err := json.Marshal("bad endppoint create data")
  999. if err != nil {
  1000. t.Fatal(err)
  1001. }
  1002. vars[urlNwName] = "firstNet"
  1003. _, errRsp = procCreateEndpoint(c, vars, vbad)
  1004. if errRsp == &createdResponse {
  1005. t.Fatalf("Expected to fail but succeeded")
  1006. }
  1007. b, err := json.Marshal(endpointCreate{Name: ""})
  1008. if err != nil {
  1009. t.Fatal(err)
  1010. }
  1011. vars[urlNwName] = "secondNet"
  1012. _, errRsp = procCreateEndpoint(c, vars, b)
  1013. if errRsp == &createdResponse {
  1014. t.Fatalf("Expected to fail but succeeded")
  1015. }
  1016. vars[urlNwName] = "firstNet"
  1017. _, errRsp = procCreateEndpoint(c, vars, b)
  1018. if errRsp == &successResponse {
  1019. t.Fatalf("Expected failure but succeeded: %v", errRsp)
  1020. }
  1021. b, err = json.Marshal(endpointCreate{Name: "firstEp"})
  1022. if err != nil {
  1023. t.Fatal(err)
  1024. }
  1025. i, errRsp = procCreateEndpoint(c, vars, b)
  1026. if errRsp != &createdResponse {
  1027. t.Fatalf("Unexepected failure: %v", errRsp)
  1028. }
  1029. eid := i2s(i)
  1030. _, errRsp = findEndpoint(c, "myNet", "firstEp", byName, byName)
  1031. if errRsp == &successResponse {
  1032. t.Fatalf("Expected failure but succeeded: %v", errRsp)
  1033. }
  1034. ep0, errRsp := findEndpoint(c, nid, "firstEp", byID, byName)
  1035. if errRsp != &successResponse {
  1036. t.Fatalf("Unexepected failure: %v", errRsp)
  1037. }
  1038. ep1, errRsp := findEndpoint(c, "firstNet", "firstEp", byName, byName)
  1039. if errRsp != &successResponse {
  1040. t.Fatalf("Unexepected failure: %v", errRsp)
  1041. }
  1042. ep2, errRsp := findEndpoint(c, nid, eid, byID, byID)
  1043. if errRsp != &successResponse {
  1044. t.Fatalf("Unexepected failure: %v", errRsp)
  1045. }
  1046. ep3, errRsp := findEndpoint(c, "firstNet", eid, byName, byID)
  1047. if errRsp != &successResponse {
  1048. t.Fatalf("Unexepected failure: %v", errRsp)
  1049. }
  1050. if ep0.ID() != ep1.ID() || ep0.ID() != ep2.ID() || ep0.ID() != ep3.ID() {
  1051. t.Fatalf("Diffenrent queries returned different endpoints: \nep0: %v\nep1: %v\nep2: %v\nep3: %v", ep0, ep1, ep2, ep3)
  1052. }
  1053. vars = make(map[string]string)
  1054. vars[urlNwName] = ""
  1055. vars[urlEpName] = "ep1"
  1056. _, errRsp = procDeleteEndpoint(c, vars, nil)
  1057. if errRsp == &successResponse {
  1058. t.Fatalf("Expected failure, got: %v", errRsp)
  1059. }
  1060. vars[urlNwName] = "firstNet"
  1061. vars[urlEpName] = ""
  1062. _, errRsp = procDeleteEndpoint(c, vars, nil)
  1063. if errRsp == &successResponse {
  1064. t.Fatalf("Expected failure, got: %v", errRsp)
  1065. }
  1066. vars[urlEpName] = "ep2"
  1067. _, errRsp = procDeleteEndpoint(c, vars, nil)
  1068. if errRsp == &successResponse {
  1069. t.Fatalf("Expected failure, got: %v", errRsp)
  1070. }
  1071. vars[urlEpName] = "firstEp"
  1072. _, errRsp = procDeleteEndpoint(c, vars, nil)
  1073. if errRsp != &successResponse {
  1074. t.Fatalf("Unexepected failure: %v", errRsp)
  1075. }
  1076. _, errRsp = findEndpoint(c, "firstNet", "firstEp", byName, byName)
  1077. if errRsp == &successResponse {
  1078. t.Fatalf("Expected failure, got: %v", errRsp)
  1079. }
  1080. }
  1081. func TestJoinLeave(t *testing.T) {
  1082. defer testutils.SetupTestOSContext(t)()
  1083. // Cleanup local datastore file
  1084. os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
  1085. c, err := libnetwork.New()
  1086. if err != nil {
  1087. t.Fatal(err)
  1088. }
  1089. defer c.Stop()
  1090. nb, err := json.Marshal(networkCreate{Name: "network", NetworkType: bridgeNetType})
  1091. if err != nil {
  1092. t.Fatal(err)
  1093. }
  1094. vars := make(map[string]string)
  1095. _, errRsp := procCreateNetwork(c, vars, nb)
  1096. if errRsp != &createdResponse {
  1097. t.Fatalf("Unexepected failure: %v", errRsp)
  1098. }
  1099. eb, err := json.Marshal(endpointCreate{Name: "endpoint"})
  1100. if err != nil {
  1101. t.Fatal(err)
  1102. }
  1103. vars[urlNwName] = "network"
  1104. _, errRsp = procCreateEndpoint(c, vars, eb)
  1105. if errRsp != &createdResponse {
  1106. t.Fatalf("Unexepected failure: %v", errRsp)
  1107. }
  1108. vbad, err := json.Marshal("bad data")
  1109. if err != nil {
  1110. t.Fatal(err)
  1111. }
  1112. _, errRsp = procJoinEndpoint(c, vars, vbad)
  1113. if errRsp == &successResponse {
  1114. t.Fatalf("Expected failure, got: %v", errRsp)
  1115. }
  1116. vars[urlEpName] = "endpoint"
  1117. bad, err := json.Marshal(endpointJoin{})
  1118. if err != nil {
  1119. t.Fatal(err)
  1120. }
  1121. _, errRsp = procJoinEndpoint(c, vars, bad)
  1122. if errRsp == &successResponse {
  1123. t.Fatalf("Expected failure, got: %v", errRsp)
  1124. }
  1125. cid := "abcdefghi"
  1126. sb, err := c.NewSandbox(cid)
  1127. defer sb.Delete()
  1128. jl := endpointJoin{SandboxID: sb.ID()}
  1129. jlb, err := json.Marshal(jl)
  1130. if err != nil {
  1131. t.Fatal(err)
  1132. }
  1133. vars = make(map[string]string)
  1134. vars[urlNwName] = ""
  1135. vars[urlEpName] = ""
  1136. _, errRsp = procJoinEndpoint(c, vars, jlb)
  1137. if errRsp == &successResponse {
  1138. t.Fatalf("Expected failure, got: %v", errRsp)
  1139. }
  1140. vars[urlNwName] = "network"
  1141. vars[urlEpName] = ""
  1142. _, errRsp = procJoinEndpoint(c, vars, jlb)
  1143. if errRsp == &successResponse {
  1144. t.Fatalf("Expected failure, got: %v", errRsp)
  1145. }
  1146. vars[urlEpName] = "epoint"
  1147. _, errRsp = procJoinEndpoint(c, vars, jlb)
  1148. if errRsp == &successResponse {
  1149. t.Fatalf("Expected failure, got: %v", errRsp)
  1150. }
  1151. // bad labels
  1152. vars[urlEpName] = "endpoint"
  1153. key, errRsp := procJoinEndpoint(c, vars, jlb)
  1154. if errRsp != &successResponse {
  1155. t.Fatalf("Unexepected failure, got: %v", errRsp)
  1156. }
  1157. keyStr := i2s(key)
  1158. if keyStr == "" {
  1159. t.Fatalf("Empty sandbox key")
  1160. }
  1161. _, errRsp = procDeleteEndpoint(c, vars, nil)
  1162. if errRsp == &successResponse {
  1163. t.Fatalf("Expected failure, got: %v", errRsp)
  1164. }
  1165. vars[urlNwName] = "network2"
  1166. _, errRsp = procLeaveEndpoint(c, vars, vbad)
  1167. if errRsp == &successResponse {
  1168. t.Fatalf("Expected failure, got: %v", errRsp)
  1169. }
  1170. _, errRsp = procLeaveEndpoint(c, vars, bad)
  1171. if errRsp == &successResponse {
  1172. t.Fatalf("Expected failure, got: %v", errRsp)
  1173. }
  1174. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  1175. if errRsp == &successResponse {
  1176. t.Fatalf("Expected failure, got: %v", errRsp)
  1177. }
  1178. vars = make(map[string]string)
  1179. vars[urlNwName] = ""
  1180. vars[urlEpName] = ""
  1181. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  1182. if errRsp == &successResponse {
  1183. t.Fatalf("Expected failure, got: %v", errRsp)
  1184. }
  1185. vars[urlNwName] = "network"
  1186. vars[urlEpName] = ""
  1187. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  1188. if errRsp == &successResponse {
  1189. t.Fatalf("Expected failure, got: %v", errRsp)
  1190. }
  1191. vars[urlEpName] = "2epoint"
  1192. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  1193. if errRsp == &successResponse {
  1194. t.Fatalf("Expected failure, got: %v", errRsp)
  1195. }
  1196. vars[urlEpName] = "epoint"
  1197. vars[urlCnID] = "who"
  1198. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  1199. if errRsp == &successResponse {
  1200. t.Fatalf("Expected failure, got: %v", errRsp)
  1201. }
  1202. delete(vars, urlCnID)
  1203. vars[urlEpName] = "endpoint"
  1204. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  1205. if errRsp == &successResponse {
  1206. t.Fatalf("Expected failure, got: %v", errRsp)
  1207. }
  1208. vars[urlSbID] = sb.ID()
  1209. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  1210. if errRsp != &successResponse {
  1211. t.Fatalf("Unexepected failure: %v", errRsp)
  1212. }
  1213. _, errRsp = procLeaveEndpoint(c, vars, jlb)
  1214. if errRsp == &successResponse {
  1215. t.Fatalf("Expected failure, got: %v", errRsp)
  1216. }
  1217. _, errRsp = procDeleteEndpoint(c, vars, nil)
  1218. if errRsp != &successResponse {
  1219. t.Fatalf("Unexepected failure: %v", errRsp)
  1220. }
  1221. }
  1222. func TestFindEndpointUtilPanic(t *testing.T) {
  1223. defer testutils.SetupTestOSContext(t)()
  1224. defer checkPanic(t)
  1225. c, nw := createTestNetwork(t, "network")
  1226. defer c.Stop()
  1227. nid := nw.ID()
  1228. findEndpoint(c, nid, "", byID, -1)
  1229. }
  1230. func TestFindServiceUtilPanic(t *testing.T) {
  1231. defer testutils.SetupTestOSContext(t)()
  1232. defer checkPanic(t)
  1233. c, _ := createTestNetwork(t, "network")
  1234. defer c.Stop()
  1235. findService(c, "random_service", -1)
  1236. }
  1237. func TestFindEndpointUtil(t *testing.T) {
  1238. defer testutils.SetupTestOSContext(t)()
  1239. c, nw := createTestNetwork(t, "network")
  1240. defer c.Stop()
  1241. nid := nw.ID()
  1242. ep, err := nw.CreateEndpoint("secondEp", nil)
  1243. if err != nil {
  1244. t.Fatal(err)
  1245. }
  1246. eid := ep.ID()
  1247. _, errRsp := findEndpoint(c, nid, "", byID, byName)
  1248. if errRsp == &successResponse {
  1249. t.Fatalf("Expected failure, but got: %v", errRsp)
  1250. }
  1251. if errRsp.StatusCode != http.StatusBadRequest {
  1252. t.Fatalf("Expected %d, but got: %d", http.StatusBadRequest, errRsp.StatusCode)
  1253. }
  1254. ep0, errRsp := findEndpoint(c, nid, "secondEp", byID, byName)
  1255. if errRsp != &successResponse {
  1256. t.Fatalf("Unexepected failure: %v", errRsp)
  1257. }
  1258. ep1, errRsp := findEndpoint(c, "network", "secondEp", byName, byName)
  1259. if errRsp != &successResponse {
  1260. t.Fatalf("Unexepected failure: %v", errRsp)
  1261. }
  1262. ep2, errRsp := findEndpoint(c, nid, eid, byID, byID)
  1263. if errRsp != &successResponse {
  1264. t.Fatalf("Unexepected failure: %v", errRsp)
  1265. }
  1266. ep3, errRsp := findEndpoint(c, "network", eid, byName, byID)
  1267. if errRsp != &successResponse {
  1268. t.Fatalf("Unexepected failure: %v", errRsp)
  1269. }
  1270. ep4, errRsp := findService(c, "secondEp", byName)
  1271. if errRsp != &successResponse {
  1272. t.Fatalf("Unexepected failure: %v", errRsp)
  1273. }
  1274. ep5, errRsp := findService(c, eid, byID)
  1275. if errRsp != &successResponse {
  1276. t.Fatalf("Unexepected failure: %v", errRsp)
  1277. }
  1278. if ep0.ID() != ep1.ID() || ep0.ID() != ep2.ID() ||
  1279. ep0.ID() != ep3.ID() || ep0.ID() != ep4.ID() || ep0.ID() != ep5.ID() {
  1280. t.Fatalf("Diffenrent queries returned different endpoints")
  1281. }
  1282. ep.Delete(false)
  1283. _, errRsp = findEndpoint(c, nid, "secondEp", byID, byName)
  1284. if errRsp == &successResponse {
  1285. t.Fatalf("Expected failure, but got: %v", errRsp)
  1286. }
  1287. if errRsp.StatusCode != http.StatusNotFound {
  1288. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  1289. }
  1290. _, errRsp = findEndpoint(c, "network", "secondEp", byName, byName)
  1291. if errRsp == &successResponse {
  1292. t.Fatalf("Expected failure, but got: %v", errRsp)
  1293. }
  1294. if errRsp.StatusCode != http.StatusNotFound {
  1295. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  1296. }
  1297. _, errRsp = findEndpoint(c, nid, eid, byID, byID)
  1298. if errRsp == &successResponse {
  1299. t.Fatalf("Expected failure, but got: %v", errRsp)
  1300. }
  1301. if errRsp.StatusCode != http.StatusNotFound {
  1302. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  1303. }
  1304. _, errRsp = findEndpoint(c, "network", eid, byName, byID)
  1305. if errRsp == &successResponse {
  1306. t.Fatalf("Expected failure, but got: %v", errRsp)
  1307. }
  1308. if errRsp.StatusCode != http.StatusNotFound {
  1309. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  1310. }
  1311. _, errRsp = findService(c, "secondEp", byName)
  1312. if errRsp == &successResponse {
  1313. t.Fatalf("Expected failure, but got: %v", errRsp)
  1314. }
  1315. if errRsp.StatusCode != http.StatusNotFound {
  1316. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  1317. }
  1318. _, errRsp = findService(c, eid, byID)
  1319. if errRsp == &successResponse {
  1320. t.Fatalf("Expected failure, but got: %v", errRsp)
  1321. }
  1322. if errRsp.StatusCode != http.StatusNotFound {
  1323. t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
  1324. }
  1325. }
  1326. func TestEndpointToService(t *testing.T) {
  1327. r := &responseStatus{Status: "this is one endpoint", StatusCode: http.StatusOK}
  1328. r = endpointToService(r)
  1329. if r.Status != "this is one service" {
  1330. t.Fatalf("endpointToService returned unexpected status string: %s", r.Status)
  1331. }
  1332. r = &responseStatus{Status: "this is one network", StatusCode: http.StatusOK}
  1333. r = endpointToService(r)
  1334. if r.Status != "this is one network" {
  1335. t.Fatalf("endpointToService returned unexpected status string: %s", r.Status)
  1336. }
  1337. }
  1338. func checkPanic(t *testing.T) {
  1339. if r := recover(); r != nil {
  1340. if _, ok := r.(runtime.Error); ok {
  1341. panic(r)
  1342. }
  1343. } else {
  1344. t.Fatalf("Expected to panic, but suceeded")
  1345. }
  1346. }
  1347. func TestDetectNetworkTargetPanic(t *testing.T) {
  1348. defer checkPanic(t)
  1349. vars := make(map[string]string)
  1350. detectNetworkTarget(vars)
  1351. }
  1352. func TestDetectEndpointTargetPanic(t *testing.T) {
  1353. defer checkPanic(t)
  1354. vars := make(map[string]string)
  1355. detectEndpointTarget(vars)
  1356. }
  1357. func TestResponseStatus(t *testing.T) {
  1358. list := []int{
  1359. http.StatusBadGateway,
  1360. http.StatusBadRequest,
  1361. http.StatusConflict,
  1362. http.StatusContinue,
  1363. http.StatusExpectationFailed,
  1364. http.StatusForbidden,
  1365. http.StatusFound,
  1366. http.StatusGatewayTimeout,
  1367. http.StatusGone,
  1368. http.StatusHTTPVersionNotSupported,
  1369. http.StatusInternalServerError,
  1370. http.StatusLengthRequired,
  1371. http.StatusMethodNotAllowed,
  1372. http.StatusMovedPermanently,
  1373. http.StatusMultipleChoices,
  1374. http.StatusNoContent,
  1375. http.StatusNonAuthoritativeInfo,
  1376. http.StatusNotAcceptable,
  1377. http.StatusNotFound,
  1378. http.StatusNotModified,
  1379. http.StatusPartialContent,
  1380. http.StatusPaymentRequired,
  1381. http.StatusPreconditionFailed,
  1382. http.StatusProxyAuthRequired,
  1383. http.StatusRequestEntityTooLarge,
  1384. http.StatusRequestTimeout,
  1385. http.StatusRequestURITooLong,
  1386. http.StatusRequestedRangeNotSatisfiable,
  1387. http.StatusResetContent,
  1388. http.StatusServiceUnavailable,
  1389. http.StatusSwitchingProtocols,
  1390. http.StatusTemporaryRedirect,
  1391. http.StatusUnauthorized,
  1392. http.StatusUnsupportedMediaType,
  1393. http.StatusUseProxy,
  1394. }
  1395. for _, c := range list {
  1396. r := responseStatus{StatusCode: c}
  1397. if r.isOK() {
  1398. t.Fatalf("isOK() returned true for code% d", c)
  1399. }
  1400. }
  1401. r := responseStatus{StatusCode: http.StatusOK}
  1402. if !r.isOK() {
  1403. t.Fatalf("isOK() failed")
  1404. }
  1405. r = responseStatus{StatusCode: http.StatusCreated}
  1406. if !r.isOK() {
  1407. t.Fatalf("isOK() failed")
  1408. }
  1409. }
  1410. // Local structs for end to end testing of api.go
  1411. type localReader struct {
  1412. data []byte
  1413. beBad bool
  1414. }
  1415. func newLocalReader(data []byte) *localReader {
  1416. lr := &localReader{data: make([]byte, len(data))}
  1417. copy(lr.data, data)
  1418. return lr
  1419. }
  1420. func (l *localReader) Read(p []byte) (n int, err error) {
  1421. if l.beBad {
  1422. return 0, errors.New("I am a bad reader")
  1423. }
  1424. if p == nil {
  1425. return -1, fmt.Errorf("nil buffer passed")
  1426. }
  1427. if l.data == nil || len(l.data) == 0 {
  1428. return 0, io.EOF
  1429. }
  1430. copy(p[:], l.data[:])
  1431. return len(l.data), io.EOF
  1432. }
  1433. type localResponseWriter struct {
  1434. body []byte
  1435. statusCode int
  1436. }
  1437. func newWriter() *localResponseWriter {
  1438. return &localResponseWriter{}
  1439. }
  1440. func (f *localResponseWriter) Header() http.Header {
  1441. return make(map[string][]string, 0)
  1442. }
  1443. func (f *localResponseWriter) Write(data []byte) (int, error) {
  1444. if data == nil {
  1445. return -1, fmt.Errorf("nil data passed")
  1446. }
  1447. f.body = make([]byte, len(data))
  1448. copy(f.body, data)
  1449. return len(f.body), nil
  1450. }
  1451. func (f *localResponseWriter) WriteHeader(c int) {
  1452. f.statusCode = c
  1453. }
  1454. func TestwriteJSON(t *testing.T) {
  1455. testCode := 55
  1456. testData, err := json.Marshal("test data")
  1457. if err != nil {
  1458. t.Fatal(err)
  1459. }
  1460. rsp := newWriter()
  1461. writeJSON(rsp, testCode, testData)
  1462. if rsp.statusCode != testCode {
  1463. t.Fatalf("writeJSON() failed to set the status code. Expected %d. Got %d", testCode, rsp.statusCode)
  1464. }
  1465. if !bytes.Equal(testData, rsp.body) {
  1466. t.Fatalf("writeJSON() failed to set the body. Expected %s. Got %s", testData, rsp.body)
  1467. }
  1468. }
  1469. func TestHttpHandlerUninit(t *testing.T) {
  1470. defer testutils.SetupTestOSContext(t)()
  1471. // Cleanup local datastore file
  1472. os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
  1473. c, err := libnetwork.New()
  1474. if err != nil {
  1475. t.Fatal(err)
  1476. }
  1477. defer c.Stop()
  1478. h := &httpHandler{c: c}
  1479. h.initRouter()
  1480. if h.r == nil {
  1481. t.Fatalf("initRouter() did not initialize the router")
  1482. }
  1483. rsp := newWriter()
  1484. req, err := http.NewRequest("GET", "/v1.19/networks", nil)
  1485. if err != nil {
  1486. t.Fatal(err)
  1487. }
  1488. handleRequest := NewHTTPHandler(nil)
  1489. handleRequest(rsp, req)
  1490. if rsp.statusCode != http.StatusServiceUnavailable {
  1491. t.Fatalf("Expected (%d). Got (%d): %s", http.StatusServiceUnavailable, rsp.statusCode, rsp.body)
  1492. }
  1493. handleRequest = NewHTTPHandler(c)
  1494. handleRequest(rsp, req)
  1495. if rsp.statusCode != http.StatusOK {
  1496. t.Fatalf("Expected (%d). Got: (%d): %s", http.StatusOK, rsp.statusCode, rsp.body)
  1497. }
  1498. var list []*networkResource
  1499. err = json.Unmarshal(rsp.body, &list)
  1500. if err != nil {
  1501. t.Fatal(err)
  1502. }
  1503. if len(list) != 0 {
  1504. t.Fatalf("Expected empty list. Got %v", list)
  1505. }
  1506. n, err := c.NewNetwork(bridgeNetType, "didietro", nil)
  1507. if err != nil {
  1508. t.Fatal(err)
  1509. }
  1510. nwr := buildNetworkResource(n)
  1511. expected, err := json.Marshal([]*networkResource{nwr})
  1512. if err != nil {
  1513. t.Fatal(err)
  1514. }
  1515. handleRequest(rsp, req)
  1516. if rsp.statusCode != http.StatusOK {
  1517. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1518. }
  1519. if len(rsp.body) == 0 {
  1520. t.Fatalf("Empty list of networks")
  1521. }
  1522. if bytes.Equal(rsp.body, expected) {
  1523. t.Fatalf("Incorrect list of networks in response's body")
  1524. }
  1525. }
  1526. func TestHttpHandlerBadBody(t *testing.T) {
  1527. defer testutils.SetupTestOSContext(t)()
  1528. rsp := newWriter()
  1529. // Cleanup local datastore file
  1530. os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
  1531. c, err := libnetwork.New()
  1532. if err != nil {
  1533. t.Fatal(err)
  1534. }
  1535. defer c.Stop()
  1536. handleRequest := NewHTTPHandler(c)
  1537. req, err := http.NewRequest("POST", "/v1.19/networks", &localReader{beBad: true})
  1538. if err != nil {
  1539. t.Fatal(err)
  1540. }
  1541. handleRequest(rsp, req)
  1542. if rsp.statusCode != http.StatusBadRequest {
  1543. t.Fatalf("Unexpected status code. Expected (%d). Got (%d): %s.", http.StatusBadRequest, rsp.statusCode, string(rsp.body))
  1544. }
  1545. body := []byte{}
  1546. lr := newLocalReader(body)
  1547. req, err = http.NewRequest("POST", "/v1.19/networks", lr)
  1548. if err != nil {
  1549. t.Fatal(err)
  1550. }
  1551. handleRequest(rsp, req)
  1552. if rsp.statusCode != http.StatusBadRequest {
  1553. t.Fatalf("Unexpected status code. Expected (%d). Got (%d): %s.", http.StatusBadRequest, rsp.statusCode, string(rsp.body))
  1554. }
  1555. }
  1556. func TestEndToEnd(t *testing.T) {
  1557. defer testutils.SetupTestOSContext(t)()
  1558. rsp := newWriter()
  1559. // Cleanup local datastore file
  1560. os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
  1561. c, err := libnetwork.New()
  1562. if err != nil {
  1563. t.Fatal(err)
  1564. }
  1565. defer c.Stop()
  1566. handleRequest := NewHTTPHandler(c)
  1567. dops := map[string]string{
  1568. bridge.BridgeName: "cdef",
  1569. netlabel.DriverMTU: "1460",
  1570. }
  1571. nops := map[string]string{
  1572. netlabel.EnableIPv6: "true",
  1573. }
  1574. // Create network
  1575. nc := networkCreate{Name: "network-fiftyfive", NetworkType: bridgeNetType, DriverOpts: dops, NetworkOpts: nops}
  1576. body, err := json.Marshal(nc)
  1577. if err != nil {
  1578. t.Fatal(err)
  1579. }
  1580. lr := newLocalReader(body)
  1581. req, err := http.NewRequest("POST", "/v1.19/networks", lr)
  1582. if err != nil {
  1583. t.Fatal(err)
  1584. }
  1585. handleRequest(rsp, req)
  1586. if rsp.statusCode != http.StatusCreated {
  1587. t.Fatalf("Unexpectded status code. Expected (%d). Got (%d): %s.", http.StatusCreated, rsp.statusCode, string(rsp.body))
  1588. }
  1589. if len(rsp.body) == 0 {
  1590. t.Fatalf("Empty response body")
  1591. }
  1592. var nid string
  1593. err = json.Unmarshal(rsp.body, &nid)
  1594. if err != nil {
  1595. t.Fatal(err)
  1596. }
  1597. // Query networks collection
  1598. req, err = http.NewRequest("GET", "/v1.19/networks?name=", nil)
  1599. if err != nil {
  1600. t.Fatal(err)
  1601. }
  1602. handleRequest(rsp, req)
  1603. if rsp.statusCode != http.StatusOK {
  1604. t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
  1605. }
  1606. var list []*networkResource
  1607. err = json.Unmarshal(rsp.body, &list)
  1608. if err != nil {
  1609. t.Fatal(err)
  1610. }
  1611. if len(list) != 0 {
  1612. t.Fatalf("Expected empty list. Got %v", list)
  1613. }
  1614. req, err = http.NewRequest("GET", "/v1.19/networks", nil)
  1615. if err != nil {
  1616. t.Fatal(err)
  1617. }
  1618. handleRequest(rsp, req)
  1619. if rsp.statusCode != http.StatusOK {
  1620. t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
  1621. }
  1622. b0 := make([]byte, len(rsp.body))
  1623. copy(b0, rsp.body)
  1624. req, err = http.NewRequest("GET", "/v1.19/networks?name=network-fiftyfive", nil)
  1625. if err != nil {
  1626. t.Fatal(err)
  1627. }
  1628. handleRequest(rsp, req)
  1629. if rsp.statusCode != http.StatusOK {
  1630. t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
  1631. }
  1632. if !bytes.Equal(b0, rsp.body) {
  1633. t.Fatalf("Expected same body from GET /networks and GET /networks?name=<nw> when only network <nw> exist.")
  1634. }
  1635. // Query network by name
  1636. req, err = http.NewRequest("GET", "/v1.19/networks?name=culo", nil)
  1637. if err != nil {
  1638. t.Fatal(err)
  1639. }
  1640. handleRequest(rsp, req)
  1641. if rsp.statusCode != http.StatusOK {
  1642. t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
  1643. }
  1644. err = json.Unmarshal(rsp.body, &list)
  1645. if err != nil {
  1646. t.Fatal(err)
  1647. }
  1648. if len(list) != 0 {
  1649. t.Fatalf("Expected empty list. Got %v", list)
  1650. }
  1651. req, err = http.NewRequest("GET", "/v1.19/networks?name=network-fiftyfive", nil)
  1652. if err != nil {
  1653. t.Fatal(err)
  1654. }
  1655. handleRequest(rsp, req)
  1656. if rsp.statusCode != http.StatusOK {
  1657. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1658. }
  1659. err = json.Unmarshal(rsp.body, &list)
  1660. if err != nil {
  1661. t.Fatal(err)
  1662. }
  1663. if len(list) == 0 {
  1664. t.Fatalf("Expected non empty list")
  1665. }
  1666. if list[0].Name != "network-fiftyfive" || nid != list[0].ID {
  1667. t.Fatalf("Incongruent resource found: %v", list[0])
  1668. }
  1669. // Query network by partial id
  1670. chars := []byte(nid)
  1671. partial := string(chars[0 : len(chars)/2])
  1672. req, err = http.NewRequest("GET", "/v1.19/networks?partial-id="+partial, nil)
  1673. if err != nil {
  1674. t.Fatal(err)
  1675. }
  1676. handleRequest(rsp, req)
  1677. if rsp.statusCode != http.StatusOK {
  1678. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1679. }
  1680. err = json.Unmarshal(rsp.body, &list)
  1681. if err != nil {
  1682. t.Fatal(err)
  1683. }
  1684. if len(list) == 0 {
  1685. t.Fatalf("Expected non empty list")
  1686. }
  1687. if list[0].Name != "network-fiftyfive" || nid != list[0].ID {
  1688. t.Fatalf("Incongruent resource found: %v", list[0])
  1689. }
  1690. // Get network by id
  1691. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid, nil)
  1692. if err != nil {
  1693. t.Fatal(err)
  1694. }
  1695. handleRequest(rsp, req)
  1696. if rsp.statusCode != http.StatusOK {
  1697. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1698. }
  1699. var nwr networkResource
  1700. err = json.Unmarshal(rsp.body, &nwr)
  1701. if err != nil {
  1702. t.Fatal(err)
  1703. }
  1704. if nwr.Name != "network-fiftyfive" || nid != nwr.ID {
  1705. t.Fatalf("Incongruent resource found: %v", nwr)
  1706. }
  1707. // Create endpoint
  1708. eb, err := json.Marshal(endpointCreate{Name: "ep-TwentyTwo"})
  1709. if err != nil {
  1710. t.Fatal(err)
  1711. }
  1712. lr = newLocalReader(eb)
  1713. req, err = http.NewRequest("POST", "/v1.19/networks/"+nid+"/endpoints", lr)
  1714. if err != nil {
  1715. t.Fatal(err)
  1716. }
  1717. handleRequest(rsp, req)
  1718. if rsp.statusCode != http.StatusCreated {
  1719. t.Fatalf("Unexpectded status code. Expected (%d). Got (%d): %s.", http.StatusCreated, rsp.statusCode, string(rsp.body))
  1720. }
  1721. if len(rsp.body) == 0 {
  1722. t.Fatalf("Empty response body")
  1723. }
  1724. var eid string
  1725. err = json.Unmarshal(rsp.body, &eid)
  1726. if err != nil {
  1727. t.Fatal(err)
  1728. }
  1729. // Query endpoint(s)
  1730. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints", nil)
  1731. if err != nil {
  1732. t.Fatal(err)
  1733. }
  1734. handleRequest(rsp, req)
  1735. if rsp.statusCode != http.StatusOK {
  1736. t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
  1737. }
  1738. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints?name=bla", nil)
  1739. if err != nil {
  1740. t.Fatal(err)
  1741. }
  1742. handleRequest(rsp, req)
  1743. if rsp.statusCode != http.StatusOK {
  1744. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1745. }
  1746. var epList []*endpointResource
  1747. err = json.Unmarshal(rsp.body, &epList)
  1748. if err != nil {
  1749. t.Fatal(err)
  1750. }
  1751. if len(epList) != 0 {
  1752. t.Fatalf("Expected empty list. Got %v", epList)
  1753. }
  1754. // Query endpoint by name
  1755. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints?name=ep-TwentyTwo", nil)
  1756. if err != nil {
  1757. t.Fatal(err)
  1758. }
  1759. handleRequest(rsp, req)
  1760. if rsp.statusCode != http.StatusOK {
  1761. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1762. }
  1763. err = json.Unmarshal(rsp.body, &epList)
  1764. if err != nil {
  1765. t.Fatal(err)
  1766. }
  1767. if len(epList) == 0 {
  1768. t.Fatalf("Empty response body")
  1769. }
  1770. if epList[0].Name != "ep-TwentyTwo" || eid != epList[0].ID {
  1771. t.Fatalf("Incongruent resource found: %v", epList[0])
  1772. }
  1773. // Query endpoint by partial id
  1774. chars = []byte(eid)
  1775. partial = string(chars[0 : len(chars)/2])
  1776. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints?partial-id="+partial, nil)
  1777. if err != nil {
  1778. t.Fatal(err)
  1779. }
  1780. handleRequest(rsp, req)
  1781. if rsp.statusCode != http.StatusOK {
  1782. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1783. }
  1784. err = json.Unmarshal(rsp.body, &epList)
  1785. if err != nil {
  1786. t.Fatal(err)
  1787. }
  1788. if len(epList) == 0 {
  1789. t.Fatalf("Empty response body")
  1790. }
  1791. if epList[0].Name != "ep-TwentyTwo" || eid != epList[0].ID {
  1792. t.Fatalf("Incongruent resource found: %v", epList[0])
  1793. }
  1794. // Get endpoint by id
  1795. req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints/"+eid, nil)
  1796. if err != nil {
  1797. t.Fatal(err)
  1798. }
  1799. handleRequest(rsp, req)
  1800. if rsp.statusCode != http.StatusOK {
  1801. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1802. }
  1803. var epr endpointResource
  1804. err = json.Unmarshal(rsp.body, &epr)
  1805. if err != nil {
  1806. t.Fatal(err)
  1807. }
  1808. if epr.Name != "ep-TwentyTwo" || epr.ID != eid {
  1809. t.Fatalf("Incongruent resource found: %v", epr)
  1810. }
  1811. // Store two container ids and one partial ids
  1812. cid1 := "container10010000000"
  1813. cid2 := "container20010000000"
  1814. chars = []byte(cid1)
  1815. cpid1 := string(chars[0 : len(chars)/2])
  1816. // Create sandboxes
  1817. sb1, err := json.Marshal(sandboxCreate{ContainerID: cid1})
  1818. if err != nil {
  1819. t.Fatal(err)
  1820. }
  1821. lr = newLocalReader(sb1)
  1822. req, err = http.NewRequest("POST", "/v5.22/sandboxes", lr)
  1823. if err != nil {
  1824. t.Fatal(err)
  1825. }
  1826. handleRequest(rsp, req)
  1827. if rsp.statusCode != http.StatusCreated {
  1828. t.Fatalf("Unexpectded status code. Expected (%d). Got (%d): %s.", http.StatusCreated, rsp.statusCode, string(rsp.body))
  1829. }
  1830. if len(rsp.body) == 0 {
  1831. t.Fatalf("Empty response body")
  1832. }
  1833. // Get sandbox id and partial id
  1834. var sid1 string
  1835. err = json.Unmarshal(rsp.body, &sid1)
  1836. if err != nil {
  1837. t.Fatal(err)
  1838. }
  1839. sb2, err := json.Marshal(sandboxCreate{ContainerID: cid2})
  1840. if err != nil {
  1841. t.Fatal(err)
  1842. }
  1843. lr = newLocalReader(sb2)
  1844. req, err = http.NewRequest("POST", "/v5.22/sandboxes", lr)
  1845. if err != nil {
  1846. t.Fatal(err)
  1847. }
  1848. handleRequest(rsp, req)
  1849. if rsp.statusCode != http.StatusCreated {
  1850. t.Fatalf("Unexpectded status code. Expected (%d). Got (%d): %s.", http.StatusCreated, rsp.statusCode, string(rsp.body))
  1851. }
  1852. if len(rsp.body) == 0 {
  1853. t.Fatalf("Empty response body")
  1854. }
  1855. // Get sandbox id and partial id
  1856. var sid2 string
  1857. err = json.Unmarshal(rsp.body, &sid2)
  1858. if err != nil {
  1859. t.Fatal(err)
  1860. }
  1861. chars = []byte(sid2)
  1862. spid2 := string(chars[0 : len(chars)/2])
  1863. // Query sandboxes
  1864. req, err = http.NewRequest("GET", "/sandboxes", nil)
  1865. if err != nil {
  1866. t.Fatal(err)
  1867. }
  1868. handleRequest(rsp, req)
  1869. if rsp.statusCode != http.StatusOK {
  1870. t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
  1871. }
  1872. var sbList []*sandboxResource
  1873. err = json.Unmarshal(rsp.body, &sbList)
  1874. if err != nil {
  1875. t.Fatal(err)
  1876. }
  1877. if len(sbList) != 2 {
  1878. t.Fatalf("Expected 2 elements in list. Got %v", sbList)
  1879. }
  1880. // Get sandbox by id
  1881. req, err = http.NewRequest("GET", "/sandboxes/"+sid1, nil)
  1882. if err != nil {
  1883. t.Fatal(err)
  1884. }
  1885. handleRequest(rsp, req)
  1886. if rsp.statusCode != http.StatusOK {
  1887. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1888. }
  1889. var sbr sandboxResource
  1890. err = json.Unmarshal(rsp.body, &sbr)
  1891. if err != nil {
  1892. t.Fatal(err)
  1893. }
  1894. if sbr.ContainerID != cid1 {
  1895. t.Fatalf("Incongruent resource found: %v", sbr)
  1896. }
  1897. // Query sandbox by partial sandbox id
  1898. req, err = http.NewRequest("GET", "/sandboxes?partial-id="+spid2, nil)
  1899. if err != nil {
  1900. t.Fatal(err)
  1901. }
  1902. handleRequest(rsp, req)
  1903. if rsp.statusCode != http.StatusOK {
  1904. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1905. }
  1906. err = json.Unmarshal(rsp.body, &sbList)
  1907. if err != nil {
  1908. t.Fatal(err)
  1909. }
  1910. if len(sbList) == 0 {
  1911. t.Fatalf("Empty response body")
  1912. }
  1913. if sbList[0].ID != sid2 {
  1914. t.Fatalf("Incongruent resource found: %v", sbList[0])
  1915. }
  1916. // Query sandbox by container id
  1917. req, err = http.NewRequest("GET", "/sandboxes?container-id="+cid2, nil)
  1918. if err != nil {
  1919. t.Fatal(err)
  1920. }
  1921. handleRequest(rsp, req)
  1922. if rsp.statusCode != http.StatusOK {
  1923. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1924. }
  1925. err = json.Unmarshal(rsp.body, &sbList)
  1926. if err != nil {
  1927. t.Fatal(err)
  1928. }
  1929. if len(sbList) == 0 {
  1930. t.Fatalf("Empty response body")
  1931. }
  1932. if sbList[0].ContainerID != cid2 {
  1933. t.Fatalf("Incongruent resource found: %v", sbList[0])
  1934. }
  1935. // Query sandbox by partial container id
  1936. req, err = http.NewRequest("GET", "/sandboxes?partial-container-id="+cpid1, nil)
  1937. if err != nil {
  1938. t.Fatal(err)
  1939. }
  1940. handleRequest(rsp, req)
  1941. if rsp.statusCode != http.StatusOK {
  1942. t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
  1943. }
  1944. err = json.Unmarshal(rsp.body, &sbList)
  1945. if err != nil {
  1946. t.Fatal(err)
  1947. }
  1948. if len(sbList) == 0 {
  1949. t.Fatalf("Empty response body")
  1950. }
  1951. if sbList[0].ContainerID != cid1 {
  1952. t.Fatalf("Incongruent resource found: %v", sbList[0])
  1953. }
  1954. }
  1955. func TestEndToEndErrorMessage(t *testing.T) {
  1956. defer testutils.SetupTestOSContext(t)()
  1957. rsp := newWriter()
  1958. // Cleanup local datastore file
  1959. os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
  1960. c, err := libnetwork.New()
  1961. if err != nil {
  1962. t.Fatal(err)
  1963. }
  1964. defer c.Stop()
  1965. handleRequest := NewHTTPHandler(c)
  1966. body := []byte{}
  1967. lr := newLocalReader(body)
  1968. req, err := http.NewRequest("POST", "/v1.19/networks", lr)
  1969. if err != nil {
  1970. t.Fatal(err)
  1971. }
  1972. handleRequest(rsp, req)
  1973. if len(rsp.body) == 0 {
  1974. t.Fatalf("Empty response body.")
  1975. }
  1976. empty := []byte("\"\"")
  1977. if bytes.Equal(empty, bytes.TrimSpace(rsp.body)) {
  1978. t.Fatalf("Empty response error message.")
  1979. }
  1980. }
  1981. type bre struct{}
  1982. func (b *bre) Error() string {
  1983. return "I am a bad request error"
  1984. }
  1985. func (b *bre) BadRequest() {}
  1986. type nfe struct{}
  1987. func (n *nfe) Error() string {
  1988. return "I am a not found error"
  1989. }
  1990. func (n *nfe) NotFound() {}
  1991. type forb struct{}
  1992. func (f *forb) Error() string {
  1993. return "I am a bad request error"
  1994. }
  1995. func (f *forb) Forbidden() {}
  1996. type notimpl struct{}
  1997. func (nip *notimpl) Error() string {
  1998. return "I am a not implemented error"
  1999. }
  2000. func (nip *notimpl) NotImplemented() {}
  2001. type inter struct{}
  2002. func (it *inter) Error() string {
  2003. return "I am a internal error"
  2004. }
  2005. func (it *inter) Internal() {}
  2006. type tout struct{}
  2007. func (to *tout) Error() string {
  2008. return "I am a timeout error"
  2009. }
  2010. func (to *tout) Timeout() {}
  2011. type noserv struct{}
  2012. func (nos *noserv) Error() string {
  2013. return "I am a no service error"
  2014. }
  2015. func (nos *noserv) NoService() {}
  2016. type notclassified struct{}
  2017. func (noc *notclassified) Error() string {
  2018. return "I am a non classified error"
  2019. }
  2020. func TestErrorConversion(t *testing.T) {
  2021. if convertNetworkError(new(bre)).StatusCode != http.StatusBadRequest {
  2022. t.Fatalf("Failed to recognize BadRequest error")
  2023. }
  2024. if convertNetworkError(new(nfe)).StatusCode != http.StatusNotFound {
  2025. t.Fatalf("Failed to recognize NotFound error")
  2026. }
  2027. if convertNetworkError(new(forb)).StatusCode != http.StatusForbidden {
  2028. t.Fatalf("Failed to recognize Forbidden error")
  2029. }
  2030. if convertNetworkError(new(notimpl)).StatusCode != http.StatusNotImplemented {
  2031. t.Fatalf("Failed to recognize NotImplemented error")
  2032. }
  2033. if convertNetworkError(new(inter)).StatusCode != http.StatusInternalServerError {
  2034. t.Fatalf("Failed to recognize Internal error")
  2035. }
  2036. if convertNetworkError(new(tout)).StatusCode != http.StatusRequestTimeout {
  2037. t.Fatalf("Failed to recognize Timeout error")
  2038. }
  2039. if convertNetworkError(new(noserv)).StatusCode != http.StatusServiceUnavailable {
  2040. t.Fatalf("Failed to recognize No Service error")
  2041. }
  2042. if convertNetworkError(new(notclassified)).StatusCode != http.StatusInternalServerError {
  2043. t.Fatalf("Failed to recognize not classified error as Internal error")
  2044. }
  2045. }
  2046. func TestFieldRegex(t *testing.T) {
  2047. pr := regexp.MustCompile(regex)
  2048. qr := regexp.MustCompile(`^` + qregx + `$`) // mux compiles it like this
  2049. if pr.MatchString("") {
  2050. t.Fatalf("Unexpected match")
  2051. }
  2052. if !qr.MatchString("") {
  2053. t.Fatalf("Unexpected match failure")
  2054. }
  2055. if pr.MatchString(":") {
  2056. t.Fatalf("Unexpected match")
  2057. }
  2058. if qr.MatchString(":") {
  2059. t.Fatalf("Unexpected match")
  2060. }
  2061. if pr.MatchString(".") {
  2062. t.Fatalf("Unexpected match")
  2063. }
  2064. if qr.MatchString(".") {
  2065. t.Fatalf("Unexpected match")
  2066. }
  2067. }