# CLOTHO: Directed Test Generation for Weakly Consistent Database Systems

**Authors:** Kia Rahmani, Kartik Nagar, Benjamin Delaware, Suresh Jagannathan

arXiv: 1908.05655 · 2019-08-16

## TL;DR

CLOTHO is a novel testing framework that automatically detects serializability violations in Java database applications running on weakly consistent storage, improving debugging and reliability in distributed systems.

## Contribution

It introduces CLOTHO, the first automated test generation tool combining static analysis and model checking for serializability violations in geo-replicated databases.

## Key findings

- Successfully detects serializability violations in benchmarks
- Generates concrete test inputs for real deployment environments
- Enhances debugging of weakly consistent database applications

## Abstract

Relational database applications are notoriously difficult to test and debug. Concurrent execution of database transactions may violate complex structural invariants that constraint how changes to the contents of one (shared) table affect the contents of another. Simplifying the underlying concurrency model is one way to ameliorate the difficulty of understanding how concurrent accesses and updates can affect database state with respect to these sophisticated properties. Enforcing serializable execution of all transactions achieves this simplification, but it comes at a significant price in performance, especially at scale, where database state is often replicated to improve latency and availability. To address these challenges, this paper presents a novel testing framework for detecting serializability violations in (SQL) database-backed Java applications executing on weakly-consistent storage systems. We manifest our approach in a tool named CLOTHO, that combines a static analyzer and a model checker to generate abstract executions, discover serializability violations in these executions, and translate them back into concrete test inputs suitable for deployment in a test environment. To the best of our knowledge, CLOTHO is the first automated test generation facility for identifying serializability anomalies of Java applications intended to operate in geo-replicated distributed environments. An experimental evaluation on a set of industry-standard benchmarks demonstrates the utility of our approach.

## Full text

_Full body text omitted from this summary view._ Fetch the complete paper as Markdown: https://tomesphere.com/paper/1908.05655/full.md

## Figures

53 figures with captions in the complete paper: https://tomesphere.com/paper/1908.05655/full.md

## References

48 references — full list in the complete paper: https://tomesphere.com/paper/1908.05655/full.md

---
Source: https://tomesphere.com/paper/1908.05655