(t *testing.T)
| 456 | } |
| 457 | |
| 458 | func TestDrainConnDuringReconnect(t *testing.T) { |
| 459 | s := RunDefaultServer() |
| 460 | defer s.Shutdown() |
| 461 | |
| 462 | done := make(chan bool, 1) |
| 463 | closedCb := func(nc *nats.Conn) { |
| 464 | done <- true |
| 465 | } |
| 466 | |
| 467 | nc, err := nats.Connect(nats.DefaultURL, |
| 468 | nats.ClosedHandler(closedCb), |
| 469 | nats.DrainTimeout(20*time.Millisecond)) |
| 470 | if err != nil { |
| 471 | t.Fatalf("Failed to create default connection: %v", err) |
| 472 | } |
| 473 | defer nc.Close() |
| 474 | |
| 475 | // Shutdown the server. |
| 476 | s.Shutdown() |
| 477 | |
| 478 | waitFor(t, time.Second, 10*time.Millisecond, func() error { |
| 479 | if nc.IsReconnecting() { |
| 480 | return nil |
| 481 | } |
| 482 | return errors.New("Not reconnecting yet") |
| 483 | }) |
| 484 | |
| 485 | // This should work correctly. |
| 486 | if err := nc.Drain(); err != nats.ErrConnectionReconnecting { |
| 487 | t.Fatalf("Unexpected error on drain: %v", err) |
| 488 | } |
| 489 | |
| 490 | // Closed should still fire. |
| 491 | select { |
| 492 | case <-done: |
| 493 | case <-time.After(2 * time.Second): |
| 494 | t.Fatalf("Timeout waiting for closed state for connection") |
| 495 | } |
| 496 | } |
| 497 | |
| 498 | func TestDrainClosedHandlerRace(t *testing.T) { |
| 499 | s := RunDefaultServer() |
nothing calls this directly
no test coverage detected