Data and Schema Compatibility
Detects removed serialization attributes and enum member removals that may break wire formats or persisted data.
Why this rule exists
Removing an enum value or [JsonPropertyName] attribute breaks every consumer that has that value persisted in a database, on a queue, or in a snapshot. The deploy succeeds; the next read fails.
Code example
public enum OrderStatus
{
Pending,
- Processing,
Shipped
} public enum OrderStatus
{
Pending,
[Obsolete("Use Fulfilled")] Processing,
Shipped,
+ Fulfilled,
}Configuration
Disable or adjust the severity of this rule in .gauntletci.json:
{
"rules": {
"GCI0021": { "enabled": true, "severity": "Block" }
}
}See Configuration for the full schema.
Related rules
Breaking Change Risk
Detects [Obsolete] attribute additions and removals on public APIs. Removing a deprecation guard is Block-severity; adding one is a Warn-level review signal.
Data Integrity Risk
Detects unchecked casts, mass assignment without validation, and SQL ON CONFLICT IGNORE patterns that silently discard errors.
SQL Column Truncation Risk
Detects short nvarchar(N) or varchar(N) column definitions that may silently truncate data when real-world values exceed the column width.
Discussed in
Implemented in src/GauntletCI.Core/Rules/Implementations/GCI0021_*.cs.
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.
