blob: 6d1c5df4ec142f2f56b70755db3b069c35634b6b [file] [log] [blame]
// Copyright 2013 The Chromium Authors. All rights reserved.
// 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_IGNORER_H_
#define SQL_TEST_SCOPED_ERROR_IGNORER_H_
#include <set>
#include "base/macros.h"
#include "sql/connection.h"
// This is not strictly necessary for the operation of ScopedErrorIgnorer, but
// the class is not useful without the SQLite error codes.
#include "third_party/sqlite/sqlite3.h"
// TODO(shess): sql::test:: seems like it could be in order for this.
namespace sql {
// sql::Connection and sql::Statement treat most SQLite errors as
// fatal in debug mode. The intention is to catch inappropriate uses
// of SQL before the code is shipped to production. This makes it
// challenging to write tests for things like recovery from
// corruption. This scoper can be used to ignore selected errors
// during a test. Errors are ignored globally (on all connections).
//
// Since errors can be very context-dependent, the class is pedantic -
// specific errors must be ignored, and every error ignored 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 ScopedErrorIgnorer {
public:
ScopedErrorIgnorer();
~ScopedErrorIgnorer();
// Add an error to ignore. Extended error codes can be ignored
// specifically, or the base code can ignore an entire group
// (SQLITE_IOERR_* versus SQLITE_IOERR).
void IgnoreError(int err);
// Allow containing test to check if the errors were encountered.
// Failure to call results in ADD_FAILURE() in destructor.
bool CheckIgnoredErrors();
// Record an error and check if it should be ignored.
bool ShouldIgnore(int err);
// Expose sqlite3_libversion_number() so that clients don't have to add a
// dependency on third_party/sqlite.
static int SQLiteLibVersionNumber();
private:
// Storage for callback passed to Connection::SetErrorIgnorer().
Connection::ErrorIgnorerCallback callback_;
// Record whether CheckIgnoredErrors() has been called.
bool checked_;
// Errors to ignore.
std::set<int> ignore_errors_;
// Errors which have been ignored.
std::set<int> errors_ignored_;
DISALLOW_COPY_AND_ASSIGN(ScopedErrorIgnorer);
};
} // namespace sql
#endif // SQL_TEST_SCOPED_ERROR_IGNORER_H_