store_test.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. package libnetwork
  2. import (
  3. "os"
  4. "path/filepath"
  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. defer ctrl.Stop()
  26. nw, err := ctrl.NewNetwork("host", "host", "")
  27. if err != nil {
  28. t.Fatalf("Error creating default \"host\" network: %v", err)
  29. }
  30. ep, err := nw.CreateEndpoint("newendpoint", []EndpointOption{}...)
  31. if err != nil {
  32. t.Fatalf("Error creating endpoint: %v", err)
  33. }
  34. store := ctrl.getStore().KVStore()
  35. if exists, err := store.Exists(datastore.Key(datastore.NetworkKeyPrefix, nw.ID())); !exists || err != nil {
  36. t.Fatalf("Network key should have been created.")
  37. }
  38. if exists, err := store.Exists(datastore.Key([]string{datastore.EndpointKeyPrefix, nw.ID(), ep.ID()}...)); !exists || err != nil {
  39. t.Fatalf("Endpoint key should have been created.")
  40. }
  41. store.Close()
  42. // test restore of local store
  43. ctrl, err = New(cfgOptions...)
  44. if err != nil {
  45. t.Fatalf("Error creating controller: %v", err)
  46. }
  47. defer ctrl.Stop()
  48. if _, err = ctrl.NetworkByID(nw.ID()); err != nil {
  49. t.Fatalf("Error getting network %v", err)
  50. }
  51. }
  52. // OptionBoltdbWithRandomDBFile function returns a random dir for local store backend
  53. func OptionBoltdbWithRandomDBFile(t *testing.T) config.Option {
  54. t.Helper()
  55. tmp := filepath.Join(t.TempDir(), "bolt.db")
  56. if err := os.WriteFile(tmp, nil, 0o600); err != nil {
  57. t.Fatal(err)
  58. }
  59. return func(c *config.Config) {
  60. config.OptionLocalKVProvider("boltdb")(c)
  61. config.OptionLocalKVProviderURL(tmp)(c)
  62. config.OptionLocalKVProviderConfig(&store.Config{Bucket: "testBackend"})(c)
  63. }
  64. }
  65. func TestMultipleControllersWithSameStore(t *testing.T) {
  66. cfgOptions := OptionBoltdbWithRandomDBFile(t)
  67. ctrl1, err := New(cfgOptions)
  68. if err != nil {
  69. t.Fatalf("Error new controller: %v", err)
  70. }
  71. defer ctrl1.Stop()
  72. // Use the same boltdb file without closing the previous controller
  73. ctrl2, err := New(cfgOptions)
  74. if err != nil {
  75. t.Fatalf("Local store must support concurrent controllers")
  76. }
  77. ctrl2.Stop()
  78. }