libnetwork_test.go 30 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394
  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 (f *fakeSandbox) EnableService() error {
  730. return nil
  731. }
  732. func (f *fakeSandbox) DisableService() error {
  733. return nil
  734. }
  735. func TestEndpointDeleteWithActiveContainer(t *testing.T) {
  736. if !testutils.IsRunningInContainer() {
  737. defer testutils.SetupTestOSContext(t)()
  738. }
  739. n, err := createTestNetwork(bridgeNetType, "testnetwork", options.Generic{
  740. netlabel.GenericData: options.Generic{
  741. "BridgeName": "testnetwork",
  742. },
  743. }, nil, nil)
  744. if err != nil {
  745. t.Fatal(err)
  746. }
  747. defer func() {
  748. if err := n.Delete(); err != nil {
  749. t.Fatal(err)
  750. }
  751. }()
  752. n2, err := createTestNetwork(bridgeNetType, "testnetwork2", options.Generic{
  753. netlabel.GenericData: options.Generic{
  754. "BridgeName": "testnetwork2",
  755. },
  756. }, nil, nil)
  757. if err != nil {
  758. t.Fatal(err)
  759. }
  760. defer func() {
  761. if err := n2.Delete(); err != nil {
  762. t.Fatal(err)
  763. }
  764. }()
  765. ep, err := n.CreateEndpoint("ep1")
  766. if err != nil {
  767. t.Fatal(err)
  768. }
  769. defer func() {
  770. err = ep.Delete(false)
  771. if err != nil {
  772. t.Fatal(err)
  773. }
  774. }()
  775. cnt, err := controller.NewSandbox(containerID,
  776. libnetwork.OptionHostname("test"),
  777. libnetwork.OptionDomainname("docker.io"),
  778. libnetwork.OptionExtraHost("web", "192.168.0.1"))
  779. defer func() {
  780. if err := cnt.Delete(); err != nil {
  781. t.Fatal(err)
  782. }
  783. }()
  784. err = ep.Join(cnt)
  785. if err != nil {
  786. t.Fatal(err)
  787. }
  788. defer func() {
  789. err = ep.Leave(cnt)
  790. if err != nil {
  791. t.Fatal(err)
  792. }
  793. }()
  794. err = ep.Delete(false)
  795. if err == nil {
  796. t.Fatal("Expected to fail. But instead succeeded")
  797. }
  798. if _, ok := err.(*libnetwork.ActiveContainerError); !ok {
  799. t.Fatalf("Did not fail with expected error. Actual error: %v", err)
  800. }
  801. }
  802. func TestEndpointMultipleJoins(t *testing.T) {
  803. if !testutils.IsRunningInContainer() {
  804. defer testutils.SetupTestOSContext(t)()
  805. }
  806. n, err := createTestNetwork(bridgeNetType, "testmultiple", options.Generic{
  807. netlabel.GenericData: options.Generic{
  808. "BridgeName": "testmultiple",
  809. },
  810. }, nil, nil)
  811. if err != nil {
  812. t.Fatal(err)
  813. }
  814. defer func() {
  815. if err := n.Delete(); err != nil {
  816. t.Fatal(err)
  817. }
  818. }()
  819. ep, err := n.CreateEndpoint("ep1")
  820. if err != nil {
  821. t.Fatal(err)
  822. }
  823. defer func() {
  824. if err := ep.Delete(false); err != nil {
  825. t.Fatal(err)
  826. }
  827. }()
  828. sbx1, err := controller.NewSandbox(containerID,
  829. libnetwork.OptionHostname("test"),
  830. libnetwork.OptionDomainname("docker.io"),
  831. libnetwork.OptionExtraHost("web", "192.168.0.1"))
  832. defer func() {
  833. if err := sbx1.Delete(); err != nil {
  834. t.Fatal(err)
  835. }
  836. }()
  837. sbx2, err := controller.NewSandbox("c2")
  838. defer func() {
  839. if err := sbx2.Delete(); err != nil {
  840. t.Fatal(err)
  841. }
  842. }()
  843. err = ep.Join(sbx1)
  844. if err != nil {
  845. t.Fatal(err)
  846. }
  847. defer func() {
  848. err = ep.Leave(sbx1)
  849. if err != nil {
  850. t.Fatal(err)
  851. }
  852. }()
  853. err = ep.Join(sbx2)
  854. if err == nil {
  855. t.Fatal("Expected to fail multiple joins for the same endpoint")
  856. }
  857. if _, ok := err.(types.ForbiddenError); !ok {
  858. t.Fatalf("Failed with unexpected error type: %T. Desc: %s", err, err.Error())
  859. }
  860. }
  861. func TestLeaveAll(t *testing.T) {
  862. if !testutils.IsRunningInContainer() {
  863. defer testutils.SetupTestOSContext(t)()
  864. }
  865. n, err := createTestNetwork(bridgeNetType, "testnetwork", options.Generic{
  866. netlabel.GenericData: options.Generic{
  867. "BridgeName": "testnetwork",
  868. },
  869. }, nil, nil)
  870. if err != nil {
  871. t.Fatal(err)
  872. }
  873. defer func() {
  874. // If this goes through, it means cnt.Delete() effectively detached from all the endpoints
  875. if err := n.Delete(); err != nil {
  876. t.Fatal(err)
  877. }
  878. }()
  879. n2, err := createTestNetwork(bridgeNetType, "testnetwork2", options.Generic{
  880. netlabel.GenericData: options.Generic{
  881. "BridgeName": "testnetwork2",
  882. },
  883. }, nil, nil)
  884. if err != nil {
  885. t.Fatal(err)
  886. }
  887. defer func() {
  888. if err := n2.Delete(); err != nil {
  889. t.Fatal(err)
  890. }
  891. }()
  892. ep1, err := n.CreateEndpoint("ep1")
  893. if err != nil {
  894. t.Fatal(err)
  895. }
  896. ep2, err := n2.CreateEndpoint("ep2")
  897. if err != nil {
  898. t.Fatal(err)
  899. }
  900. cnt, err := controller.NewSandbox("leaveall")
  901. if err != nil {
  902. t.Fatal(err)
  903. }
  904. err = ep1.Join(cnt)
  905. if err != nil {
  906. t.Fatalf("Failed to join ep1: %v", err)
  907. }
  908. err = ep2.Join(cnt)
  909. if err != nil {
  910. t.Fatalf("Failed to join ep2: %v", err)
  911. }
  912. err = cnt.Delete()
  913. if err != nil {
  914. t.Fatal(err)
  915. }
  916. }
  917. func TestContainerInvalidLeave(t *testing.T) {
  918. if !testutils.IsRunningInContainer() {
  919. defer testutils.SetupTestOSContext(t)()
  920. }
  921. n, err := createTestNetwork(bridgeNetType, "testnetwork", options.Generic{
  922. netlabel.GenericData: options.Generic{
  923. "BridgeName": "testnetwork",
  924. },
  925. }, nil, nil)
  926. if err != nil {
  927. t.Fatal(err)
  928. }
  929. defer func() {
  930. if err := n.Delete(); err != nil {
  931. t.Fatal(err)
  932. }
  933. }()
  934. ep, err := n.CreateEndpoint("ep1")
  935. if err != nil {
  936. t.Fatal(err)
  937. }
  938. defer func() {
  939. if err := ep.Delete(false); err != nil {
  940. t.Fatal(err)
  941. }
  942. }()
  943. cnt, err := controller.NewSandbox(containerID,
  944. libnetwork.OptionHostname("test"),
  945. libnetwork.OptionDomainname("docker.io"),
  946. libnetwork.OptionExtraHost("web", "192.168.0.1"))
  947. if err != nil {
  948. t.Fatal(err)
  949. }
  950. defer func() {
  951. if err := cnt.Delete(); err != nil {
  952. t.Fatal(err)
  953. }
  954. }()
  955. err = ep.Leave(cnt)
  956. if err == nil {
  957. t.Fatal("Expected to fail leave from an endpoint which has no active join")
  958. }
  959. if _, ok := err.(types.ForbiddenError); !ok {
  960. t.Fatalf("Failed with unexpected error type: %T. Desc: %s", err, err.Error())
  961. }
  962. if err = ep.Leave(nil); err == nil {
  963. t.Fatalf("Expected to fail leave nil Sandbox")
  964. }
  965. if _, ok := err.(types.BadRequestError); !ok {
  966. t.Fatalf("Unexpected error type returned: %T. Desc: %s", err, err.Error())
  967. }
  968. fsbx := &fakeSandbox{}
  969. if err = ep.Leave(fsbx); err == nil {
  970. t.Fatalf("Expected to fail leave with invalid Sandbox")
  971. }
  972. if _, ok := err.(types.BadRequestError); !ok {
  973. t.Fatalf("Unexpected error type returned: %T. Desc: %s", err, err.Error())
  974. }
  975. }
  976. func TestEndpointUpdateParent(t *testing.T) {
  977. if !testutils.IsRunningInContainer() {
  978. defer testutils.SetupTestOSContext(t)()
  979. }
  980. n, err := createTestNetwork("bridge", "testnetwork", options.Generic{
  981. netlabel.GenericData: options.Generic{
  982. "BridgeName": "testnetwork",
  983. },
  984. }, nil, nil)
  985. if err != nil {
  986. t.Fatal(err)
  987. }
  988. defer func() {
  989. if err := n.Delete(); err != nil {
  990. t.Fatal(err)
  991. }
  992. }()
  993. ep1, err := n.CreateEndpoint("ep1")
  994. if err != nil {
  995. t.Fatal(err)
  996. }
  997. ep2, err := n.CreateEndpoint("ep2")
  998. if err != nil {
  999. t.Fatal(err)
  1000. }
  1001. sbx1, err := controller.NewSandbox(containerID,
  1002. libnetwork.OptionHostname("test"),
  1003. libnetwork.OptionDomainname("docker.io"),
  1004. libnetwork.OptionExtraHost("web", "192.168.0.1"))
  1005. if err != nil {
  1006. t.Fatal(err)
  1007. }
  1008. defer func() {
  1009. if err := sbx1.Delete(); err != nil {
  1010. t.Fatal(err)
  1011. }
  1012. }()
  1013. sbx2, err := controller.NewSandbox("c2",
  1014. libnetwork.OptionHostname("test2"),
  1015. libnetwork.OptionDomainname("docker.io"),
  1016. libnetwork.OptionHostsPath("/var/lib/docker/test_network/container2/hosts"),
  1017. libnetwork.OptionExtraHost("web", "192.168.0.2"))
  1018. if err != nil {
  1019. t.Fatal(err)
  1020. }
  1021. defer func() {
  1022. if err := sbx2.Delete(); err != nil {
  1023. t.Fatal(err)
  1024. }
  1025. }()
  1026. err = ep1.Join(sbx1)
  1027. if err != nil {
  1028. t.Fatal(err)
  1029. }
  1030. err = ep2.Join(sbx2)
  1031. if err != nil {
  1032. t.Fatal(err)
  1033. }
  1034. }
  1035. func TestInvalidRemoteDriver(t *testing.T) {
  1036. if !testutils.IsRunningInContainer() {
  1037. t.Skip("Skipping test when not running inside a Container")
  1038. }
  1039. mux := http.NewServeMux()
  1040. server := httptest.NewServer(mux)
  1041. if server == nil {
  1042. t.Fatal("Failed to start an HTTP Server")
  1043. }
  1044. defer server.Close()
  1045. type pluginRequest struct {
  1046. name string
  1047. }
  1048. mux.HandleFunc("/Plugin.Activate", func(w http.ResponseWriter, r *http.Request) {
  1049. w.Header().Set("Content-Type", "application/vnd.docker.plugins.v1+json")
  1050. fmt.Fprintln(w, `{"Implements": ["InvalidDriver"]}`)
  1051. })
  1052. if err := os.MkdirAll("/etc/docker/plugins", 0755); err != nil {
  1053. t.Fatal(err)
  1054. }
  1055. defer func() {
  1056. if err := os.RemoveAll("/etc/docker/plugins"); err != nil {
  1057. t.Fatal(err)
  1058. }
  1059. }()
  1060. if err := ioutil.WriteFile("/etc/docker/plugins/invalid-network-driver.spec", []byte(server.URL), 0644); err != nil {
  1061. t.Fatal(err)
  1062. }
  1063. ctrlr, err := libnetwork.New()
  1064. if err != nil {
  1065. t.Fatal(err)
  1066. }
  1067. defer ctrlr.Stop()
  1068. _, err = ctrlr.NewNetwork("invalid-network-driver", "dummy", "",
  1069. libnetwork.NetworkOptionGeneric(getEmptyGenericOption()))
  1070. if err == nil {
  1071. t.Fatal("Expected to fail. But instead succeeded")
  1072. }
  1073. if err != plugins.ErrNotImplements {
  1074. t.Fatalf("Did not fail with expected error. Actual error: %v", err)
  1075. }
  1076. }
  1077. func TestValidRemoteDriver(t *testing.T) {
  1078. if !testutils.IsRunningInContainer() {
  1079. t.Skip("Skipping test when not running inside a Container")
  1080. }
  1081. mux := http.NewServeMux()
  1082. server := httptest.NewServer(mux)
  1083. if server == nil {
  1084. t.Fatal("Failed to start an HTTP Server")
  1085. }
  1086. defer server.Close()
  1087. type pluginRequest struct {
  1088. name string
  1089. }
  1090. mux.HandleFunc("/Plugin.Activate", func(w http.ResponseWriter, r *http.Request) {
  1091. w.Header().Set("Content-Type", "application/vnd.docker.plugins.v1+json")
  1092. fmt.Fprintf(w, `{"Implements": ["%s"]}`, driverapi.NetworkPluginEndpointType)
  1093. })
  1094. mux.HandleFunc(fmt.Sprintf("/%s.CreateNetwork", driverapi.NetworkPluginEndpointType), func(w http.ResponseWriter, r *http.Request) {
  1095. w.Header().Set("Content-Type", "application/vnd.docker.plugins.v1+json")
  1096. fmt.Fprintf(w, "null")
  1097. })
  1098. if err := os.MkdirAll("/etc/docker/plugins", 0755); err != nil {
  1099. t.Fatal(err)
  1100. }
  1101. defer func() {
  1102. if err := os.RemoveAll("/etc/docker/plugins"); err != nil {
  1103. t.Fatal(err)
  1104. }
  1105. }()
  1106. if err := ioutil.WriteFile("/etc/docker/plugins/valid-network-driver.spec", []byte(server.URL), 0644); err != nil {
  1107. t.Fatal(err)
  1108. }
  1109. n, err := controller.NewNetwork("valid-network-driver", "dummy", "",
  1110. libnetwork.NetworkOptionGeneric(getEmptyGenericOption()))
  1111. if err != nil {
  1112. // Only fail if we could not find the plugin driver
  1113. if _, ok := err.(types.NotFoundError); ok {
  1114. t.Fatal(err)
  1115. }
  1116. return
  1117. }
  1118. defer func() {
  1119. if err := n.Delete(); err != nil {
  1120. t.Fatal(err)
  1121. }
  1122. }()
  1123. }
  1124. var (
  1125. once sync.Once
  1126. start = make(chan struct{})
  1127. done = make(chan chan struct{}, numThreads-1)
  1128. origns = netns.None()
  1129. testns = netns.None()
  1130. sboxes = make([]libnetwork.Sandbox, numThreads)
  1131. )
  1132. const (
  1133. iterCnt = 25
  1134. numThreads = 3
  1135. first = 1
  1136. last = numThreads
  1137. debug = false
  1138. )
  1139. func createGlobalInstance(t *testing.T) {
  1140. var err error
  1141. defer close(start)
  1142. origns, err = netns.Get()
  1143. if err != nil {
  1144. t.Fatal(err)
  1145. }
  1146. if testutils.IsRunningInContainer() {
  1147. testns = origns
  1148. } else {
  1149. testns, err = netns.New()
  1150. if err != nil {
  1151. t.Fatal(err)
  1152. }
  1153. }
  1154. netOption := options.Generic{
  1155. netlabel.GenericData: options.Generic{
  1156. "BridgeName": "network",
  1157. },
  1158. }
  1159. net1, err := controller.NetworkByName("testhost")
  1160. if err != nil {
  1161. t.Fatal(err)
  1162. }
  1163. net2, err := createTestNetwork("bridge", "network2", netOption, nil, nil)
  1164. if err != nil {
  1165. t.Fatal(err)
  1166. }
  1167. _, err = net1.CreateEndpoint("pep1")
  1168. if err != nil {
  1169. t.Fatal(err)
  1170. }
  1171. _, err = net2.CreateEndpoint("pep2")
  1172. if err != nil {
  1173. t.Fatal(err)
  1174. }
  1175. _, err = net2.CreateEndpoint("pep3")
  1176. if err != nil {
  1177. t.Fatal(err)
  1178. }
  1179. if sboxes[first-1], err = controller.NewSandbox(fmt.Sprintf("%drace", first), libnetwork.OptionUseDefaultSandbox()); err != nil {
  1180. t.Fatal(err)
  1181. }
  1182. for thd := first + 1; thd <= last; thd++ {
  1183. if sboxes[thd-1], err = controller.NewSandbox(fmt.Sprintf("%drace", thd)); err != nil {
  1184. t.Fatal(err)
  1185. }
  1186. }
  1187. }
  1188. func debugf(format string, a ...interface{}) (int, error) {
  1189. if debug {
  1190. return fmt.Printf(format, a...)
  1191. }
  1192. return 0, nil
  1193. }