etcd_test.go 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. // Copyright 2019 Yunion
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package lockman
  15. import (
  16. "sync"
  17. "testing"
  18. "yunion.io/x/onecloud/pkg/util/atexit"
  19. )
  20. func TestEctdLockManager(t *testing.T) {
  21. cfgs := []*testLockManagerConfig{}
  22. shared := newSharedObject()
  23. for i := 0; i < 4; i++ {
  24. lockman, err := NewEtcdLockManager(&SEtcdLockManagerConfig{
  25. LockPrefix: "test-etcd-lock-manager",
  26. Endpoints: []string{"localhost:2379"},
  27. })
  28. if err != nil {
  29. t.Skipf("new etcd lockman: %v", err)
  30. }
  31. cfg := &testLockManagerConfig{
  32. players: 3,
  33. cycles: 3,
  34. lockman: lockman,
  35. shared: shared,
  36. }
  37. cfgs = append(cfgs, cfg)
  38. }
  39. defer atexit.Handle()
  40. wg := &sync.WaitGroup{}
  41. wg.Add(len(cfgs))
  42. for _, cfg := range cfgs {
  43. go func(cfg *testLockManagerConfig) {
  44. testLockManager(t, cfg)
  45. wg.Done()
  46. }(cfg)
  47. }
  48. wg.Wait()
  49. }