File: sinks_test.go

package info (click to toggle)
docker.io 20.10.24%2Bdfsg1-1%2Bdeb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 60,824 kB
  • sloc: sh: 5,621; makefile: 593; ansic: 179; python: 162; asm: 7
file content (48 lines) | stat: -rw-r--r-- 1,012 bytes parent folder | download | duplicates (6)
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
package watch

import (
	"testing"
	"time"

	"github.com/stretchr/testify/require"
)

// TestTimeoutDropErrSinkGen tests the full chain of sinks
func TestTimeoutDropErrSinkGen(t *testing.T) {
	require := require.New(t)
	doneChan := make(chan struct{})

	sinkGen := NewTimeoutDropErrSinkGen(time.Second)

	// Generate two channels to perform the following test-cases
	sink, ch := sinkGen.NewChannelSink()
	sink2, ch2 := sinkGen.NewChannelSink()

	go func() {
		for {
			select {
			case <-ch.C:
			case <-doneChan:
				return
			}
		}
	}()
	require.NoError(sink.Write("some event"))

	// Make sure the sink times out on the write operation if the channel is
	// not read from.
	err := sink2.Write("some event")
	require.Error(err)
	require.Equal(ErrSinkTimeout, err)

	// Ensure that hitting a timeout causes the sink to close
	<-ch2.Done()

	// Make sure that closing a sink closes the channel
	errClose := sink.Close()
	<-ch.Done()
	require.NoError(errClose)

	// Close the leaking goroutine
	close(doneChan)
}