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

object_store: Migrate from snafu to thiserror #6266

Merged
merged 15 commits into from
Jan 2, 2025

Conversation

Turbo87
Copy link
Contributor

@Turbo87 Turbo87 commented Aug 16, 2024

Which issue does this PR close?

#6166, though only partially, since the PR is only targeting the object_store crate.

Rationale for this change

The rationale is explained in the linked issue :)

What changes are included in this PR?

The first commit in the PR adds a dependency on thiserror, the following commits incrementally port all error enums from snafu to thiserror, and then the final commit removes the now obsolete snafu dependency.

Note that this PR also includes #6265 to avoid merge conflicts from the bugfix.

Are there any user-facing changes?

As the linked issue mentions, some of the snafu type may leak to the outside and this PR will remove them so this should probably be treated as a breaking change, even though these types have been considered private API before.

@github-actions github-actions bot added the object-store Object Store Interface label Aug 16, 2024
@Turbo87
Copy link
Contributor Author

Turbo87 commented Aug 23, 2024

/cc @tustvold :)

@tustvold
Copy link
Contributor

HI @Turbo87, thank you for this, it looks pretty spot on. Unfortunately this ended up missing the 0.11 release, the RC was cut on the 12th August, and the next breaking release will not be for another 3 months...

I'm not really sure what the best way to proceed with this is, as we can't merge it to master for another 2 months. One option might be to keep this PR as a draft until then, but I appreciate that's likely a longer time commitment than you might have reasonably intuited when you picked this up 😅

Also tagging @Xuanwo and @alamb who may have other thoughts

@Turbo87
Copy link
Contributor Author

Turbo87 commented Aug 23, 2024

the next breaking release will not be for another 3 months

no worries :)

as we can't merge it to master for another 2 months

any reason for not being able to merge before then? I would guess potential bug fixes could be branched off before the merge of this PR, but I'm not familiar with the release process here :D

@tustvold
Copy link
Contributor

any reason for not being able to merge before then

Non-backport releases, including minor releases, are made from master. There have been some discussions in the past about alternative approaches, but they're not without their own trade-offs. #5907

@alamb
Copy link
Contributor

alamb commented Sep 18, 2024

I am depressed about the large review backlog in this crate. We are looking for more help from the community reviewing PRs -- see #6418 for more

object_store/src/delimited.rs Outdated Show resolved Hide resolved
@Jefffrey Jefffrey added the next-major-release the PR has API changes and it waiting on the next major version label Sep 27, 2024
@findepi
Copy link
Member

findepi commented Sep 30, 2024

I am depressed about the large review backlog in this crate. We are looking for more help from the community reviewing PRs -- see #6418 for more

Smaller PRs are faster to merge, because the review time is more than linear.

@Turbo87 your PR has awesome commit-by-commit structure. Would you consider moving eg first ~4 commits to a separate one?

@tustvold
Copy link
Contributor

This PR is probably fine as is, it's largely mechanical, it is actually just waiting on us to start preparation for the next breaking release

@Turbo87
Copy link
Contributor Author

Turbo87 commented Sep 30, 2024

Would you consider moving eg first ~4 commits to a separate one?

we can do that, but I'm not sure how valuable that would actually be since we'd then end up in a situation where we have both dependencies in the Cargo.toml file. it's probably easiest to review this commit-by-commit. since the changes are indeed pretty mechanical this should get quicker after reviewing the first few commits.

@Turbo87 Turbo87 force-pushed the object_store/thiserror branch from 90a3da1 to 9b987d5 Compare September 30, 2024 08:05
@Turbo87
Copy link
Contributor Author

Turbo87 commented Sep 30, 2024

FYI I've just rebased the branch to fix the merge conflict and integrate #6266 (comment)

@Turbo87 Turbo87 force-pushed the object_store/thiserror branch from 9b987d5 to bfe4165 Compare October 3, 2024 10:01
@Turbo87
Copy link
Contributor Author

Turbo87 commented Oct 3, 2024

rebased again to fix merge conflicts caused by #6453

@jondot
Copy link

jondot commented Oct 30, 2024

This is great! I've been looking for this to optimize builds of Loco (https://github.com/loco-rs/loco)

@Turbo87 Turbo87 force-pushed the object_store/thiserror branch from 6c32214 to 56947d0 Compare November 3, 2024 20:40
@Turbo87 Turbo87 force-pushed the object_store/thiserror branch from 56947d0 to 084744e Compare November 6, 2024 07:43
@Turbo87
Copy link
Contributor Author

Turbo87 commented Nov 6, 2024

rebased once more and updated to thiserror v2

@Turbo87 Turbo87 force-pushed the object_store/thiserror branch from 084744e to d49c00b Compare November 10, 2024 10:35
@Turbo87 Turbo87 force-pushed the object_store/thiserror branch from d49c00b to e42d9c2 Compare November 26, 2024 12:23
@crepererum
Copy link
Contributor

I think enough time has been passed to cut another major release. Before we send @Turbo87 off to fix the conflicts AGAIN, @alamb do you agree that we could merge this? Since the PR is a purely mechanical translation, the size is totally fine.

