libnetwork_test.go 29 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358
  1. package libnetwork_test
  2. import (
  3. "fmt"
  4. "io/ioutil"
  5. "net"
  6. "net/http"
  7. "net/http/httptest"
  8. "os"
  9. "sync"
  10. "testing"
  11. log "github.com/Sirupsen/logrus"
  12. "github.com/docker/docker/pkg/plugins"
  13. "github.com/docker/docker/pkg/reexec"
  14. "github.com/docker/libnetwork"
  15. "github.com/docker/libnetwork/config"
  16. "github.com/docker/libnetwork/datastore"
  17. "github.com/docker/libnetwork/driverapi"
  18. "github.com/docker/libnetwork/ipamapi"
  19. "github.com/docker/libnetwork/netlabel"
  20. "github.com/docker/libnetwork/options"
  21. "github.com/docker/libnetwork/testutils"
  22. "github.com/docker/libnetwork/types"
  23. "github.com/vishvananda/netns"
  24. )
  25. const (
  26. bridgeNetType = "bridge"
  27. )
  28. var controller libnetwork.NetworkController
  29. func TestMain(m *testing.M) {
  30. if reexec.Init() {
  31. return
  32. }
  33. if err := createController(); err != nil {
  34. log.Errorf("Error creating controller: %v", err)
  35. os.Exit(1)
  36. }
  37. x := m.Run()
  38. controller.Stop()
  39. os.Exit(x)
  40. }
  41. func createController() error {
  42. var err error
  43. // Cleanup local datastore file
  44. os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
  45. option := options.Generic{
  46. "EnableIPForwarding": true,
  47. }
  48. genericOption := make(map[string]interface{})
  49. genericOption[netlabel.GenericData] = option
  50. cfgOptions, err := libnetwork.OptionBoltdbWithRandomDBFile()
  51. if err != nil {
  52. return err
  53. }
  54. controller, err = libnetwork.New(append(cfgOptions, config.OptionDriverConfig(bridgeNetType, genericOption))...)
  55. if err != nil {
  56. return err
  57. }
  58. return nil
  59. }
  60. func createTestNetwork(networkType, networkName string, netOption options.Generic, ipamV4Configs, ipamV6Configs []*libnetwork.IpamConf) (libnetwork.Network, error) {
  61. return controller.NewNetwork(networkType, networkName, "",
  62. libnetwork.NetworkOptionGeneric(netOption),
  63. libnetwork.NetworkOptionIpam(ipamapi.DefaultIPAM, "", ipamV4Configs, ipamV6Configs, nil))
  64. }
  65. func getEmptyGenericOption() map[string]interface{} {
  66. genericOption := make(map[string]interface{})
  67. genericOption[netlabel.GenericData] = options.Generic{}
  68. return genericOption
  69. }
  70. func getPortMapping() []types.PortBinding {
  71. return []types.PortBinding{
  72. {Proto: types.TCP, Port: uint16(230), HostPort: uint16(23000)},
  73. {Proto: types.UDP, Port: uint16(200), HostPort: uint16(22000)},
  74. {Proto: types.TCP, Port: uint16(120), HostPort: uint16(12000)},
  75. {Proto: types.TCP, Port: uint16(320), HostPort: uint16(32000), HostPortEnd: uint16(32999)},
  76. {Proto: types.UDP, Port: uint16(420), HostPort: uint16(42000), HostPortEnd: uint16(42001)},
  77. }
  78. }
  79. func TestNull(t *testing.T) {
  80. cnt, err := controller.NewSandbox("null_container",
  81. libnetwork.OptionHostname("test"),
  82. libnetwork.OptionDomainname("docker.io"),
  83. libnetwork.OptionExtraHost("web", "192.168.0.1"))
  84. if err != nil {
  85. t.Fatal(err)
  86. }
  87. network, err := createTestNetwork("null", "testnull", options.Generic{}, nil, nil)
  88. if err != nil {
  89. t.Fatal(err)
  90. }
  91. ep, err := network.CreateEndpoint("testep")
  92. if err != nil {
  93. t.Fatal(err)
  94. }
  95. err = ep.Join(cnt)
  96. if err != nil {
  97. t.Fatal(err)
  98. }
  99. err = ep.Leave(cnt)
  100. if err != nil {
  101. t.Fatal(err)
  102. }
  103. if err := ep.Delete(false); err != nil {
  104. t.Fatal(err)
  105. }
  106. if err := cnt.Delete(); err != nil {
  107. t.Fatal(err)
  108. }
  109. // host type is special network. Cannot be removed.
  110. err = network.Delete()
  111. if err == nil {
  112. t.Fatal(err)
  113. }
  114. if _, ok := err.(types.ForbiddenError); !ok {
  115. t.Fatalf("Unexpected error type")
  116. }
  117. }
  118. func TestBridge(t *testing.T) {
  119. if !testutils.IsRunningInContainer() {
  120. defer testutils.SetupTestOSContext(t)()
  121. }
  122. netOption := options.Generic{
  123. netlabel.EnableIPv6: true,
  124. netlabel.GenericData: options.Generic{
  125. "BridgeName": "testnetwork",
  126. "EnableICC": true,
  127. "EnableIPMasquerade": true,
  128. },
  129. }
  130. ipamV4ConfList := []*libnetwork.IpamConf{{PreferredPool: "192.168.100.0/24", Gateway: "192.168.100.1"}}
  131. ipamV6ConfList := []*libnetwork.IpamConf{{PreferredPool: "fe90::/64", Gateway: "fe90::22"}}
  132. network, err := createTestNetwork(bridgeNetType, "testnetwork", netOption, ipamV4ConfList, ipamV6ConfList)
  133. if err != nil {
  134. t.Fatal(err)
  135. }
  136. defer func() {
  137. if err := network.Delete(); err != nil {
  138. t.Fatal(err)
  139. }
  140. }()
  141. ep, err := network.CreateEndpoint("testep")
  142. if err != nil {
  143. t.Fatal(err)
  144. }
  145. sb, err := controller.NewSandbox(containerID, libnetwork.OptionPortMapping(getPortMapping()))
  146. if err != nil {
  147. t.Fatal(err)
  148. }
  149. defer func() {
  150. if err := sb.Delete(); err != nil {
  151. t.Fatal(err)
  152. }
  153. }()
  154. err = ep.Join(sb)
  155. if err != nil {
  156. t.Fatal(err)
  157. }
  158. epInfo, err := ep.DriverInfo()
  159. if err != nil {
  160. t.Fatal(err)
  161. }
  162. pmd, ok := epInfo[netlabel.PortMap]
  163. if !ok {
  164. t.Fatalf("Could not find expected info in endpoint data")
  165. }
  166. pm, ok := pmd.([]types.PortBinding)
  167. if !ok {
  168. t.Fatalf("Unexpected format for port mapping in endpoint operational data")
  169. }
  170. if len(pm) != 5 {
  171. t.Fatalf("Incomplete data for port mapping in endpoint operational data: %d", len(pm))
  172. }
  173. }
  174. func TestUnknownDriver(t *testing.T) {
  175. if !testutils.IsRunningInContainer() {
  176. defer testutils.SetupTestOSContext(t)()
  177. }
  178. _, err := createTestNetwork("unknowndriver", "testnetwork", options.Generic{}, nil, nil)
  179. if err == nil {
  180. t.Fatal("Expected to fail. But instead succeeded")
  181. }
  182. if _, ok := err.(types.NotFoundError); !ok {
  183. t.Fatalf("Did not fail with expected error. Actual error: %v", err)
  184. }
  185. }
  186. func TestNilRemoteDriver(t *testing.T) {
  187. _, err := controller.NewNetwork("framerelay", "dummy", "",
  188. libnetwork.NetworkOptionGeneric(getEmptyGenericOption()))
  189. if err == nil {
  190. t.Fatal("Expected to fail. But instead succeeded")
  191. }
  192. if _, ok := err.(types.NotFoundError); !ok {
  193. t.Fatalf("Did not fail with expected error. Actual error: %v", err)
  194. }
  195. }
  196. func TestNetworkName(t *testing.T) {
  197. if !testutils.IsRunningInContainer() {
  198. defer testutils.SetupTestOSContext(t)()
  199. }
  200. netOption := options.Generic{
  201. netlabel.GenericData: options.Generic{
  202. "BridgeName": "testnetwork",
  203. },
  204. }
  205. _, err := createTestNetwork(bridgeNetType, "", netOption, nil, nil)
  206. if err == nil {
  207. t.Fatal("Expected to fail. But instead succeeded")
  208. }
  209. if _, ok := err.(libnetwork.ErrInvalidName); !ok {
  210. t.Fatalf("Expected to fail with ErrInvalidName error. Got %v", err)
  211. }
  212. networkName := "testnetwork"
  213. n, err := createTestNetwork(bridgeNetType, networkName, netOption, nil, nil)
  214. if err != nil {
  215. t.Fatal(err)
  216. }
  217. defer func() {
  218. if err := n.Delete(); err != nil {
  219. t.Fatal(err)
  220. }
  221. }()
  222. if n.Name() != networkName {
  223. t.Fatalf("Expected network name %s, got %s", networkName, n.Name())
  224. }
  225. }
  226. func TestNetworkType(t *testing.T) {
  227. if !testutils.IsRunningInContainer() {
  228. defer testutils.SetupTestOSContext(t)()
  229. }
  230. netOption := options.Generic{
  231. netlabel.GenericData: options.Generic{
  232. "BridgeName": "testnetwork",
  233. },
  234. }
  235. n, err := createTestNetwork(bridgeNetType, "testnetwork", netOption, nil, nil)
  236. if err != nil {
  237. t.Fatal(err)
  238. }
  239. defer func() {
  240. if err := n.Delete(); err != nil {
  241. t.Fatal(err)
  242. }
  243. }()
  244. if n.Type() != bridgeNetType {
  245. t.Fatalf("Expected network type %s, got %s", bridgeNetType, n.Type())
  246. }
  247. }
  248. func TestNetworkID(t *testing.T) {
  249. if !testutils.IsRunningInContainer() {
  250. defer testutils.SetupTestOSContext(t)()
  251. }
  252. netOption := options.Generic{
  253. netlabel.GenericData: options.Generic{
  254. "BridgeName": "testnetwork",
  255. },
  256. }
  257. n, err := createTestNetwork(bridgeNetType, "testnetwork", netOption, nil, nil)
  258. if err != nil {
  259. t.Fatal(err)
  260. }
  261. defer func() {
  262. if err := n.Delete(); err != nil {
  263. t.Fatal(err)
  264. }
  265. }()
  266. if n.ID() == "" {
  267. t.Fatal("Expected non-empty network id")
  268. }
  269. }
  270. func TestDeleteNetworkWithActiveEndpoints(t *testing.T) {
  271. if !testutils.IsRunningInContainer() {
  272. defer testutils.SetupTestOSContext(t)()
  273. }
  274. netOption := options.Generic{
  275. "BridgeName": "testnetwork",
  276. }
  277. option := options.Generic{
  278. netlabel.GenericData: netOption,
  279. }
  280. network, err := createTestNetwork(bridgeNetType, "testnetwork", option, nil, nil)
  281. if err != nil {
  282. t.Fatal(err)
  283. }
  284. ep, err := network.CreateEndpoint("testep")
  285. if err != nil {
  286. t.Fatal(err)
  287. }
  288. err = network.Delete()
  289. if err == nil {
  290. t.Fatal("Expected to fail. But instead succeeded")
  291. }
  292. if _, ok := err.(*libnetwork.ActiveEndpointsError); !ok {
  293. t.Fatalf("Did not fail with expected error. Actual error: %v", err)
  294. }
  295. // Done testing. Now cleanup.
  296. if err := ep.Delete(false); err != nil {
  297. t.Fatal(err)
  298. }
  299. if err := network.Delete(); err != nil {
  300. t.Fatal(err)
  301. }
  302. }
  303. func TestUnknownNetwork(t *testing.T) {
  304. if !testutils.IsRunningInContainer() {
  305. defer testutils.SetupTestOSContext(t)()
  306. }
  307. netOption := options.Generic{
  308. "BridgeName": "testnetwork",
  309. }
  310. option := options.Generic{
  311. netlabel.GenericData: netOption,
  312. }
  313. network, err := createTestNetwork(bridgeNetType, "testnetwork", option, nil, nil)
  314. if err != nil {
  315. t.Fatal(err)
  316. }
  317. err = network.Delete()
  318. if err != nil {
  319. t.Fatal(err)
  320. }
  321. err = network.Delete()
  322. if err == nil {
  323. t.Fatal("Expected to fail. But instead succeeded")
  324. }
  325. if _, ok := err.(*libnetwork.UnknownNetworkError); !ok {
  326. t.Fatalf("Did not fail with expected error. Actual error: %v", err)
  327. }
  328. }
  329. func TestUnknownEndpoint(t *testing.T) {
  330. if !testutils.IsRunningInContainer() {
  331. defer testutils.SetupTestOSContext(t)()
  332. }
  333. netOption := options.Generic{
  334. "BridgeName": "testnetwork",
  335. }
  336. option := options.Generic{
  337. netlabel.GenericData: netOption,
  338. }
  339. ipamV4ConfList := []*libnetwork.IpamConf{{PreferredPool: "192.168.100.0/24"}}
  340. network, err := createTestNetwork(bridgeNetType, "testnetwork", option, ipamV4ConfList, nil)
  341. if err != nil {
  342. t.Fatal(err)
  343. }
  344. _, err = network.CreateEndpoint("")
  345. if err == nil {
  346. t.Fatal("Expected to fail. But instead succeeded")
  347. }
  348. if _, ok := err.(libnetwork.ErrInvalidName); !ok {
  349. t.Fatalf("Expected to fail with ErrInvalidName error. Actual error: %v", err)
  350. }
  351. ep, err := network.CreateEndpoint("testep")
  352. if err != nil {
  353. t.Fatal(err)
  354. }
  355. err = ep.Delete(false)
  356. if err != nil {
  357. t.Fatal(err)
  358. }
  359. // Done testing. Now cleanup
  360. if err := network.Delete(); err != nil {
  361. t.Fatal(err)
  362. }
  363. }
  364. func TestNetworkEndpointsWalkers(t *testing.T) {
  365. if !testutils.IsRunningInContainer() {
  366. defer testutils.SetupTestOSContext(t)()
  367. }
  368. // Create network 1 and add 2 endpoint: ep11, ep12
  369. netOption := options.Generic{
  370. netlabel.GenericData: options.Generic{
  371. "BridgeName": "network1",
  372. },
  373. }
  374. net1, err := createTestNetwork(bridgeNetType, "network1", netOption, nil, nil)
  375. if err != nil {
  376. t.Fatal(err)
  377. }
  378. defer func() {
  379. if err := net1.Delete(); err != nil {
  380. t.Fatal(err)
  381. }
  382. }()
  383. ep11, err := net1.CreateEndpoint("ep11")
  384. if err != nil {
  385. t.Fatal(err)
  386. }
  387. defer func() {
  388. if err := ep11.Delete(false); err != nil {
  389. t.Fatal(err)
  390. }
  391. }()
  392. ep12, err := net1.CreateEndpoint("ep12")
  393. if err != nil {
  394. t.Fatal(err)
  395. }
  396. defer func() {
  397. if err := ep12.Delete(false); err != nil {
  398. t.Fatal(err)
  399. }
  400. }()
  401. // Test list methods on net1
  402. epList1 := net1.Endpoints()
  403. if len(epList1) != 2 {
  404. t.Fatalf("Endpoints() returned wrong number of elements: %d instead of 2", len(epList1))
  405. }
  406. // endpoint order is not guaranteed
  407. for _, e := range epList1 {
  408. if e != ep11 && e != ep12 {
  409. t.Fatal("Endpoints() did not return all the expected elements")
  410. }
  411. }
  412. // Test Endpoint Walk method
  413. var epName string
  414. var epWanted libnetwork.Endpoint
  415. wlk := func(ep libnetwork.Endpoint) bool {
  416. if ep.Name() == epName {
  417. epWanted = ep
  418. return true
  419. }
  420. return false
  421. }
  422. // Look for ep1 on network1
  423. epName = "ep11"
  424. net1.WalkEndpoints(wlk)
  425. if epWanted == nil {
  426. t.Fatal(err)
  427. }
  428. if ep11 != epWanted {
  429. t.Fatal(err)
  430. }
  431. current := len(controller.Networks())
  432. // Create network 2
  433. netOption = options.Generic{
  434. netlabel.GenericData: options.Generic{
  435. "BridgeName": "network2",
  436. },
  437. }
  438. net2, err := createTestNetwork(bridgeNetType, "network2", netOption, nil, nil)
  439. if err != nil {
  440. t.Fatal(err)
  441. }
  442. defer func() {
  443. if err := net2.Delete(); err != nil {
  444. t.Fatal(err)
  445. }
  446. }()
  447. // Test Networks method
  448. if len(controller.Networks()) != current+1 {
  449. t.Fatalf("Did not find the expected number of networks")
  450. }
  451. // Test Network Walk method
  452. var netName string
  453. var netWanted libnetwork.Network
  454. nwWlk := func(nw libnetwork.Network) bool {
  455. if nw.Name() == netName {
  456. netWanted = nw
  457. return true
  458. }
  459. return false
  460. }
  461. // Look for network named "network1" and "network2"
  462. netName = "network1"
  463. controller.WalkNetworks(nwWlk)
  464. if netWanted == nil {
  465. t.Fatal(err)
  466. }
  467. if net1.ID() != netWanted.ID() {
  468. t.Fatal(err)
  469. }
  470. netName = "network2"
  471. controller.WalkNetworks(nwWlk)
  472. if netWanted == nil {
  473. t.Fatal(err)
  474. }
  475. if net2.ID() != netWanted.ID() {
  476. t.Fatal(err)
  477. }
  478. }
  479. func TestDuplicateEndpoint(t *testing.T) {
  480. if !testutils.IsRunningInContainer() {
  481. defer testutils.SetupTestOSContext(t)()
  482. }
  483. netOption := options.Generic{
  484. netlabel.GenericData: options.Generic{
  485. "BridgeName": "testnetwork",
  486. },
  487. }
  488. n, err := createTestNetwork(bridgeNetType, "testnetwork", netOption, nil, nil)
  489. if err != nil {
  490. t.Fatal(err)
  491. }
  492. defer func() {
  493. if err := n.Delete(); err != nil {
  494. t.Fatal(err)
  495. }
  496. }()
  497. ep, err := n.CreateEndpoint("ep1")
  498. if err != nil {
  499. t.Fatal(err)
  500. }
  501. defer func() {
  502. if err := ep.Delete(false); err != nil {
  503. t.Fatal(err)
  504. }
  505. }()
  506. ep2, err := n.CreateEndpoint("ep1")
  507. defer func() {
  508. // Cleanup ep2 as well, else network cleanup might fail for failure cases
  509. if ep2 != nil {
  510. if err := ep2.Delete(false); err != nil {
  511. t.Fatal(err)
  512. }
  513. }
  514. }()
  515. if err == nil {
  516. t.Fatal("Expected to fail. But instead succeeded")
  517. }
  518. if _, ok := err.(types.ForbiddenError); !ok {
  519. t.Fatalf("Did not fail with expected error. Actual error: %v", err)
  520. }
  521. }
  522. func TestControllerQuery(t *testing.T) {
  523. if !testutils.IsRunningInContainer() {
  524. defer testutils.SetupTestOSContext(t)()
  525. }
  526. // Create network 1
  527. netOption := options.Generic{
  528. netlabel.GenericData: options.Generic{
  529. "BridgeName": "network1",
  530. },
  531. }
  532. net1, err := createTestNetwork(bridgeNetType, "network1", netOption, nil, nil)
  533. if err != nil {
  534. t.Fatal(err)
  535. }
  536. defer func() {
  537. if err := net1.Delete(); err != nil {
  538. t.Fatal(err)
  539. }
  540. }()
  541. // Create network 2
  542. netOption = options.Generic{
  543. netlabel.GenericData: options.Generic{
  544. "BridgeName": "network2",
  545. },
  546. }
  547. net2, err := createTestNetwork(bridgeNetType, "network2", netOption, nil, nil)
  548. if err != nil {
  549. t.Fatal(err)
  550. }
  551. defer func() {
  552. if err := net2.Delete(); err != nil {
  553. t.Fatal(err)
  554. }
  555. }()
  556. _, err = controller.NetworkByName("")
  557. if err == nil {
  558. t.Fatalf("NetworkByName() succeeded with invalid target name")
  559. }
  560. if _, ok := err.(libnetwork.ErrInvalidName); !ok {
  561. t.Fatalf("Expected NetworkByName() to fail with ErrInvalidName error. Got: %v", err)
  562. }
  563. _, err = controller.NetworkByID("")
  564. if err == nil {
  565. t.Fatalf("NetworkByID() succeeded with invalid target id")
  566. }
  567. if _, ok := err.(libnetwork.ErrInvalidID); !ok {
  568. t.Fatalf("NetworkByID() failed with unexpected error: %v", err)
  569. }
  570. g, err := controller.NetworkByID("network1")
  571. if err == nil {
  572. t.Fatalf("Unexpected success for NetworkByID(): %v", g)
  573. }
  574. if _, ok := err.(libnetwork.ErrNoSuchNetwork); !ok {
  575. t.Fatalf("NetworkByID() failed with unexpected error: %v", err)
  576. }
  577. g, err = controller.NetworkByName("network1")
  578. if err != nil {
  579. t.Fatalf("Unexpected failure for NetworkByName(): %v", err)
  580. }
  581. if g == nil {
  582. t.Fatalf("NetworkByName() did not find the network")
  583. }
  584. if g != net1 {
  585. t.Fatalf("NetworkByName() returned the wrong network")
  586. }
  587. g, err = controller.NetworkByID(net1.ID())
  588. if err != nil {
  589. t.Fatalf("Unexpected failure for NetworkByID(): %v", err)
  590. }
  591. if net1.ID() != g.ID() {
  592. t.Fatalf("NetworkByID() returned unexpected element: %v", g)
  593. }
  594. g, err = controller.NetworkByName("network2")
  595. if err != nil {
  596. t.Fatalf("Unexpected failure for NetworkByName(): %v", err)
  597. }
  598. if g == nil {
  599. t.Fatalf("NetworkByName() did not find the network")
  600. }
  601. if g != net2 {
  602. t.Fatalf("NetworkByName() returned the wrong network")
  603. }
  604. g, err = controller.NetworkByID(net2.ID())
  605. if err != nil {
  606. t.Fatalf("Unexpected failure for NetworkByID(): %v", err)
  607. }
  608. if net2.ID() != g.ID() {
  609. t.Fatalf("NetworkByID() returned unexpected element: %v", g)
  610. }
  611. }
  612. func TestNetworkQuery(t *testing.T) {
  613. if !testutils.IsRunningInContainer() {
  614. defer testutils.SetupTestOSContext(t)()
  615. }
  616. // Create network 1 and add 2 endpoint: ep11, ep12
  617. netOption := options.Generic{
  618. netlabel.GenericData: options.Generic{
  619. "BridgeName": "network1",
  620. },
  621. }
  622. net1, err := createTestNetwork(bridgeNetType, "network1", netOption, nil, nil)
  623. if err != nil {
  624. t.Fatal(err)
  625. }
  626. defer func() {
  627. if err := net1.Delete(); err != nil {
  628. t.Fatal(err)
  629. }
  630. }()
  631. ep11, err := net1.CreateEndpoint("ep11")
  632. if err != nil {
  633. t.Fatal(err)
  634. }
  635. defer func() {
  636. if err := ep11.Delete(false); err != nil {
  637. t.Fatal(err)
  638. }
  639. }()
  640. ep12, err := net1.CreateEndpoint("ep12")
  641. if err != nil {
  642. t.Fatal(err)
  643. }
  644. defer func() {
  645. if err := ep12.Delete(false); err != nil {
  646. t.Fatal(err)
  647. }
  648. }()
  649. e, err := net1.EndpointByName("ep11")
  650. if err != nil {
  651. t.Fatal(err)
  652. }
  653. if ep11 != e {
  654. t.Fatalf("EndpointByName() returned %v instead of %v", e, ep11)
  655. }
  656. e, err = net1.EndpointByName("")
  657. if err == nil {
  658. t.Fatalf("EndpointByName() succeeded with invalid target name")
  659. }
  660. if _, ok := err.(libnetwork.ErrInvalidName); !ok {
  661. t.Fatalf("Expected EndpointByName() to fail with ErrInvalidName error. Got: %v", err)
  662. }
  663. e, err = net1.EndpointByName("IamNotAnEndpoint")
  664. if err == nil {
  665. t.Fatalf("EndpointByName() succeeded with unknown target name")
  666. }
  667. if _, ok := err.(libnetwork.ErrNoSuchEndpoint); !ok {
  668. t.Fatal(err)
  669. }
  670. if e != nil {
  671. t.Fatalf("EndpointByName(): expected nil, got %v", e)
  672. }
  673. e, err = net1.EndpointByID(ep12.ID())
  674. if err != nil {
  675. t.Fatal(err)
  676. }
  677. if ep12.ID() != e.ID() {
  678. t.Fatalf("EndpointByID() returned %v instead of %v", e, ep12)
  679. }
  680. e, err = net1.EndpointByID("")
  681. if err == nil {
  682. t.Fatalf("EndpointByID() succeeded with invalid target id")
  683. }
  684. if _, ok := err.(libnetwork.ErrInvalidID); !ok {
  685. t.Fatalf("EndpointByID() failed with unexpected error: %v", err)
  686. }
  687. }
  688. const containerID = "valid_c"
  689. type fakeSandbox struct{}
  690. func (f *fakeSandbox) ID() string {
  691. return "fake sandbox"
  692. }
  693. func (f *fakeSandbox) ContainerID() string {
  694. return ""
  695. }
  696. func (f *fakeSandbox) Key() string {
  697. return "fake key"
  698. }
  699. func (f *fakeSandbox) Labels() map[string]interface{} {
  700. return nil
  701. }
  702. func (f *fakeSandbox) Statistics() (map[string]*types.InterfaceStatistics, error) {
  703. return nil, nil
  704. }
  705. func (f *fakeSandbox) Refresh(opts ...libnetwork.SandboxOption) error {
  706. return nil
  707. }
  708. func (f *fakeSandbox) Delete() error {
  709. return nil
  710. }
  711. func (f *fakeSandbox) Rename(name string) error {
  712. return nil
  713. }
  714. func (f *fakeSandbox) SetKey(key string) error {
  715. return nil
  716. }
  717. func (f *fakeSandbox) ResolveName(name string, ipType int) ([]net.IP, bool) {
  718. return nil, false
  719. }
  720. func (f *fakeSandbox) ResolveIP(ip string) string {
  721. return ""
  722. }
  723. func (f *fakeSandbox) ResolveService(name string) ([]*net.SRV, []net.IP) {
  724. return nil, nil
  725. }
  726. func (f *fakeSandbox) Endpoints() []libnetwork.Endpoint {
  727. return nil
  728. }
  729. func TestEndpointDeleteWithActiveContainer(t *testing.T) {
  730. if !testutils.IsRunningInContainer() {
  731. defer testutils.SetupTestOSContext(t)()
  732. }
  733. n, err := createTestNetwork(bridgeNetType, "testnetwork", options.Generic{
  734. netlabel.GenericData: options.Generic{
  735. "BridgeName": "testnetwork",
  736. },
  737. }, nil, nil)
  738. if err != nil {
  739. t.Fatal(err)
  740. }
  741. defer func() {
  742. if err := n.Delete(); err != nil {
  743. t.Fatal(err)
  744. }
  745. }()
  746. ep, err := n.CreateEndpoint("ep1")
  747. if err != nil {
  748. t.Fatal(err)
  749. }
  750. defer func() {
  751. err = ep.Delete(false)
  752. if err != nil {
  753. t.Fatal(err)
  754. }
  755. }()
  756. cnt, err := controller.NewSandbox(containerID,
  757. libnetwork.OptionHostname("test"),
  758. libnetwork.OptionDomainname("docker.io"),
  759. libnetwork.OptionExtraHost("web", "192.168.0.1"))
  760. defer func() {
  761. if err := cnt.Delete(); err != nil {
  762. t.Fatal(err)
  763. }
  764. }()
  765. err = ep.Join(cnt)
  766. if err != nil {
  767. t.Fatal(err)
  768. }
  769. defer func() {
  770. err = ep.Leave(cnt)
  771. if err != nil {
  772. t.Fatal(err)
  773. }
  774. }()
  775. err = ep.Delete(false)
  776. if err == nil {
  777. t.Fatal("Expected to fail. But instead succeeded")
  778. }
  779. if _, ok := err.(*libnetwork.ActiveContainerError); !ok {
  780. t.Fatalf("Did not fail with expected error. Actual error: %v", err)
  781. }
  782. }
  783. func TestEndpointMultipleJoins(t *testing.T) {
  784. if !testutils.IsRunningInContainer() {
  785. defer testutils.SetupTestOSContext(t)()
  786. }
  787. n, err := createTestNetwork(bridgeNetType, "testmultiple", options.Generic{
  788. netlabel.GenericData: options.Generic{
  789. "BridgeName": "testmultiple",
  790. },
  791. }, nil, nil)
  792. if err != nil {
  793. t.Fatal(err)
  794. }
  795. defer func() {
  796. if err := n.Delete(); err != nil {
  797. t.Fatal(err)
  798. }
  799. }()
  800. ep, err := n.CreateEndpoint("ep1")
  801. if err != nil {
  802. t.Fatal(err)
  803. }
  804. defer func() {
  805. if err := ep.Delete(false); err != nil {
  806. t.Fatal(err)
  807. }
  808. }()
  809. sbx1, err := controller.NewSandbox(containerID,
  810. libnetwork.OptionHostname("test"),
  811. libnetwork.OptionDomainname("docker.io"),
  812. libnetwork.OptionExtraHost("web", "192.168.0.1"))
  813. defer func() {
  814. if err := sbx1.Delete(); err != nil {
  815. t.Fatal(err)
  816. }
  817. }()
  818. sbx2, err := controller.NewSandbox("c2")
  819. defer func() {
  820. if err := sbx2.Delete(); err != nil {
  821. t.Fatal(err)
  822. }
  823. }()
  824. err = ep.Join(sbx1)
  825. if err != nil {
  826. t.Fatal(err)
  827. }
  828. defer func() {
  829. err = ep.Leave(sbx1)
  830. if err != nil {
  831. t.Fatal(err)
  832. }
  833. }()
  834. err = ep.Join(sbx2)
  835. if err == nil {
  836. t.Fatal("Expected to fail multiple joins for the same endpoint")
  837. }
  838. if _, ok := err.(types.ForbiddenError); !ok {
  839. t.Fatalf("Failed with unexpected error type: %T. Desc: %s", err, err.Error())
  840. }
  841. }
  842. func TestLeaveAll(t *testing.T) {
  843. if !testutils.IsRunningInContainer() {
  844. defer testutils.SetupTestOSContext(t)()
  845. }
  846. n, err := createTestNetwork(bridgeNetType, "testnetwork", options.Generic{
  847. netlabel.GenericData: options.Generic{
  848. "BridgeName": "testnetwork",
  849. },
  850. }, nil, nil)
  851. if err != nil {
  852. t.Fatal(err)
  853. }
  854. defer func() {
  855. // If this goes through, it means cnt.Delete() effectively detached from all the endpoints
  856. if err := n.Delete(); err != nil {
  857. t.Fatal(err)
  858. }
  859. }()
  860. ep1, err := n.CreateEndpoint("ep1")
  861. if err != nil {
  862. t.Fatal(err)
  863. }
  864. ep2, err := n.CreateEndpoint("ep2")
  865. if err != nil {
  866. t.Fatal(err)
  867. }
  868. cnt, err := controller.NewSandbox("leaveall")
  869. if err != nil {
  870. t.Fatal(err)
  871. }
  872. err = ep1.Join(cnt)
  873. if err != nil {
  874. t.Fatalf("Failed to join ep1: %v", err)
  875. }
  876. err = ep2.Join(cnt)
  877. if err != nil {
  878. t.Fatalf("Failed to join ep2: %v", err)
  879. }
  880. err = cnt.Delete()
  881. if err != nil {
  882. t.Fatal(err)
  883. }
  884. }
  885. func TestContainerInvalidLeave(t *testing.T) {
  886. if !testutils.IsRunningInContainer() {
  887. defer testutils.SetupTestOSContext(t)()
  888. }
  889. n, err := createTestNetwork(bridgeNetType, "testnetwork", options.Generic{
  890. netlabel.GenericData: options.Generic{
  891. "BridgeName": "testnetwork",
  892. },
  893. }, nil, nil)
  894. if err != nil {
  895. t.Fatal(err)
  896. }
  897. defer func() {
  898. if err := n.Delete(); err != nil {
  899. t.Fatal(err)
  900. }
  901. }()
  902. ep, err := n.CreateEndpoint("ep1")
  903. if err != nil {
  904. t.Fatal(err)
  905. }
  906. defer func() {
  907. if err := ep.Delete(false); err != nil {
  908. t.Fatal(err)
  909. }
  910. }()
  911. cnt, err := controller.NewSandbox(containerID,
  912. libnetwork.OptionHostname("test"),
  913. libnetwork.OptionDomainname("docker.io"),
  914. libnetwork.OptionExtraHost("web", "192.168.0.1"))
  915. if err != nil {
  916. t.Fatal(err)
  917. }
  918. defer func() {
  919. if err := cnt.Delete(); err != nil {
  920. t.Fatal(err)
  921. }
  922. }()
  923. err = ep.Leave(cnt)
  924. if err == nil {
  925. t.Fatal("Expected to fail leave from an endpoint which has no active join")
  926. }
  927. if _, ok := err.(types.ForbiddenError); !ok {
  928. t.Fatalf("Failed with unexpected error type: %T. Desc: %s", err, err.Error())
  929. }
  930. if err = ep.Leave(nil); err == nil {
  931. t.Fatalf("Expected to fail leave nil Sandbox")
  932. }
  933. if _, ok := err.(types.BadRequestError); !ok {
  934. t.Fatalf("Unexpected error type returned: %T. Desc: %s", err, err.Error())
  935. }
  936. fsbx := &fakeSandbox{}
  937. if err = ep.Leave(fsbx); err == nil {
  938. t.Fatalf("Expected to fail leave with invalid Sandbox")
  939. }
  940. if _, ok := err.(types.BadRequestError); !ok {
  941. t.Fatalf("Unexpected error type returned: %T. Desc: %s", err, err.Error())
  942. }
  943. }
  944. func TestEndpointUpdateParent(t *testing.T) {
  945. if !testutils.IsRunningInContainer() {
  946. defer testutils.SetupTestOSContext(t)()
  947. }
  948. n, err := createTestNetwork("bridge", "testnetwork", options.Generic{
  949. netlabel.GenericData: options.Generic{
  950. "BridgeName": "testnetwork",
  951. },
  952. }, nil, nil)
  953. if err != nil {
  954. t.Fatal(err)
  955. }
  956. defer func() {
  957. if err := n.Delete(); err != nil {
  958. t.Fatal(err)
  959. }
  960. }()
  961. ep1, err := n.CreateEndpoint("ep1")
  962. if err != nil {
  963. t.Fatal(err)
  964. }
  965. ep2, err := n.CreateEndpoint("ep2")
  966. if err != nil {
  967. t.Fatal(err)
  968. }
  969. sbx1, err := controller.NewSandbox(containerID,
  970. libnetwork.OptionHostname("test"),
  971. libnetwork.OptionDomainname("docker.io"),
  972. libnetwork.OptionExtraHost("web", "192.168.0.1"))
  973. if err != nil {
  974. t.Fatal(err)
  975. }
  976. defer func() {
  977. if err := sbx1.Delete(); err != nil {
  978. t.Fatal(err)
  979. }
  980. }()
  981. sbx2, err := controller.NewSandbox("c2",
  982. libnetwork.OptionHostname("test2"),
  983. libnetwork.OptionDomainname("docker.io"),
  984. libnetwork.OptionHostsPath("/var/lib/docker/test_network/container2/hosts"),
  985. libnetwork.OptionExtraHost("web", "192.168.0.2"))
  986. if err != nil {
  987. t.Fatal(err)
  988. }
  989. defer func() {
  990. if err := sbx2.Delete(); err != nil {
  991. t.Fatal(err)
  992. }
  993. }()
  994. err = ep1.Join(sbx1)
  995. if err != nil {
  996. t.Fatal(err)
  997. }
  998. err = ep2.Join(sbx2)
  999. if err != nil {
  1000. t.Fatal(err)
  1001. }
  1002. }
  1003. func TestInvalidRemoteDriver(t *testing.T) {
  1004. if !testutils.IsRunningInContainer() {
  1005. t.Skip("Skipping test when not running inside a Container")
  1006. }
  1007. mux := http.NewServeMux()
  1008. server := httptest.NewServer(mux)
  1009. if server == nil {
  1010. t.Fatal("Failed to start an HTTP Server")
  1011. }
  1012. defer server.Close()
  1013. type pluginRequest struct {
  1014. name string
  1015. }
  1016. mux.HandleFunc("/Plugin.Activate", func(w http.ResponseWriter, r *http.Request) {
  1017. w.Header().Set("Content-Type", "application/vnd.docker.plugins.v1+json")
  1018. fmt.Fprintln(w, `{"Implements": ["InvalidDriver"]}`)
  1019. })
  1020. if err := os.MkdirAll("/etc/docker/plugins", 0755); err != nil {
  1021. t.Fatal(err)
  1022. }
  1023. defer func() {
  1024. if err := os.RemoveAll("/etc/docker/plugins"); err != nil {
  1025. t.Fatal(err)
  1026. }
  1027. }()
  1028. if err := ioutil.WriteFile("/etc/docker/plugins/invalid-network-driver.spec", []byte(server.URL), 0644); err != nil {
  1029. t.Fatal(err)
  1030. }
  1031. ctrlr, err := libnetwork.New()
  1032. if err != nil {
  1033. t.Fatal(err)
  1034. }
  1035. defer ctrlr.Stop()
  1036. _, err = ctrlr.NewNetwork("invalid-network-driver", "dummy", "",
  1037. libnetwork.NetworkOptionGeneric(getEmptyGenericOption()))
  1038. if err == nil {
  1039. t.Fatal("Expected to fail. But instead succeeded")
  1040. }
  1041. if err != plugins.ErrNotImplements {
  1042. t.Fatalf("Did not fail with expected error. Actual error: %v", err)
  1043. }
  1044. }
  1045. func TestValidRemoteDriver(t *testing.T) {
  1046. if !testutils.IsRunningInContainer() {
  1047. t.Skip("Skipping test when not running inside a Container")
  1048. }
  1049. mux := http.NewServeMux()
  1050. server := httptest.NewServer(mux)
  1051. if server == nil {
  1052. t.Fatal("Failed to start an HTTP Server")
  1053. }
  1054. defer server.Close()
  1055. type pluginRequest struct {
  1056. name string
  1057. }
  1058. mux.HandleFunc("/Plugin.Activate", func(w http.ResponseWriter, r *http.Request) {
  1059. w.Header().Set("Content-Type", "application/vnd.docker.plugins.v1+json")
  1060. fmt.Fprintf(w, `{"Implements": ["%s"]}`, driverapi.NetworkPluginEndpointType)
  1061. })
  1062. mux.HandleFunc(fmt.Sprintf("/%s.CreateNetwork", driverapi.NetworkPluginEndpointType), func(w http.ResponseWriter, r *http.Request) {
  1063. w.Header().Set("Content-Type", "application/vnd.docker.plugins.v1+json")
  1064. fmt.Fprintf(w, "null")
  1065. })
  1066. if err := os.MkdirAll("/etc/docker/plugins", 0755); err != nil {
  1067. t.Fatal(err)
  1068. }
  1069. defer func() {
  1070. if err := os.RemoveAll("/etc/docker/plugins"); err != nil {
  1071. t.Fatal(err)
  1072. }
  1073. }()
  1074. if err := ioutil.WriteFile("/etc/docker/plugins/valid-network-driver.spec", []byte(server.URL), 0644); err != nil {
  1075. t.Fatal(err)
  1076. }
  1077. n, err := controller.NewNetwork("valid-network-driver", "dummy", "",
  1078. libnetwork.NetworkOptionGeneric(getEmptyGenericOption()))
  1079. if err != nil {
  1080. // Only fail if we could not find the plugin driver
  1081. if _, ok := err.(types.NotFoundError); ok {
  1082. t.Fatal(err)
  1083. }
  1084. return
  1085. }
  1086. defer func() {
  1087. if err := n.Delete(); err != nil {
  1088. t.Fatal(err)
  1089. }
  1090. }()
  1091. }
  1092. var (
  1093. once sync.Once
  1094. start = make(chan struct{})
  1095. done = make(chan chan struct{}, numThreads-1)
  1096. origns = netns.None()
  1097. testns = netns.None()
  1098. sboxes = make([]libnetwork.Sandbox, numThreads)
  1099. )
  1100. const (
  1101. iterCnt = 25
  1102. numThreads = 3
  1103. first = 1
  1104. last = numThreads
  1105. debug = false
  1106. )
  1107. func createGlobalInstance(t *testing.T) {
  1108. var err error
  1109. defer close(start)
  1110. origns, err = netns.Get()
  1111. if err != nil {
  1112. t.Fatal(err)
  1113. }
  1114. if testutils.IsRunningInContainer() {
  1115. testns = origns
  1116. } else {
  1117. testns, err = netns.New()
  1118. if err != nil {
  1119. t.Fatal(err)
  1120. }
  1121. }
  1122. netOption := options.Generic{
  1123. netlabel.GenericData: options.Generic{
  1124. "BridgeName": "network",
  1125. },
  1126. }
  1127. net1, err := controller.NetworkByName("testhost")
  1128. if err != nil {
  1129. t.Fatal(err)
  1130. }
  1131. net2, err := createTestNetwork("bridge", "network2", netOption, nil, nil)
  1132. if err != nil {
  1133. t.Fatal(err)
  1134. }
  1135. _, err = net1.CreateEndpoint("pep1")
  1136. if err != nil {
  1137. t.Fatal(err)
  1138. }
  1139. _, err = net2.CreateEndpoint("pep2")
  1140. if err != nil {
  1141. t.Fatal(err)
  1142. }
  1143. _, err = net2.CreateEndpoint("pep3")
  1144. if err != nil {
  1145. t.Fatal(err)
  1146. }
  1147. if sboxes[first-1], err = controller.NewSandbox(fmt.Sprintf("%drace", first), libnetwork.OptionUseDefaultSandbox()); err != nil {
  1148. t.Fatal(err)
  1149. }
  1150. for thd := first + 1; thd <= last; thd++ {
  1151. if sboxes[thd-1], err = controller.NewSandbox(fmt.Sprintf("%drace", thd)); err != nil {
  1152. t.Fatal(err)
  1153. }
  1154. }
  1155. }
  1156. func debugf(format string, a ...interface{}) (int, error) {
  1157. if debug {
  1158. return fmt.Printf(format, a...)
  1159. }
  1160. return 0, nil
  1161. }