Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(62)

Unified Diff: content/browser/media/webrtc_identity_store_backend.cc

Issue 289343005: Do not CHECK on the result of Sql::Statement::Run. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: use ScopedVector Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | content/browser/media/webrtc_identity_store_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: content/browser/media/webrtc_identity_store_backend.cc
diff --git a/content/browser/media/webrtc_identity_store_backend.cc b/content/browser/media/webrtc_identity_store_backend.cc
index d599dcda742d08d3ffb80598acabdf432bb5a3d0..28e7186d97236cf05bbe82d954bc7d6a7162cec5 100644
--- a/content/browser/media/webrtc_identity_store_backend.cc
+++ b/content/browser/media/webrtc_identity_store_backend.cc
@@ -6,6 +6,8 @@
#include "base/file_util.h"
#include "base/files/file_path.h"
+#include "base/memory/scoped_vector.h"
+#include "base/strings/string_util.h"
#include "content/public/browser/browser_thread.h"
#include "net/base/net_errors.h"
#include "sql/error_delegate_util.h"
@@ -31,6 +33,7 @@ static bool InitDB(sql::Connection* db) {
db->DoesColumnExist(kWebRTCIdentityStoreDBName, "private_key") &&
db->DoesColumnExist(kWebRTCIdentityStoreDBName, "creation_time"))
return true;
+
if (!db->Execute("DROP TABLE webrtc_identity_store"))
return false;
}
@@ -153,7 +156,7 @@ class WebRTCIdentityStoreBackend::SqlLiteStorage
std::string identity_name;
Identity identity;
};
- typedef std::vector<PendingOperation*> PendingOperationList;
+ typedef ScopedVector<PendingOperation> PendingOperationList;
virtual ~SqlLiteStorage() {}
void OnDatabaseError(int error, sql::Statement* stmt);
@@ -343,7 +346,7 @@ void WebRTCIdentityStoreBackend::OnLoaded(scoped_ptr<IdentityMap> out_map) {
if (state_ != LOADING)
return;
- DVLOG(2) << "WebRTC identity store has loaded.";
+ DVLOG(3) << "WebRTC identity store has loaded.";
state_ = LOADED;
identities_.swap(*out_map);
@@ -370,7 +373,7 @@ void WebRTCIdentityStoreBackend::SqlLiteStorage::Load(IdentityMap* out_map) {
// from it.
const base::FilePath dir = path_.DirName();
if (!base::PathExists(dir) && !base::CreateDirectory(dir)) {
- DLOG(ERROR) << "Unable to open DB file path.";
+ DVLOG(2) << "Unable to open DB file path.";
return;
}
@@ -379,13 +382,13 @@ void WebRTCIdentityStoreBackend::SqlLiteStorage::Load(IdentityMap* out_map) {
db_->set_error_callback(base::Bind(&SqlLiteStorage::OnDatabaseError, this));
if (!db_->Open(path_)) {
- DLOG(ERROR) << "Unable to open DB.";
+ DVLOG(2) << "Unable to open DB.";
db_.reset();
return;
}
if (!InitDB(db_.get())) {
- DLOG(ERROR) << "Unable to init DB.";
+ DVLOG(2) << "Unable to init DB.";
db_.reset();
return;
}
@@ -470,21 +473,26 @@ void WebRTCIdentityStoreBackend::SqlLiteStorage::DeleteBetween(
sql::Transaction transaction(db_.get());
if (!transaction.Begin()) {
- DLOG(ERROR) << "Failed to begin the transaction.";
+ DVLOG(2) << "Failed to begin the transaction.";
+ return;
+ }
+
+ if (!del_stmt.Run()) {
+ DVLOG(2) << "Failed to run the delete statement.";
return;
}
- CHECK(del_stmt.Run());
- transaction.Commit();
+ if (!transaction.Commit())
+ DVLOG(2) << "Failed to commit the transaction.";
}
void WebRTCIdentityStoreBackend::SqlLiteStorage::OnDatabaseError(
int error,
sql::Statement* stmt) {
DCHECK(BrowserThread::CurrentlyOn(BrowserThread::DB));
- if (!sql::IsErrorCatastrophic(error))
- return;
+
db_->RazeAndClose();
+ // It's not safe to reset |db_| here.
}
void WebRTCIdentityStoreBackend::SqlLiteStorage::BatchOperation(
@@ -542,14 +550,19 @@ void WebRTCIdentityStoreBackend::SqlLiteStorage::Commit() {
sql::Transaction transaction(db_.get());
if (!transaction.Begin()) {
- DLOG(ERROR) << "Failed to begin the transaction.";
+ DVLOG(2) << "Failed to begin the transaction.";
return;
}
- for (PendingOperationList::iterator it = pending_operations_.begin();
- it != pending_operations_.end();
+ // Swaps |pending_operations_| into a temporary list to make sure
+ // |pending_operations_| is always cleared in case of DB errors.
+ PendingOperationList pending_operations_copy;
+ pending_operations_.swap(pending_operations_copy);
+
+ for (PendingOperationList::iterator it = pending_operations_copy.begin();
+ it != pending_operations_copy.end();
++it) {
- scoped_ptr<PendingOperation> po(*it);
+ PendingOperation* po = *it;
Ami GONE FROM CHROMIUM 2014/05/27 23:00:29 FWIW could also const& it instead.
switch (po->type) {
case ADD_IDENTITY: {
add_stmt.Reset(true);
@@ -561,14 +574,20 @@ void WebRTCIdentityStoreBackend::SqlLiteStorage::Commit() {
const std::string& private_key = po->identity.private_key;
add_stmt.BindBlob(4, private_key.data(), private_key.size());
add_stmt.BindInt64(5, po->identity.creation_time);
- CHECK(add_stmt.Run());
+ if (!add_stmt.Run()) {
+ DVLOG(2) << "Failed to add the identity to DB.";
+ return;
+ }
break;
}
case DELETE_IDENTITY:
del_stmt.Reset(true);
del_stmt.BindString(0, po->origin.spec());
del_stmt.BindString(1, po->identity_name);
- CHECK(del_stmt.Run());
+ if (!del_stmt.Run()) {
+ DVLOG(2) << "Failed to delete the identity from DB.";
+ return;
+ }
break;
default:
@@ -576,8 +595,9 @@ void WebRTCIdentityStoreBackend::SqlLiteStorage::Commit() {
break;
}
}
- transaction.Commit();
- pending_operations_.clear();
+
+ if (!transaction.Commit())
+ DVLOG(2) << "Failed to commit the transaction.";
}
} // namespace content
« no previous file with comments | « no previous file | content/browser/media/webrtc_identity_store_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698