@tustvold
Copy link
Contributor

tustvold commented Dec 18, 2024

I think enough time has been passed to cut another major release

I think we we would want to coordinate this with the arrow major release, as otherwise everything will end up lagging. Given the arrow release has already started, this will probably need to wait until the next arrow breaking release next year.

I'm also not sure we really have enough functionality to warrant making a breaking release - see discussion on #6596

@alamb
Copy link
Contributor

alamb commented Dec 18, 2024

I think enough time has been passed to cut another major release. Before we send @Turbo87 off to fix the conflicts AGAIN, @alamb do you agree that we could merge this? Since the PR is a purely mechanical translation, the size is totally fine.

I think the as yet unresolved question is what the next object_store release will be -- breaking or non breaking:

If it will be breaking we can merge this PR, if not, we should wait

Let's figure out what the next release will be on #6596

@alamb
Copy link
Contributor

alamb commented Dec 18, 2024

tustvold beat me to it!

@Turbo87 Turbo87 force-pushed the object_store/thiserror branch from e42d9c2 to 0390fff Compare December 18, 2024 14:47
@Turbo87
Copy link
Contributor Author

Turbo87 commented Dec 18, 2024

I have to admit that it's getting a bit frustrating that this PR has been open for 4 months and now it's looking like it gets to stay open for at least another 2 months...

Same for #6636. It sounds like the argument is that there are not enough breaking changes gathered, but I'm wondering what the threshold is since I kept maintaining these two breaking change PRs for a while now 😅

@tustvold
Copy link
Contributor

Same for #6636. It sounds like the argument is that there are not enough breaking changes gathered,

I apologise that we've ended up in this position, and thank you for your patience. We've had a fair amount of push back from the community about the rate of breaking changes and so are trying hard to keep them down. Just under half of the install base still hasn't made it to 0.11 yet... - https://crates.io/crates/object_store

I've proposed that the next release after the one next week be a breaking release, and so we'd be able to get this merged to main in a week or so - #6596 (comment)

@Turbo87 Turbo87 force-pushed the object_store/thiserror branch from 0390fff to 3e2261e Compare January 2, 2025 18:38
@Turbo87
Copy link
Contributor Author

Turbo87 commented Jan 2, 2025

rebased once more. I guess this is ready to be merged now? :)

@alamb
Copy link
Contributor

alamb commented Jan 2, 2025

🔫 🚀

@alamb alamb merged commit f7263e2 into apache:main Jan 2, 2025
15 checks passed
@alamb
Copy link
Contributor

alamb commented Jan 2, 2025

Thanks again for for sticking with this @Turbo87

@Turbo87 Turbo87 deleted the object_store/thiserror branch January 3, 2025 05:54
CurtHagenlocher pushed a commit to CurtHagenlocher/arrow-rs that referenced this pull request Jan 13, 2025
* object_store: Add `thiserror` dependency

* object_store/memory: Migrate from `snafu` to `thiserror`

* object_store/parse: Migrate from `snafu` to `thiserror`

* object_store/util: Migrate from `snafu` to `thiserror`

* object_store/local: Migrate from `snafu` to `thiserror`

* object_store/delimited: Migrate from `snafu` to `thiserror`

* object_store/path/parts: Migrate from `snafu` to `thiserror`

* object_store/path: Migrate from `snafu` to `thiserror`

* object_store/http: Migrate from `snafu` to `thiserror`

* object_store/client: Migrate from `snafu` to `thiserror`

* object_store/aws: Migrate from `snafu` to `thiserror`

* object_store/azure: Migrate from `snafu` to `thiserror`

* object_store/gcp: Migrate from `snafu` to `thiserror`

* object_store/lib: Migrate from `snafu` to `thiserror`

* Remove `snafu` dependency
svencowart pushed a commit to elastiflow/arrow-rs that referenced this pull request Jan 14, 2025
* object_store: Add `thiserror` dependency

* object_store/memory: Migrate from `snafu` to `thiserror`

* object_store/parse: Migrate from `snafu` to `thiserror`

* object_store/util: Migrate from `snafu` to `thiserror`

* object_store/local: Migrate from `snafu` to `thiserror`

* object_store/delimited: Migrate from `snafu` to `thiserror`

* object_store/path/parts: Migrate from `snafu` to `thiserror`

* object_store/path: Migrate from `snafu` to `thiserror`

* object_store/http: Migrate from `snafu` to `thiserror`

* object_store/client: Migrate from `snafu` to `thiserror`

* object_store/aws: Migrate from `snafu` to `thiserror`

* object_store/azure: Migrate from `snafu` to `thiserror`

* object_store/gcp: Migrate from `snafu` to `thiserror`

* object_store/lib: Migrate from `snafu` to `thiserror`

* Remove `snafu` dependency
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
next-major-release the PR has API changes and it waiting on the next major version object-store Object Store Interface
Projects
None yet
Development

Successfully merging this pull request may close these issues.

9 participants