value_test.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. package csync
  2. import (
  3. "sync"
  4. "testing"
  5. "github.com/stretchr/testify/require"
  6. )
  7. func TestValue_GetSet(t *testing.T) {
  8. t.Parallel()
  9. v := NewValue(42)
  10. require.Equal(t, 42, v.Get())
  11. v.Set(100)
  12. require.Equal(t, 100, v.Get())
  13. }
  14. func TestValue_ZeroValue(t *testing.T) {
  15. t.Parallel()
  16. v := NewValue("")
  17. require.Equal(t, "", v.Get())
  18. v.Set("hello")
  19. require.Equal(t, "hello", v.Get())
  20. }
  21. func TestValue_Struct(t *testing.T) {
  22. t.Parallel()
  23. type config struct {
  24. Name string
  25. Count int
  26. }
  27. v := NewValue(config{Name: "test", Count: 1})
  28. require.Equal(t, config{Name: "test", Count: 1}, v.Get())
  29. v.Set(config{Name: "updated", Count: 2})
  30. require.Equal(t, config{Name: "updated", Count: 2}, v.Get())
  31. }
  32. func TestValue_PointerPanics(t *testing.T) {
  33. t.Parallel()
  34. require.Panics(t, func() {
  35. NewValue(&struct{}{})
  36. })
  37. }
  38. func TestValue_SlicePanics(t *testing.T) {
  39. t.Parallel()
  40. require.Panics(t, func() {
  41. NewValue([]string{"a", "b"})
  42. })
  43. }
  44. func TestValue_MapPanics(t *testing.T) {
  45. t.Parallel()
  46. require.Panics(t, func() {
  47. NewValue(map[string]int{"a": 1})
  48. })
  49. }
  50. func TestValue_ConcurrentAccess(t *testing.T) {
  51. t.Parallel()
  52. v := NewValue(0)
  53. var wg sync.WaitGroup
  54. // Concurrent writers.
  55. for i := range 100 {
  56. wg.Add(1)
  57. go func(val int) {
  58. defer wg.Done()
  59. v.Set(val)
  60. }(i)
  61. }
  62. // Concurrent readers.
  63. for range 100 {
  64. wg.Go(func() {
  65. _ = v.Get()
  66. })
  67. }
  68. wg.Wait()
  69. // Value should be one of the set values (0-99).
  70. got := v.Get()
  71. require.GreaterOrEqual(t, got, 0)
  72. require.Less(t, got, 100)
  73. }