libnetwork_test.go 31 KB

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