Skip to content

Commit

Permalink
(Memory|Timing) Distribution: snapshot only contains non-zero buckets…
Browse files Browse the repository at this point in the history
… now

**BREAKING CHANGE**:
This changes the ping payload for memory/timing distributions.
  • Loading branch information
badboy committed May 24, 2024
1 parent 6fd3947 commit f2c7095
Show file tree
Hide file tree
Showing 5 changed files with 6 additions and 50 deletions.
40 changes: 2 additions & 38 deletions glean-core/src/histogram/functional.rs
Original file line number Diff line number Diff line change
Expand Up @@ -85,44 +85,8 @@ impl Histogram<Functional> {
/// **Caution** This is a more specific implementation of `snapshot_values` on functional
/// histograms. `snapshot_values` cannot be used with those, due to buckets not being
/// precomputed.
pub fn snapshot(&self) -> HashMap<u64, u64> {
if self.values.is_empty() {
return HashMap::new();
}

let mut min_key = None;
let mut max_key = None;

// `Iterator#min` and `Iterator#max` would do the same job independently,
// but we want to avoid iterating the keys twice, so we loop ourselves.
for key in self.values.keys() {
let key = *key;

// safe unwrap, we checked it's not none
if min_key.is_none() || key < min_key.unwrap() {
min_key = Some(key);
}

// safe unwrap, we checked it's not none
if max_key.is_none() || key > max_key.unwrap() {
max_key = Some(key);
}
}

// Non-empty values, therefore minimum/maximum exists.
// safe unwraps, we set it at least once.
let min_bucket = self.bucketing.sample_to_bucket_index(min_key.unwrap());
let max_bucket = self.bucketing.sample_to_bucket_index(max_key.unwrap()) + 1;

let mut values = self.values.clone();

for idx in min_bucket..=max_bucket {
// Fill in missing entries.
let min_bucket = self.bucketing.bucket_index_to_bucket_minimum(idx);
let _ = values.entry(min_bucket).or_insert(0);
}

values
pub fn snapshot(&self) -> &HashMap<u64, u64> {
&self.values
}
}

Expand Down
4 changes: 2 additions & 2 deletions glean-core/src/metrics/memory_distribution.rs
Original file line number Diff line number Diff line change
Expand Up @@ -41,8 +41,8 @@ pub(crate) fn snapshot(hist: &Histogram<Functional>) -> DistributionData {
// specialized snapshot function.
values: hist
.snapshot()
.into_iter()
.map(|(k, v)| (k as i64, v as i64))
.iter()
.map(|(&k, &v)| (k as i64, v as i64))
.collect(),
sum: hist.sum() as i64,
count: hist.count() as i64,
Expand Down
8 changes: 2 additions & 6 deletions glean-core/src/metrics/timing_distribution.rs
Original file line number Diff line number Diff line change
Expand Up @@ -73,8 +73,8 @@ pub(crate) fn snapshot(hist: &Histogram<Functional>) -> DistributionData {
// specialized snapshot function.
values: hist
.snapshot()
.into_iter()
.map(|(k, v)| (k as i64, v as i64))
.iter()
.map(|(&k, &v)| (k as i64, v as i64))
.collect(),
sum: hist.sum() as i64,
count: hist.count() as i64,
Expand Down Expand Up @@ -585,7 +585,6 @@ mod test {
"8": 1,
"9": 1,
"10": 1,
"11": 0,
},
});

Expand All @@ -610,10 +609,7 @@ mod test {
"values": {
"1024": 2,
"1116": 1,
"1217": 0,
"1327": 0,
"1448": 1,
"1579": 0,
},
});

Expand Down
2 changes: 0 additions & 2 deletions glean-core/tests/memory_distribution.rs
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,6 @@ fn serializer_should_correctly_serialize_memory_distribution() {
"sum": 100_000 * kb,
"values": {
"99108124": 1,
"103496016": 0,
}
});
assert_eq!(
Expand Down Expand Up @@ -93,7 +92,6 @@ fn set_value_properly_sets_the_value_in_all_stores() {
"sum": 100_000,
"values": {
"96785": 1,
"101070": 0,
}
});
for store_name in store_names {
Expand Down
2 changes: 0 additions & 2 deletions glean-core/tests/timing_distribution.rs
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,6 @@ fn serializer_should_correctly_serialize_timing_distribution() {
"sum": duration,
"values": {
"58": 1,
"64": 0,
}
});
assert_eq!(
Expand Down Expand Up @@ -102,7 +101,6 @@ fn set_value_properly_sets_the_value_in_all_stores() {
"sum": 1,
"values": {
"1": 1,
"2": 0,
}
});
for store_name in store_names {
Expand Down

0 comments on commit f2c7095

Please sign in to comment.