-
Notifications
You must be signed in to change notification settings - Fork 145
EuroPython 2018 Sprint on Bonobo
Status: | Sprint In Progress! |
---|---|
Date: | 28/29 July 2018 |
Location: | EICC Edinburgh / #sprint on slack |
Whatever your background and experience is, you are very welcome. If you want to discover the library, want to bring your opinions on how this can be useful in name your job, help with improving the documentation with a new regard, want to dive in the code and propose patches, help refining how we present the toolkit, ... or anything else aiming at getting the tool better known and easier to use, feel free to join us!
I (Romain) will be available for introduction, help, routing, assistance, ... Ask me anything, I firmly believe that there is no such thing as a stupid question.
- Say hi, introduce yourself.
- Join #sprint on Slack (https://bonobo-slack.herokuapp.com/).
- Add your name to the bottom of the page.
- Install the develop version (TODO add direct link)
- Homepage: https://www.bonobo-project.org/
- Documentation: http://docs.bonobo-project.org/
- Repositories: https://github.com/python-bonobo/bonobo
- Slack: https://bonobo-slack.herokuapp.com/
- Release mailing list: http://eepurl.com/cLG1AH
To install the bleeding edge "develop" version, you can run:
$ pip install -e git+https://github.com/python-bonobo/bonobo@develop#egg=bonobo
To work on the source code, it's better to clone the repository and use an editable package:
$ git clone [email protected]:python-bonobo/bonobo.git --branch develop
$ pip install --editable bonobo
First, anybody, any level is welcome. Don't think you do not have enough experience, that's just plain wrong. Beginners and very experienced python enthusiasts are much welcome, and of course anybody in between or outside of this scope.
Learning bonobo should take much less than 1 hour (and I'll help!). It's a very good opportunity to make contributions to the first steps documentation. There must be typos here, minor errors, maybe completely erroneous things (I hope not!). Let's go together through the tutorials and fix whatever is unclear or erroneous. Also, if you think there are missing parts, feel free to add!
Tutorial: http://docs.bonobo-project.org/en/latest/tutorial/index.html
Best way to learn, after the first steps, is to actually try out and implement something. There are a lot of learnings to take from various people using the lib, please ask for assistance on anything, it will help building the best ETL for modern python!
There are a lot of open features and bugs. Some of them are explicitly flagged as "easy" (github tag) to allow easier spotting of good candidates. Feature code and bug fixes should include documentation and tests.
http://docs.bonobo-project.org/en/latest/contribute/index.html
Arrrglll... We hate them!
https://github.com/python-bonobo/bonobo/issues?q=is%3Aopen+is%3Aissue+label%3Abug
Those are ideas you can pick to work on something. It is not a definitive an exhaustive list, feel free to propose something else. If you start working on something, announce it to other participant by adding your handle on this page next to the topic, and in Slack. This will allow multiple persons interested by the same topic to work together, and also ease getting help.
- Better onboarding.
- Better API reference.
- Document the internal mechanisms (bags, queues, strategies ...)
- Better docs about sqlalchemy.
- A lot of errors are a bit cryptic for now. Especially the ones related to input format and prototype mismatching calls.
- We need to have the Queue implementation chosen by the Exectution Strategy, to allow more execution strategies (like asyncio, subprocess, dask ...)
- We need to rework how bonobo decide if an output is compatible with the next input. Type equality is too strict and cause a lot of trouble to users.
- What decorators can we remove? Especially thinking about the use_context, use_raw_input decorators.
- If we can't remove them, how can we make them better? We should not need to add them again in subclasses (or should we?). Decorators should work the same for CBT (class based transformations) and FBT (function based transformations).
- Can we optionally use type annotations for this purpose? Maybe "def xyz(context: NodeExecutionContext)" should be enough to ask for the context as a dependency?
- Can we optionally use type annotations for service injection? Maybe "def xyz(..., foo: ServiceReference('some_foo')" can be more explicit?
- Rework the Configurable inheritance mechanism (defaults? delete one?)
name, filter, fields
- @oagbaneje
- @maklori
- (your handle here)