File size: 2,268 Bytes
651d019
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
package concurrency_test

import (
	"context"
	"fmt"
	"time"

	. "github.com/mudler/LocalAI/pkg/concurrency"
	. "github.com/onsi/ginkgo/v2"
	. "github.com/onsi/gomega"
)

var _ = Describe("pkg/concurrency unit tests", func() {
	It("can be used to recieve a result across goroutines", func() {
		jr, wjr := NewJobResult[string, string]("foo")
		Expect(jr).ToNot(BeNil())
		Expect(wjr).ToNot(BeNil())

		go func(wjr *WritableJobResult[string, string]) {
			time.Sleep(time.Second * 5)
			wjr.SetResult("bar", nil)
		}(wjr)

		resPtr, err := jr.Wait(context.Background())
		Expect(err).To(BeNil())
		Expect(jr.Request).ToNot(BeNil())
		Expect(*jr.Request()).To(Equal("foo"))
		Expect(resPtr).ToNot(BeNil())
		Expect(*resPtr).To(Equal("bar"))

	})

	It("can be used to recieve an error across goroutines", func() {
		jr, wjr := NewJobResult[string, string]("foo")
		Expect(jr).ToNot(BeNil())
		Expect(wjr).ToNot(BeNil())

		go func(wjr *WritableJobResult[string, string]) {
			time.Sleep(time.Second * 5)
			wjr.SetResult("", fmt.Errorf("test"))
		}(wjr)

		_, err := jr.Wait(context.Background())
		Expect(jr.Request).ToNot(BeNil())
		Expect(*jr.Request()).To(Equal("foo"))
		Expect(err).ToNot(BeNil())
		Expect(err).To(MatchError("test"))
	})

	It("can properly handle timeouts", func() {
		jr, wjr := NewJobResult[string, string]("foo")
		Expect(jr).ToNot(BeNil())
		Expect(wjr).ToNot(BeNil())

		go func(wjr *WritableJobResult[string, string]) {
			time.Sleep(time.Second * 5)
			wjr.SetResult("bar", nil)
		}(wjr)

		timeout1s, c1 := context.WithTimeoutCause(context.Background(), time.Second, fmt.Errorf("timeout"))
		timeout10s, c2 := context.WithTimeoutCause(context.Background(), time.Second*10, fmt.Errorf("timeout"))

		_, err := jr.Wait(timeout1s)
		Expect(jr.Request).ToNot(BeNil())
		Expect(*jr.Request()).To(Equal("foo"))
		Expect(err).ToNot(BeNil())
		Expect(err).To(MatchError(context.DeadlineExceeded))

		resPtr, err := jr.Wait(timeout10s)
		Expect(jr.Request).ToNot(BeNil())
		Expect(*jr.Request()).To(Equal("foo"))
		Expect(err).To(BeNil())
		Expect(resPtr).ToNot(BeNil())
		Expect(*resPtr).To(Equal("bar"))

		// Is this needed? Cleanup Either Way.
		c1()
		c2()
	})
})