mirror of
https://github.com/postgres/postgres.git
synced 2025-07-02 09:02:37 +03:00
Assign error codes where missing for user-facing failures
All the errors triggered in the code paths patched here would cause the backend to issue an internal_error errcode, which is a state that should be used only for "can't happen" situations. However, these code paths are reachable by the regression tests, and could be seen by users in valid cases. Some regression tests expect internal errcodes as they manipulate the backend state to cause corruption (like checksums), or use elog() because it is more convenient (like injection points), these have no need to change. This reduces the number of internal failures triggered in a check-world by more than half, while providing correct errcodes for these valid cases. Reviewed-by: Robert Haas Discussion: https://postgr.es/m/Zic_GNgos5sMxKoa@paquier.xyz
This commit is contained in:
@ -312,9 +312,11 @@ currtid_internal(Relation rel, ItemPointer tid)
|
||||
return currtid_for_view(rel, tid);
|
||||
|
||||
if (!RELKIND_HAS_STORAGE(rel->rd_rel->relkind))
|
||||
elog(ERROR, "cannot look at latest visible tid for relation \"%s.%s\"",
|
||||
get_namespace_name(RelationGetNamespace(rel)),
|
||||
RelationGetRelationName(rel));
|
||||
ereport(ERROR,
|
||||
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
|
||||
errmsg("cannot look at latest visible tid for relation \"%s.%s\"",
|
||||
get_namespace_name(RelationGetNamespace(rel)),
|
||||
RelationGetRelationName(rel)));
|
||||
|
||||
ItemPointerCopy(tid, result);
|
||||
|
||||
@ -349,16 +351,22 @@ currtid_for_view(Relation viewrel, ItemPointer tid)
|
||||
if (strcmp(NameStr(attr->attname), "ctid") == 0)
|
||||
{
|
||||
if (attr->atttypid != TIDOID)
|
||||
elog(ERROR, "ctid isn't of type TID");
|
||||
ereport(ERROR,
|
||||
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
|
||||
errmsg("ctid isn't of type TID"));
|
||||
tididx = i;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (tididx < 0)
|
||||
elog(ERROR, "currtid cannot handle views with no CTID");
|
||||
ereport(ERROR,
|
||||
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
|
||||
errmsg("currtid cannot handle views with no CTID"));
|
||||
rulelock = viewrel->rd_rules;
|
||||
if (!rulelock)
|
||||
elog(ERROR, "the view has no rules");
|
||||
ereport(ERROR,
|
||||
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
|
||||
errmsg("the view has no rules"));
|
||||
for (i = 0; i < rulelock->numLocks; i++)
|
||||
{
|
||||
rewrite = rulelock->rules[i];
|
||||
@ -368,7 +376,9 @@ currtid_for_view(Relation viewrel, ItemPointer tid)
|
||||
TargetEntry *tle;
|
||||
|
||||
if (list_length(rewrite->actions) != 1)
|
||||
elog(ERROR, "only one select rule is allowed in views");
|
||||
ereport(ERROR,
|
||||
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
|
||||
errmsg("only one select rule is allowed in views"));
|
||||
query = (Query *) linitial(rewrite->actions);
|
||||
tle = get_tle_by_resno(query->targetList, tididx + 1);
|
||||
if (tle && tle->expr && IsA(tle->expr, Var))
|
||||
|
Reference in New Issue
Block a user