-
Notifications
You must be signed in to change notification settings - Fork 42
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
Future for Importers with V3 #103
Comments
Hello there, Until then, I suggest using Beancount v2. There's no significant difference between that and v3 for most users, and upgrading to v3+beancount_reds_importers when it uses beangulp would be trivial. Does that help? |
I have been using Red's importers with beangulp since 2022 without any problem. I moved over when he tried to move over. I have used the following approach. This code was pulled from beangulp I think:
and then I create wrappers like this:
I call it from my own tool like this:
It will be nice to pull all that out eventually. If you are in a hurry you could do the same ... or just wait. |
Oh very cool, thank you for sharing, @patbakdev! I haven't looked through it all, but if you want to turn it into a PR at some point, that'd be most welcome. |
Not sure what you want to do here. This code was just about making v2 importers work with beangulp by adapting the interface until you were ready to move to beangulp for those that don't want to wait. But I suspect you will want to move the importers to use the beangulp interface instead. I guess the question is whether or not you want to have some backwards compatibility with V2. In which case we might be able to invert this code to work the other way around. But that seems like a design decision. Personally I would just freeze V2 in a branch and move to V3 instead of having bankv2 and bankv3 importers. Maybe there is a smart way to do this so nobody has to update anything (at one point I think I read that beangulp was backwards compatible). |
Sorry I wasn't being clear. You're right: the plan is to freeze v2 and move on to v3. However, it's going to be several weeks or longer before I have any time to do it. Until then, I was thinking of temoprarily providing an adapter such as yours for folks wanting to adopt Beancount v3 right away. On further thought, providing an adapter "officially" may not be worth the effort it takes to test it, provide examples, and such. Your code is already in this thread, and that should be helpful for anyone wanting it. Thoughts welcome if I'm missing anything. Thank you for engaging in this conversation! |
Ok. Yes, we are on the same page then. I'm also subscribed to the thread in case anyone runs into trouble adapting the code to their needs in the mean time. |
Not sure how to implement the adapter workaround for a custom importer relying on the csv reader: EDIT: all good, got it- I thought beangulp was v3 only |
Glad you figured it out. All of my banking/investment importers are still using OFX so I don't have any experience with CSV. Although I am not sure why that would matter. I did attempt to switch from OFX to CSV for Fidelity once upon a time by creating an importer and if I look through that (dead) code it looks pretty much the same.
So I would think one would just need to do the same for an existing importer.
Anyways, hope that helps. |
I took a quick look at converting this project to beangulp and immediately tripped on the removal of the regression testing plugin at beancount/beangulp@d4d9212 @redstreet have you played with this at all? If not, @dnicolodi do you have any advice on converting importers that did use that framework? |
@blalor I haven't had a chance to look yet. Thanks for the pointer. That commit message says there's a simpler testing framework now. Is that the one you're looking for advice to convert to? If so, I haven't taken a look at it yet. |
@blalor I haven't had a chance to look yet. Thanks for the pointer. That commit message says there's a simpler testing framework now. Is that the one you're looking for advice to convert to? If so, I haven't taken a look at it yet
Yeah, that’s what I’m referring to. The tests seem to have been moved into a shell script that calls a `test` command on the importer instance itself. Feels awkward because it’s not part of pytest, which is why I’m asking for guidance. 😁
|
I'm not sure I understand the question. There was a piece of code that tried to define some helpers to use pytest to test importers. The code was ugly, hard to use, and made obsolete by new pytest features. Thus it has been removed. Those who want to keep using pytest for testing their importers, they can continue to do so: they just need to hook up their tests with pytest in the way they prefer. Which functionality of the code that has been removed do you miss? We found that most importers are easier to test with something much simpler than pytest and that is the simple test subcommand that the importers framework implements. This simply compares the output of the importer with an expected output and provides some not too ugly report. This has the advantage that it does not require to write any code. Somewhere I have some code that allows |
Which new pytest features are you referring to?
This is an example of the old regression test fixture: beancount_reds_importers/beancount_reds_importers/importers/dcu/tests/dcu_csv_test.py Lines 5 to 20 in 07d972d
Is there an example of using the new framework with pytest? If not, do you have any pointers? |
One change to note is that beangulp requests we use the beangulp.importer ABC (abstract base class) rather than the beangulp.importer.ImportProtocol currently referenced by these importers (well, technically beancount.ingest.importer.ImportProtocol). The big difference is the files are no longer cached so Caching is then left as a manual choice for users to add to their importers as they see fit. I have yet to need this myself (e.g. convert a PDF statement) so I don't know the details but it looks like you have a decorator from beangulp.cache or I just replaced Also, you need to add an account method to your importer that just returns the account:
|
Martin has released "v3" of beancount, which is just the refactored pythonic bits, as the default version. With this, things like
bean-extract
andbean-identify
are finally sunset, replaced withbeangulp
. What are your thoughts on adapting your importers to this updated framework?For starters,
beancount.ingest
can probably becomebeangulp
, although I can't find the regression pytest. Then, shell scripts have to become python scripts, I guess. Probably other work to ensure your importer frameworks remain compatible with the modern beangulp importer.As someone who was just starting to get the hang of your scripts and was writing my first importer when this change happened, it seems overwhelming to have to adapt to a new framework, so I'd greatly appreciate some expert advice on how to use the new framework :)
The text was updated successfully, but these errors were encountered: