mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-15 00:44:33 +00:00
index: add stats for number of change ids and pruned commits
This commit is contained in:
parent
bc64cf02c7
commit
e2e9fe8f0d
2 changed files with 51 additions and 8 deletions
|
@ -736,6 +736,8 @@ impl<'a> CompositeIndex<'a> {
|
||||||
let mut num_merges = 0;
|
let mut num_merges = 0;
|
||||||
let mut max_generation_number = 0;
|
let mut max_generation_number = 0;
|
||||||
let mut is_head = vec![true; num_commits as usize];
|
let mut is_head = vec![true; num_commits as usize];
|
||||||
|
let mut change_ids = HashSet::new();
|
||||||
|
let mut num_pruned_commits = 0;
|
||||||
for pos in 0..num_commits {
|
for pos in 0..num_commits {
|
||||||
let entry = self.entry_by_pos(pos);
|
let entry = self.entry_by_pos(pos);
|
||||||
max_generation_number = max(max_generation_number, entry.generation_number());
|
max_generation_number = max(max_generation_number, entry.generation_number());
|
||||||
|
@ -745,6 +747,10 @@ impl<'a> CompositeIndex<'a> {
|
||||||
for parent_pos in entry.parent_positions() {
|
for parent_pos in entry.parent_positions() {
|
||||||
is_head[parent_pos as usize] = false;
|
is_head[parent_pos as usize] = false;
|
||||||
}
|
}
|
||||||
|
if entry.is_pruned() {
|
||||||
|
num_pruned_commits += 1;
|
||||||
|
}
|
||||||
|
change_ids.insert(entry.change_id());
|
||||||
}
|
}
|
||||||
let num_heads = is_head.iter().filter(|is_head| **is_head).count() as u32;
|
let num_heads = is_head.iter().filter(|is_head| **is_head).count() as u32;
|
||||||
|
|
||||||
|
@ -768,6 +774,8 @@ impl<'a> CompositeIndex<'a> {
|
||||||
num_merges,
|
num_merges,
|
||||||
max_generation_number,
|
max_generation_number,
|
||||||
num_heads,
|
num_heads,
|
||||||
|
num_pruned_commits,
|
||||||
|
num_changes: change_ids.len() as u32,
|
||||||
levels,
|
levels,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -971,6 +979,8 @@ pub struct IndexStats {
|
||||||
pub num_merges: u32,
|
pub num_merges: u32,
|
||||||
pub max_generation_number: u32,
|
pub max_generation_number: u32,
|
||||||
pub num_heads: u32,
|
pub num_heads: u32,
|
||||||
|
pub num_pruned_commits: u32,
|
||||||
|
pub num_changes: u32,
|
||||||
pub levels: Vec<IndexLevelStats>,
|
pub levels: Vec<IndexLevelStats>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1633,6 +1643,8 @@ mod tests {
|
||||||
assert_eq!(stats.num_heads, 0);
|
assert_eq!(stats.num_heads, 0);
|
||||||
assert_eq!(stats.max_generation_number, 0);
|
assert_eq!(stats.max_generation_number, 0);
|
||||||
assert_eq!(stats.num_merges, 0);
|
assert_eq!(stats.num_merges, 0);
|
||||||
|
assert_eq!(stats.num_changes, 0);
|
||||||
|
assert_eq!(stats.num_pruned_commits, 0);
|
||||||
assert_eq!(index.num_commits(), 0);
|
assert_eq!(index.num_commits(), 0);
|
||||||
// Cannot find any commits
|
// Cannot find any commits
|
||||||
assert!(index.entry_by_id(&CommitId::from_hex("000000")).is_none());
|
assert!(index.entry_by_id(&CommitId::from_hex("000000")).is_none());
|
||||||
|
@ -1646,7 +1658,8 @@ mod tests {
|
||||||
let temp_dir = tempfile::tempdir().unwrap();
|
let temp_dir = tempfile::tempdir().unwrap();
|
||||||
let mut index = MutableIndex::full(temp_dir.path().to_owned(), 3);
|
let mut index = MutableIndex::full(temp_dir.path().to_owned(), 3);
|
||||||
let id_0 = CommitId::from_hex("000000");
|
let id_0 = CommitId::from_hex("000000");
|
||||||
index.add_commit_data(id_0.clone(), new_change_id(), false, vec![], vec![]);
|
let change_id0 = new_change_id();
|
||||||
|
index.add_commit_data(id_0.clone(), change_id0.clone(), false, vec![], vec![]);
|
||||||
let index = if on_disk {
|
let index = if on_disk {
|
||||||
IndexRef::Readonly(index.save().unwrap())
|
IndexRef::Readonly(index.save().unwrap())
|
||||||
} else {
|
} else {
|
||||||
|
@ -1659,6 +1672,8 @@ mod tests {
|
||||||
assert_eq!(stats.num_heads, 1);
|
assert_eq!(stats.num_heads, 1);
|
||||||
assert_eq!(stats.max_generation_number, 0);
|
assert_eq!(stats.max_generation_number, 0);
|
||||||
assert_eq!(stats.num_merges, 0);
|
assert_eq!(stats.num_merges, 0);
|
||||||
|
assert_eq!(stats.num_changes, 1);
|
||||||
|
assert_eq!(stats.num_pruned_commits, 0);
|
||||||
assert_eq!(index.num_commits(), 1);
|
assert_eq!(index.num_commits(), 1);
|
||||||
// Can find only the root commit
|
// Can find only the root commit
|
||||||
assert_eq!(index.commit_id_to_pos(&id_0), Some(0));
|
assert_eq!(index.commit_id_to_pos(&id_0), Some(0));
|
||||||
|
@ -1668,6 +1683,8 @@ mod tests {
|
||||||
let entry = index.entry_by_id(&id_0).unwrap();
|
let entry = index.entry_by_id(&id_0).unwrap();
|
||||||
assert_eq!(entry.pos, 0);
|
assert_eq!(entry.pos, 0);
|
||||||
assert_eq!(entry.commit_id(), id_0);
|
assert_eq!(entry.commit_id(), id_0);
|
||||||
|
assert_eq!(entry.change_id(), change_id0);
|
||||||
|
assert_eq!(entry.is_pruned(), false);
|
||||||
assert_eq!(entry.generation_number(), 0);
|
assert_eq!(entry.generation_number(), 0);
|
||||||
assert_eq!(entry.num_parents(), 0);
|
assert_eq!(entry.num_parents(), 0);
|
||||||
assert_eq!(entry.parent_positions(), Vec::<u32>::new());
|
assert_eq!(entry.parent_positions(), Vec::<u32>::new());
|
||||||
|
@ -1685,6 +1702,16 @@ mod tests {
|
||||||
index.add_commit_data(id_1, new_change_id(), false, vec![id_0], vec![]);
|
index.add_commit_data(id_1, new_change_id(), false, vec![id_0], vec![]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
#[should_panic(expected = "predecessor commit is not indexed")]
|
||||||
|
fn index_missing_predecessor_commit() {
|
||||||
|
let temp_dir = tempfile::tempdir().unwrap();
|
||||||
|
let mut index = MutableIndex::full(temp_dir.path().to_owned(), 3);
|
||||||
|
let id_0 = CommitId::from_hex("000000");
|
||||||
|
let id_1 = CommitId::from_hex("111111");
|
||||||
|
index.add_commit_data(id_1, new_change_id(), false, vec![], vec![id_0]);
|
||||||
|
}
|
||||||
|
|
||||||
#[test_case(false, false; "full in memory")]
|
#[test_case(false, false; "full in memory")]
|
||||||
#[test_case(false, true; "full on disk")]
|
#[test_case(false, true; "full on disk")]
|
||||||
#[test_case(true, false; "incremental in memory")]
|
#[test_case(true, false; "incremental in memory")]
|
||||||
|
@ -1700,19 +1727,22 @@ mod tests {
|
||||||
// |/
|
// |/
|
||||||
// 0
|
// 0
|
||||||
let id_0 = CommitId::from_hex("000000");
|
let id_0 = CommitId::from_hex("000000");
|
||||||
|
let change_id0 = new_change_id();
|
||||||
let id_1 = CommitId::from_hex("111111");
|
let id_1 = CommitId::from_hex("111111");
|
||||||
|
let change_id1 = new_change_id();
|
||||||
let id_2 = CommitId::from_hex("222222");
|
let id_2 = CommitId::from_hex("222222");
|
||||||
index.add_commit_data(id_0.clone(), new_change_id(), false, vec![], vec![]);
|
let change_id2 = change_id1.clone();
|
||||||
|
index.add_commit_data(id_0.clone(), change_id0, false, vec![], vec![]);
|
||||||
index.add_commit_data(
|
index.add_commit_data(
|
||||||
id_1.clone(),
|
id_1.clone(),
|
||||||
new_change_id(),
|
change_id1.clone(),
|
||||||
false,
|
false,
|
||||||
vec![id_0.clone()],
|
vec![id_0.clone()],
|
||||||
vec![],
|
vec![],
|
||||||
);
|
);
|
||||||
index.add_commit_data(
|
index.add_commit_data(
|
||||||
id_2.clone(),
|
id_2.clone(),
|
||||||
new_change_id(),
|
change_id2.clone(),
|
||||||
false,
|
false,
|
||||||
vec![id_0.clone()],
|
vec![id_0.clone()],
|
||||||
vec![],
|
vec![],
|
||||||
|
@ -1726,25 +1756,28 @@ mod tests {
|
||||||
}
|
}
|
||||||
|
|
||||||
let id_3 = CommitId::from_hex("333333");
|
let id_3 = CommitId::from_hex("333333");
|
||||||
|
let change_id3 = new_change_id();
|
||||||
let id_4 = CommitId::from_hex("444444");
|
let id_4 = CommitId::from_hex("444444");
|
||||||
|
let change_id4 = new_change_id();
|
||||||
let id_5 = CommitId::from_hex("555555");
|
let id_5 = CommitId::from_hex("555555");
|
||||||
|
let change_id5 = change_id3.clone();
|
||||||
index.add_commit_data(
|
index.add_commit_data(
|
||||||
id_3.clone(),
|
id_3.clone(),
|
||||||
new_change_id(),
|
change_id3.clone(),
|
||||||
false,
|
true,
|
||||||
vec![id_2.clone()],
|
vec![id_2.clone()],
|
||||||
vec![],
|
vec![],
|
||||||
);
|
);
|
||||||
index.add_commit_data(
|
index.add_commit_data(
|
||||||
id_4.clone(),
|
id_4.clone(),
|
||||||
new_change_id(),
|
change_id4,
|
||||||
false,
|
false,
|
||||||
vec![id_1.clone()],
|
vec![id_1.clone()],
|
||||||
vec![id_2.clone(), id_3.clone()],
|
vec![id_2.clone(), id_3.clone()],
|
||||||
);
|
);
|
||||||
index.add_commit_data(
|
index.add_commit_data(
|
||||||
id_5.clone(),
|
id_5.clone(),
|
||||||
new_change_id(),
|
change_id5,
|
||||||
false,
|
false,
|
||||||
vec![id_4.clone(), id_2.clone()],
|
vec![id_4.clone(), id_2.clone()],
|
||||||
vec![],
|
vec![],
|
||||||
|
@ -1761,6 +1794,8 @@ mod tests {
|
||||||
assert_eq!(stats.num_heads, 2);
|
assert_eq!(stats.num_heads, 2);
|
||||||
assert_eq!(stats.max_generation_number, 3);
|
assert_eq!(stats.max_generation_number, 3);
|
||||||
assert_eq!(stats.num_merges, 1);
|
assert_eq!(stats.num_merges, 1);
|
||||||
|
assert_eq!(stats.num_changes, 4);
|
||||||
|
assert_eq!(stats.num_pruned_commits, 1);
|
||||||
assert_eq!(index.num_commits(), 6);
|
assert_eq!(index.num_commits(), 6);
|
||||||
// Can find all the commits
|
// Can find all the commits
|
||||||
let entry_0 = index.entry_by_id(&id_0).unwrap();
|
let entry_0 = index.entry_by_id(&id_0).unwrap();
|
||||||
|
@ -1774,6 +1809,8 @@ mod tests {
|
||||||
assert_eq!(entry_0.commit_id(), id_0);
|
assert_eq!(entry_0.commit_id(), id_0);
|
||||||
assert_eq!(entry_1.pos, 1);
|
assert_eq!(entry_1.pos, 1);
|
||||||
assert_eq!(entry_1.commit_id(), id_1);
|
assert_eq!(entry_1.commit_id(), id_1);
|
||||||
|
assert_eq!(entry_1.change_id(), change_id1);
|
||||||
|
assert_eq!(entry_1.is_pruned(), false);
|
||||||
assert_eq!(entry_1.generation_number(), 1);
|
assert_eq!(entry_1.generation_number(), 1);
|
||||||
assert_eq!(entry_1.num_parents(), 1);
|
assert_eq!(entry_1.num_parents(), 1);
|
||||||
assert_eq!(entry_1.parent_positions(), vec![0]);
|
assert_eq!(entry_1.parent_positions(), vec![0]);
|
||||||
|
@ -1781,11 +1818,15 @@ mod tests {
|
||||||
assert_eq!(entry_1.predecessor_positions(), Vec::<u32>::new());
|
assert_eq!(entry_1.predecessor_positions(), Vec::<u32>::new());
|
||||||
assert_eq!(entry_2.pos, 2);
|
assert_eq!(entry_2.pos, 2);
|
||||||
assert_eq!(entry_2.commit_id(), id_2);
|
assert_eq!(entry_2.commit_id(), id_2);
|
||||||
|
assert_eq!(entry_2.change_id(), change_id2);
|
||||||
|
assert_eq!(entry_2.is_pruned(), false);
|
||||||
assert_eq!(entry_2.generation_number(), 1);
|
assert_eq!(entry_2.generation_number(), 1);
|
||||||
assert_eq!(entry_2.num_parents(), 1);
|
assert_eq!(entry_2.num_parents(), 1);
|
||||||
assert_eq!(entry_2.parent_positions(), vec![0]);
|
assert_eq!(entry_2.parent_positions(), vec![0]);
|
||||||
|
assert_eq!(entry_3.change_id(), change_id3);
|
||||||
assert_eq!(entry_3.generation_number(), 2);
|
assert_eq!(entry_3.generation_number(), 2);
|
||||||
assert_eq!(entry_3.parent_positions(), vec![2]);
|
assert_eq!(entry_3.parent_positions(), vec![2]);
|
||||||
|
assert_eq!(entry_3.is_pruned(), true);
|
||||||
assert_eq!(entry_4.pos, 4);
|
assert_eq!(entry_4.pos, 4);
|
||||||
assert_eq!(entry_4.generation_number(), 2);
|
assert_eq!(entry_4.generation_number(), 2);
|
||||||
assert_eq!(entry_4.num_parents(), 1);
|
assert_eq!(entry_4.num_parents(), 1);
|
||||||
|
|
|
@ -1779,6 +1779,8 @@ fn cmd_debug(
|
||||||
writeln!(ui, "Number of merges: {}", stats.num_merges);
|
writeln!(ui, "Number of merges: {}", stats.num_merges);
|
||||||
writeln!(ui, "Max generation number: {}", stats.max_generation_number);
|
writeln!(ui, "Max generation number: {}", stats.max_generation_number);
|
||||||
writeln!(ui, "Number of heads: {}", stats.num_heads);
|
writeln!(ui, "Number of heads: {}", stats.num_heads);
|
||||||
|
writeln!(ui, "Number of pruned commits: {}", stats.num_pruned_commits);
|
||||||
|
writeln!(ui, "Number of changes: {}", stats.num_changes);
|
||||||
writeln!(ui, "Stats per level:");
|
writeln!(ui, "Stats per level:");
|
||||||
for (i, level) in stats.levels.iter().enumerate() {
|
for (i, level) in stats.levels.iter().enumerate() {
|
||||||
writeln!(ui, " Level {}:", i);
|
writeln!(ui, " Level {}:", i);
|
||||||
|
|
Loading…
Reference in a new issue