requireIdleInTransactionTimeout
Diagnostic Category: lint/safety/requireIdleInTransactionTimeout
Since: vnext
Sources:
- Inspired from: pgfence/missing-idle-timeout
Description
Dangerous lock statements should be preceded by SET idle_in_transaction_session_timeout.
A transaction holding dangerous locks that goes idle (e.g., due to application errors)
will block other operations indefinitely. Setting idle_in_transaction_session_timeout
ensures the session is terminated if it sits idle too long.
Examples
Invalid
ALTER TABLE users ADD COLUMN email TEXT;
code-block.sql:1:1 lint/safety/requireIdleInTransactionTimeout ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
! Statement takes a dangerous lock without idle_in_transaction_session_timeout set.
> 1 │ ALTER TABLE users ADD COLUMN email TEXT;
│ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
2 │
i Run SET idle_in_transaction_session_timeout = '...' before this statement to prevent idle transactions from holding locks.
Valid
CREATE INDEX CONCURRENTLY users_email_idx ON users(email);
How to configure
{
"linter": {
"rules": {
"safety": {
"requireIdleInTransactionTimeout": "error"
}
}
}
}