All rules
GCI0015BlockData Integrity

Data Integrity Risk

Detects unchecked casts, mass assignment without validation, and SQL ON CONFLICT IGNORE patterns that silently discard errors.

Why this rule exists

Silent data discard is the worst kind of bug: the system behaves correctly under tests, but production data slowly diverges from reality. By the time anyone notices, the audit trail is gone.

Code example

Triggers the rule
+ INSERT INTO orders (id, total) VALUES (@id, @total) ON CONFLICT DO NOTHING;
Passes the rule
+ INSERT INTO orders (id, total) VALUES (@id, @total)
+ ON CONFLICT (id) DO UPDATE SET total = EXCLUDED.total
+ WHERE orders.updated_at < EXCLUDED.updated_at;

Configuration

Disable or adjust the severity of this rule in .gauntletci.json:

{
  "rules": {
    "GCI0015": { "enabled": true, "severity": "Block" }
  }
}

See Configuration for the full schema.

Related rules

Discussed in

Real-world evidence

Implemented in src/GauntletCI.Core/Rules/Implementations/GCI0015_*.cs.

About the author

Eric Cogen -- Founder, GauntletCI

Twenty years as a senior technical consultant building and modernizing enterprise platforms across .NET, AWS, serverless, microservices, and AI-driven systems.