store_test.go 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. package libnetwork
  2. import (
  3. "fmt"
  4. "os"
  5. "testing"
  6. "github.com/docker/docker/libnetwork/config"
  7. "github.com/docker/docker/libnetwork/datastore"
  8. "github.com/docker/docker/libnetwork/netlabel"
  9. "github.com/docker/docker/libnetwork/options"
  10. "github.com/docker/libkv/store"
  11. )
  12. func testLocalBackend(t *testing.T, provider, url string, storeConfig *store.Config) {
  13. cfgOptions := []config.Option{}
  14. cfgOptions = append(cfgOptions, config.OptionLocalKVProvider(provider))
  15. cfgOptions = append(cfgOptions, config.OptionLocalKVProviderURL(url))
  16. cfgOptions = append(cfgOptions, config.OptionLocalKVProviderConfig(storeConfig))
  17. driverOptions := options.Generic{}
  18. genericOption := make(map[string]interface{})
  19. genericOption[netlabel.GenericData] = driverOptions
  20. cfgOptions = append(cfgOptions, config.OptionDriverConfig("host", genericOption))
  21. ctrl, err := New(cfgOptions...)
  22. if err != nil {
  23. t.Fatalf("Error new controller: %v", err)
  24. }
  25. nw, err := ctrl.NewNetwork("host", "host", "")
  26. if err != nil {
  27. t.Fatalf("Error creating default \"host\" network: %v", err)
  28. }
  29. ep, err := nw.CreateEndpoint("newendpoint", []EndpointOption{}...)
  30. if err != nil {
  31. t.Fatalf("Error creating endpoint: %v", err)
  32. }
  33. store := ctrl.(*controller).getStore(datastore.LocalScope).KVStore()
  34. if exists, err := store.Exists(datastore.Key(datastore.NetworkKeyPrefix, nw.ID())); !exists || err != nil {
  35. t.Fatalf("Network key should have been created.")
  36. }
  37. if exists, err := store.Exists(datastore.Key([]string{datastore.EndpointKeyPrefix, nw.ID(), ep.ID()}...)); !exists || err != nil {
  38. t.Fatalf("Endpoint key should have been created.")
  39. }
  40. store.Close()
  41. // test restore of local store
  42. ctrl, err = New(cfgOptions...)
  43. if err != nil {
  44. t.Fatalf("Error creating controller: %v", err)
  45. }
  46. if _, err = ctrl.NetworkByID(nw.ID()); err != nil {
  47. t.Fatalf("Error getting network %v", err)
  48. }
  49. }
  50. // OptionBoltdbWithRandomDBFile function returns a random dir for local store backend
  51. func OptionBoltdbWithRandomDBFile() ([]config.Option, error) {
  52. tmp, err := os.CreateTemp("", "libnetwork-")
  53. if err != nil {
  54. return nil, fmt.Errorf("Error creating temp file: %v", err)
  55. }
  56. if err := tmp.Close(); err != nil {
  57. return nil, fmt.Errorf("Error closing temp file: %v", err)
  58. }
  59. cfgOptions := []config.Option{}
  60. cfgOptions = append(cfgOptions, config.OptionLocalKVProvider("boltdb"))
  61. cfgOptions = append(cfgOptions, config.OptionLocalKVProviderURL(tmp.Name()))
  62. sCfg := &store.Config{Bucket: "testBackend"}
  63. cfgOptions = append(cfgOptions, config.OptionLocalKVProviderConfig(sCfg))
  64. return cfgOptions, nil
  65. }
  66. func TestMultipleControllersWithSameStore(t *testing.T) {
  67. cfgOptions, err := OptionBoltdbWithRandomDBFile()
  68. if err != nil {
  69. t.Fatalf("Error getting random boltdb configs %v", err)
  70. }
  71. ctrl1, err := New(cfgOptions...)
  72. if err != nil {
  73. t.Fatalf("Error new controller: %v", err)
  74. }
  75. defer ctrl1.Stop()
  76. // Use the same boltdb file without closing the previous controller
  77. _, err = New(cfgOptions...)
  78. if err != nil {
  79. t.Fatalf("Local store must support concurrent controllers")
  80. }
  81. }