| Giorgi Lekveishvili | 77ee2dc | 2023-12-11 16:51:10 +0400 | [diff] [blame] | 1 | package tasks |
| 2 | |
| 3 | import ( |
| 4 | "fmt" |
| Giorgi Lekveishvili | 0a0ca0e | 2024-04-01 09:07:41 +0400 | [diff] [blame] | 5 | "sync" |
| Giorgi Lekveishvili | 77ee2dc | 2023-12-11 16:51:10 +0400 | [diff] [blame] | 6 | "testing" |
| Giorgi Lekveishvili | 0a0ca0e | 2024-04-01 09:07:41 +0400 | [diff] [blame] | 7 | "time" |
| Giorgi Lekveishvili | 77ee2dc | 2023-12-11 16:51:10 +0400 | [diff] [blame] | 8 | ) |
| 9 | |
| 10 | func TestLeaf(t *testing.T) { |
| 11 | l := newLeafTask("leaf", func() error { |
| 12 | return nil |
| 13 | }) |
| 14 | done := make(chan error) |
| 15 | l.OnDone(func(err error) { |
| 16 | done <- err |
| 17 | }) |
| 18 | go l.Start() |
| 19 | err := <-done |
| 20 | if err != nil { |
| 21 | t.Fatalf("Expected nil, got %s", err.Error()) |
| 22 | } |
| 23 | } |
| 24 | |
| 25 | func TestSequentialSuccess(t *testing.T) { |
| 26 | one := newLeafTask("one", func() error { |
| 27 | return nil |
| 28 | }) |
| 29 | two := newLeafTask("two", func() error { |
| 30 | return nil |
| 31 | }) |
| Giorgi Lekveishvili | 5c1b06e | 2024-03-28 15:19:44 +0400 | [diff] [blame] | 32 | l := newSequentialParentTask("parent", true, &one, &two) |
| Giorgi Lekveishvili | 77ee2dc | 2023-12-11 16:51:10 +0400 | [diff] [blame] | 33 | done := make(chan error) |
| 34 | l.OnDone(func(err error) { |
| 35 | done <- err |
| 36 | }) |
| 37 | go l.Start() |
| 38 | err := <-done |
| 39 | if err != nil { |
| 40 | t.Fatalf("Expected nil, got %s", err.Error()) |
| 41 | } |
| 42 | } |
| 43 | |
| 44 | func TestSequentialFailsFirst(t *testing.T) { |
| 45 | one := newLeafTask("one", func() error { |
| 46 | return fmt.Errorf("one") |
| 47 | }) |
| 48 | two := newLeafTask("two", func() error { |
| 49 | return nil |
| 50 | }) |
| Giorgi Lekveishvili | 5c1b06e | 2024-03-28 15:19:44 +0400 | [diff] [blame] | 51 | l := newSequentialParentTask("parent", true, &one, &two) |
| Giorgi Lekveishvili | 77ee2dc | 2023-12-11 16:51:10 +0400 | [diff] [blame] | 52 | done := make(chan error) |
| 53 | l.OnDone(func(err error) { |
| 54 | done <- err |
| 55 | }) |
| 56 | go l.Start() |
| 57 | err := <-done |
| 58 | if err == nil || err.Error() != "one" { |
| 59 | t.Fatalf("Expected one, got %s", err) |
| 60 | } |
| 61 | } |
| 62 | |
| 63 | func TestSequentialFailsSecond(t *testing.T) { |
| 64 | one := newLeafTask("one", func() error { |
| 65 | fmt.Println("one") |
| 66 | return nil |
| 67 | }) |
| 68 | two := newLeafTask("two", func() error { |
| 69 | fmt.Println("two") |
| 70 | return fmt.Errorf("two") |
| 71 | }) |
| Giorgi Lekveishvili | 5c1b06e | 2024-03-28 15:19:44 +0400 | [diff] [blame] | 72 | l := newSequentialParentTask("parent", true, &one, &two) |
| Giorgi Lekveishvili | 77ee2dc | 2023-12-11 16:51:10 +0400 | [diff] [blame] | 73 | done := make(chan error) |
| 74 | l.OnDone(func(err error) { |
| 75 | done <- err |
| 76 | }) |
| 77 | go l.Start() |
| 78 | err := <-done |
| 79 | if err == nil || err.Error() != "two" { |
| 80 | t.Fatalf("Expected two, got %s", err) |
| 81 | } |
| 82 | } |
| Giorgi Lekveishvili | 0a0ca0e | 2024-04-01 09:07:41 +0400 | [diff] [blame] | 83 | |
| 84 | func TestConcurrentTaskSucceeds_WaitsForAllChildren(t *testing.T) { |
| 85 | cnt := 0 |
| 86 | var m sync.Mutex |
| 87 | one := newLeafTask("one", func() error { |
| 88 | m.Lock() |
| 89 | defer m.Unlock() |
| 90 | cnt++ |
| 91 | return nil |
| 92 | }) |
| 93 | two := newLeafTask("two", func() error { |
| 94 | time.Sleep(1 * time.Second) |
| 95 | m.Lock() |
| 96 | defer m.Unlock() |
| 97 | cnt++ |
| 98 | return nil |
| 99 | }) |
| 100 | l := newConcurrentParentTask("parent", true, &one, &two) |
| 101 | done := make(chan error) |
| 102 | l.OnDone(func(err error) { |
| 103 | done <- err |
| 104 | }) |
| 105 | go l.Start() |
| 106 | err := <-done |
| 107 | if err != nil { |
| 108 | t.Fatalf("Expected nil, got %s", err.Error()) |
| 109 | } |
| 110 | if cnt != 2 { |
| 111 | t.Fatalf("Expected 2, got %d", cnt) |
| 112 | } |
| 113 | } |