-
Notifications
You must be signed in to change notification settings - Fork 311
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 tests to improve coverage #745
Add tests to improve coverage #745
Conversation
I'd like to see b91afdb split into multiple commits: at least one different commit for each bug discovered and fixed, with an explanation of the bug found. You modified quite a bit of code in |
1563bdf
to
fa1d063
Compare
@danielabrozzoni, I have implemented the changes requested and explained reason for the change in the commit message. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
First of all, some styling nits:
- You shouldn't put "Fix failing test: test_del_tx" as the commit message for 27c6735 - your commit is not fixing a test. Your commit is fixing a bug you've found. This is very different, as "Fix failing test" makes the reader think that in the commit you are modifying the actual test behavior.
- This is a quite big nit, but I usually first put commits that fix bugs and then commits that add tests, not the other way around (in this PR d8f5026 is before 27c6735). The reason for that is: it helps me write a clearer commit message, as that I'm not tempted to cite any test in the bug-fixing commit, but also it makes the git history bisectable, which is always a nice to have.
The added tests look good and they actually improve the code coverage :) See https://coveralls.io/builds/52344495
I am a bit confused about 27c6735: to me, it doesn't seem that you need to modify select_transaction_details_by_txid
, you can just remove the transaction from the returned object if include_raw
is false:
diff --git a/src/database/sqlite.rs b/src/database/sqlite.rs
index 562c934..4fb6337 100644
--- a/src/database/sqlite.rs
+++ b/src/database/sqlite.rs
@@ -744,11 +744,16 @@ impl BatchOperations for SqliteDatabase {
include_raw: bool,
) -> Result<Option<TransactionDetails>, Error> {
match self.select_transaction_details_by_txid(txid)? {
- Some(transaction_details) => {
+ Some(mut transaction_details) => {
self.delete_transaction_details_by_txid(txid)?;
if include_raw {
self.delete_transaction_by_txid(txid)?;
+ } else {
+ // Since we want to return what we actually deleted from
+ // the database, we make sure to put a "None" in the
+ // transaction field here.
+ transaction_details.transaction = None;
}
Ok(Some(transaction_details))
}
Is there something I'm not seeing?
@danielabrozzoni, initially I made the transaction field |
fa1d063
to
c80c058
Compare
`del_tx` pulls the TransactionDetails object using `select_transaction_details_by_txid` method which gets the transaction details' data with a non-None transaction field even if the `include_raw` argument is `false`. So it becomes necessary to Set the transaction field in transactiondetails to None in `del_tx`, when we make a call to it with `include_raw=false`.
c80c058
to
2ea1f57
Compare
This PR aims to add more test to database code so that we can catch bugs as soon as they occur. Contributing to fixing issue bitcoindevkit#699.
Change parameter name in database test functions from `tree` to `db`.
2ea1f57
to
e65edbf
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
tACK e65edbf
Thanks for the new tests..
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Code review ACK e65edbf
Description
This PR add more test to the database module and also fixes certain bugs discovered by the written test. I also amended the name used for the database parameter in the test functions.
Notes to the reviewers
This contributes to fixing #699
Changelog notice
Checklists
All Submissions:
cargo fmt
andcargo clippy
before committing