Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add a Binary format to store test aggregates #51

Merged
merged 30 commits into from
Jan 7, 2025

Conversation

Swatinem
Copy link
Contributor

This defines a binary file format similar to the various cache formats we use in Symbolicator.

The format contains various aggregations for a configurable number of days.

@Swatinem Swatinem self-assigned this Nov 19, 2024
@Swatinem Swatinem force-pushed the swatinem/binary-rollup-format branch 2 times, most recently from 8432c94 to bad2ad5 Compare November 21, 2024 14:36
@Swatinem Swatinem force-pushed the swatinem/binary-rollup-format branch 2 times, most recently from 833ab8f to 24806c1 Compare November 29, 2024 13:51
Copy link

codecov bot commented Nov 29, 2024

Codecov Report

Attention: Patch coverage is 97.65298% with 28 lines in your changes missing coverage. Please review.

Project coverage is 94.31%. Comparing base (508185c) to head (57bcd00).
Report is 31 commits behind head on main.

✅ All tests successful. No failed tests found.

Files with missing lines Patch % Lines
src/binary/bindings.rs 90.65% 10 Missing ⚠️
src/binary/format.rs 94.01% 10 Missing ⚠️
src/binary/error.rs 0.00% 6 Missing ⚠️
src/binary/writer.rs 99.43% 2 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main      #51      +/-   ##
==========================================
+ Coverage   88.68%   94.31%   +5.63%     
==========================================
  Files           5       14       +9     
  Lines         707     1900    +1193     
==========================================
+ Hits          627     1792    +1165     
- Misses         80      108      +28     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@codecov-notifications
Copy link

codecov-notifications bot commented Nov 29, 2024

Codecov Report

Attention: Patch coverage is 97.65298% with 28 lines in your changes missing coverage. Please review.

✅ All tests successful. No failed tests found.

Files with missing lines Patch % Lines
src/binary/bindings.rs 90.65% 10 Missing ⚠️
src/binary/format.rs 94.01% 10 Missing ⚠️
src/binary/error.rs 0.00% 6 Missing ⚠️
src/binary/writer.rs 99.43% 2 Missing ⚠️

📢 Thoughts on this report? Let us know!

@Swatinem Swatinem force-pushed the swatinem/binary-rollup-format branch from 24806c1 to 4282b18 Compare November 29, 2024 13:59
@Swatinem Swatinem marked this pull request as ready for review December 5, 2024 15:49
@Swatinem
Copy link
Contributor Author

Swatinem commented Dec 5, 2024

I believe this should be feature complete now.
I would appreciate a review, and would be happy to schedule another meeting to walk through the code or through the feedback / questions.

"commits_where_fail":test.commits_where_fail,
"last_duration":test.last_duration,# TODO
}
print(test_dict)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

should we do some kind of assert to sanity-check the output

Copy link
Contributor

@joseph-sentry joseph-sentry left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

left 1 comment about the use of unsafe, but at a high level this lgtm

i generally agree that there should be more testing done though

(note so i don't forget)
i think we're going to have to add more features:

  • filtering by testsuite name
  • filtering by name

let format = TestAnalytics::parse(&buffer, timestamp)?;
// SAFETY: the lifetime of `TestAnalytics` depends on `buffer`,
// which we do not mutate, and which outlives the parsed format.
let format = unsafe { transmute::<TestAnalytics<'_>, TestAnalytics<'_>>(format) };
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

just to make sure i understand: the transmute here is saying "whatever the lifetime of format is now, change it such that it satisfies the lifetime we would need for the compiler to be happy"

also, just because i'm curious, is there an alternative to storing the buffer in the struct alongside a data structure that holds references to it?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

also, just because i'm curious, is there an alternative to storing the buffer in the struct alongside a data structure that holds references to it?

The alternative would be to use a reference with a lifetime :-)

Though that is not allowed in pyo3 bindings, so we have to use self-contained, and thus self-referential data. Which is currently not possible in safe Rust, and we work around that by using an unsafe transmute to essentially turn the lifetime into 'static, meaning it essentially does not carry any lifetime anymore.

@Swatinem Swatinem force-pushed the swatinem/binary-rollup-format branch from 411e84a to 57bcd00 Compare January 7, 2025 10:04
@Swatinem Swatinem merged commit 0a663e5 into main Jan 7, 2025
10 of 11 checks passed
@Swatinem Swatinem deleted the swatinem/binary-rollup-format branch January 7, 2025 10:07
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants