context_test.go 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. package context_test
  2. import (
  3. "context"
  4. "fmt"
  5. "testing"
  6. "time"
  7. "gitee.com/wecisecode/util/logger"
  8. )
  9. func TestContext(t *testing.T) {
  10. ctx, cancel := context.WithCancelCause(context.Background())
  11. cancel(fmt.Errorf("%s", "cancel"))
  12. go func() {
  13. for {
  14. select {
  15. case <-ctx.Done():
  16. err := ctx.Err()
  17. if err == context.Canceled {
  18. err = context.Cause(ctx)
  19. }
  20. logger.Info("context done", err)
  21. default:
  22. }
  23. time.Sleep(5 * time.Second)
  24. }
  25. }()
  26. time.Sleep(1 * time.Hour)
  27. }
  28. func TestContextDone(t *testing.T) {
  29. ctx, cancel := context.WithCancelCause(context.Background())
  30. go func() {
  31. for {
  32. select {
  33. case <-ctx.Done():
  34. err := ctx.Err()
  35. if err == context.Canceled {
  36. err = context.Cause(ctx)
  37. }
  38. logger.Info("context done 1", err)
  39. default:
  40. }
  41. time.Sleep(5 * time.Second)
  42. }
  43. }()
  44. go func() {
  45. for {
  46. select {
  47. case <-ctx.Done():
  48. err := ctx.Err()
  49. if err == context.Canceled {
  50. err = context.Cause(ctx)
  51. }
  52. logger.Info("context done 2", err)
  53. default:
  54. }
  55. time.Sleep(5 * time.Second)
  56. }
  57. }()
  58. go func() {
  59. for {
  60. select {
  61. case <-ctx.Done():
  62. err := ctx.Err()
  63. if err == context.Canceled {
  64. err = context.Cause(ctx)
  65. }
  66. logger.Info("context done 3", err)
  67. default:
  68. }
  69. time.Sleep(5 * time.Second)
  70. }
  71. }()
  72. cancel(fmt.Errorf("%s", "cancel"))
  73. time.Sleep(1 * time.Hour)
  74. }