(ctx context.Context, uri string, timeout time.Duration)
| 190 | } |
| 191 | |
| 192 | func waitForPostgres(ctx context.Context, uri string, timeout time.Duration) error { |
| 193 | deadline := time.Now().Add(timeout) |
| 194 | ticker := time.NewTicker(100 * time.Millisecond) |
| 195 | defer ticker.Stop() |
| 196 | |
| 197 | var lastErr error |
| 198 | for { |
| 199 | select { |
| 200 | case <-ctx.Done(): |
| 201 | return fmt.Errorf("context cancelled: %w (last error: %v)", ctx.Err(), lastErr) |
| 202 | case <-ticker.C: |
| 203 | if time.Now().After(deadline) { |
| 204 | return fmt.Errorf("timeout waiting for PostgreSQL (last error: %v)", lastErr) |
| 205 | } |
| 206 | conn, err := pgx.Connect(ctx, uri) |
| 207 | if err != nil { |
| 208 | lastErr = err |
| 209 | slog.Debug("native/postgres", "connect-attempt", err) |
| 210 | continue |
| 211 | } |
| 212 | if err := conn.Ping(ctx); err != nil { |
| 213 | lastErr = err |
| 214 | conn.Close(ctx) |
| 215 | continue |
| 216 | } |
| 217 | conn.Close(ctx) |
| 218 | return nil |
| 219 | } |
| 220 | } |
| 221 | } |
no test coverage detected