ChangeNotes: Don't auto-rebuild if both state and ref are missing

This is the normal state when only writing NoteDb changes but not
reading. The whole point of the optimization in Ic8c6c28e was to keep
old changes in this state until an explicit rebuild.

Change-Id: I9353bcd36ead4f4f7350884c795b0bad9c0da572
This commit is contained in:
Dave Borowitz
2016-05-05 17:18:23 -04:00
parent edabbdaa68
commit 31cee3af70
3 changed files with 22 additions and 3 deletions

View File

@@ -627,7 +627,7 @@ public class ChangeNotes extends AbstractChangeNotes<ChangeNotes> {
if (autoRebuild) { if (autoRebuild) {
NoteDbChangeState state = NoteDbChangeState.parse(change); NoteDbChangeState state = NoteDbChangeState.parse(change);
RefCache refs = this.refs != null ? this.refs : new RepoRefCache(repo); RefCache refs = this.refs != null ? this.refs : new RepoRefCache(repo);
if (state == null || !state.isChangeUpToDate(refs)) { if (!NoteDbChangeState.isChangeUpToDate(state, refs, getChangeId())) {
return rebuildAndOpen(repo); return rebuildAndOpen(repo);
} }
} }

View File

@@ -153,8 +153,8 @@ public class DraftCommentNotes extends AbstractChangeNotes<DraftCommentNotes> {
NoteDbChangeState state = NoteDbChangeState.parse(change); NoteDbChangeState state = NoteDbChangeState.parse(change);
// Only check if this particular user's drafts are up to date, to avoid // Only check if this particular user's drafts are up to date, to avoid
// reading unnecessary refs. // reading unnecessary refs.
if (state == null if (!NoteDbChangeState.areDraftsUpToDate(
|| !state.areDraftsUpToDate(new RepoRefCache(repo), author)) { state, new RepoRefCache(repo), getChangeId(), author)) {
return rebuildAndOpen(repo); return rebuildAndOpen(repo);
} }
} }

View File

@@ -26,6 +26,7 @@ import com.google.common.base.Splitter;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
import com.google.common.collect.Lists; import com.google.common.collect.Lists;
import com.google.common.collect.Maps; import com.google.common.collect.Maps;
import com.google.gerrit.common.Nullable;
import com.google.gerrit.reviewdb.client.Account; import com.google.gerrit.reviewdb.client.Account;
import com.google.gerrit.reviewdb.client.Change; import com.google.gerrit.reviewdb.client.Change;
import com.google.gerrit.reviewdb.server.ReviewDbUtil; import com.google.gerrit.reviewdb.server.ReviewDbUtil;
@@ -140,6 +141,24 @@ public class NoteDbChangeState {
return state; return state;
} }
public static boolean isChangeUpToDate(@Nullable NoteDbChangeState state,
RefCache changeRepoRefs, Change.Id changeId) throws IOException {
if (state == null) {
return !changeRepoRefs.get(changeMetaRef(changeId)).isPresent();
}
return state.isChangeUpToDate(changeRepoRefs);
}
public static boolean areDraftsUpToDate(@Nullable NoteDbChangeState state,
RefCache draftsRepoRefs, Change.Id changeId, Account.Id accountId)
throws IOException {
if (state == null) {
return !draftsRepoRefs.get(refsDraftComments(changeId, accountId))
.isPresent();
}
return state.areDraftsUpToDate(draftsRepoRefs, accountId);
}
public static String toString(ObjectId changeMetaId, public static String toString(ObjectId changeMetaId,
Map<Account.Id, ObjectId> draftIds) { Map<Account.Id, ObjectId> draftIds) {
List<Account.Id> accountIds = Lists.newArrayList(draftIds.keySet()); List<Account.Id> accountIds = Lists.newArrayList(draftIds.keySet());