File: hanging_test.go

package info (click to toggle)
golang-github-onsi-ginkgo-v2 2.27.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 4,340 kB
  • sloc: javascript: 65; makefile: 23; sh: 14
file content (53 lines) | stat: -rw-r--r-- 1,028 bytes parent folder | download | duplicates (3)
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
package hanging_suite_test

import (
	"fmt"
	"time"

	. "github.com/onsi/ginkgo/v2"
)

var _ = AfterSuite(func() {
	fmt.Println("Heading Out After Suite")
})

var _ = ReportAfterSuite("", func(r Report) {
	fmt.Println("Reporting at the end")
})

var _ = Describe("HangingSuite", func() {
	BeforeEach(func() {
		fmt.Fprintln(GinkgoWriter, "Just beginning")
	})

	Context("inner context", func() {
		BeforeEach(func() {
			fmt.Fprintln(GinkgoWriter, "Almost there...")
		})

		It("should hang out for a while", func(ctx SpecContext) {
			fmt.Fprintln(GinkgoWriter, "Hanging Out")
			fmt.Println("Sleeping...")
			select {
			case <-ctx.Done():
				fmt.Println("Got your signal, but still taking a nap")
				time.Sleep(time.Hour)
			case <-time.After(time.Hour):
			}
		})

		AfterEach(func() {
			fmt.Println("Cleaning up once...")
		})
	})

	AfterEach(func() {
		fmt.Println("Cleaning up twice...")
		fmt.Println("Sleeping again...")
		time.Sleep(time.Hour)
	})

	AfterEach(func() {
		fmt.Println("Cleaning up thrice...")
	})
})