// Copyright 2013 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef SQL_TEST_SCOPED_ERROR_EXPECTER_H_ #define SQL_TEST_SCOPED_ERROR_EXPECTER_H_ #include <set> #include "sql/database.h" // This is not strictly necessary for the operation of ScopedErrorExpecter, but // the class is not useful without the SQLite error codes. #include "third_party/sqlite/sqlite3.h" namespace sql { namespace test { // sql::Database and sql::Statement treat most SQLite errors as fatal in debug // mode. The goal is to catch SQL errors before code is shipped to production. // That fatal check makes it hard to write tests for error-handling code. This // scoper lists errors to expect and treat as non-fatal. Errors are expected // globally (on all connections). // // Since errors can be very context-dependent, the class is pedantic - specific // errors must be expected, and every expected error must be seen. // // NOTE(shess): There are still fatal error cases this does not address. If // your test is handling database errors and you're hitting a case not handled, // contact me. class ScopedErrorExpecter { … }; } // namespace test } // namespace sql #endif // SQL_TEST_SCOPED_ERROR_EXPECTER_H_