Description
I think it's time to discuss a versioning and naming policy for the graphql-python tools so we can move forward.
We currently have three "generations" of the underlying core library:
- graphql-core (supports Python 2+3, old API, based on an old version of GraphQL.js)
- graphql-core-next (supports only Python >= 3.6, new API, latest features from GraphQL.js)
- graphql-core/modern branch (trys to be compatible with core-next, but support Py 2 + 3)
All of these use the package name "graphql" (like GraphQL.js) which makes things difficult, and currently have version numbers that are not (chrono)logical (core-next has a lower version number than core).
We also have a large set of other libraries that use graphql-core as their foundation: Graphene, graphql-server-core, flask-graphql, graphene-sqlalchemy etc. etc.
We want to move things forward, but not break this whole carefully assembled house of cards or create a proliferation of different forks and subvariants. So we need to talk on how to proceed regarding the versioning and naming strategy.
Some questions that come to my mind:
- Do we really want to support the graphql-core/modern branch? Yes, it looks like a reasonable strategy and @syrusakbary already put a lot of work into this, but I'm not sure if it's realistic to keep it - to me it seems too much of an effort just for supporting Python 2.7 (end of life 2020-01) and Python 3.5 (end of life 2020-09), and I see nobody who feels responsible and will maintain it. Syrus dropped out, and I want to focus on core-next. And it makes the whole story even more complicated like juggling with three balls. But I'd like to hear the opinion of others, and maybe somebody really wants to maintain it?
- When the existing tools are rebased on the new API (graphql-core-next), should they be released under a new name (like graphql-server-core-next) or should they keep the name and use a new major version number? Should new repositories be created or just separate branches in the existing repositories?
- Should we use different names instead of just "graphql" for the base package so that graphql-core and core-next can be installed in parallel?
- Or should we use the same name, maybe even release them under the same well-known name ("graphql-core") on PyPI and distinguish them by version number ranges (e.g. core = 2.x, core/modern = 3.x, core-next = 4.x+)?
- Or maybe even choose a completely different distribution name? "GraphQL.py" or "graphql" would be great, but they are already in use.
I'd like to get your thoughts and feedback here or on the Slack channel.
Activity
jplock commentedon Apr 5, 2019
I like the idea of the
graphql-core-next
project being the one and only python GraphQL implementation, retire the other two, and have it replacegraphql-core
(published with a major-version bump to 3.x or something) in PyPI.Then update the dependent projects, where possible, around that new major version, bumping their major versions as well.
Nabellaleen commentedon Apr 5, 2019
core
projects should be "unified" in the same repository and "differentiated" throught their version numbergraphql-core
is a better name thangraphql-core-next
for the long term. Becausenext
is a relative term. So it has sense now, because there is the "old"graphql-core
, but in the future, this "old" version will disappear, andgraphql-core-next
will be a very bad name, creating confusion.graphql-core
is not a bad name, so we could keep itgraphql-core
, to do not "force" 2.7 projects to migrate their python because ofgraphql-core
repositoryBase on that, I think we should migrate
modern
andnext
as3.x
and4.x
like @Cito suggested. And we should stop to develop new "features" for thelegacy
andmodern
versions, to just provide a "long term security support".And all the other projects in the organisation should follow this principle, migrating in a major version to the
4.x
version, and just keeping a "long term security support" for the previous (the current today ;)) versionProjectCheshire commentedon Apr 5, 2019
Similar to above, I prefer a semver policy. Nb We also need to add a toggle on the docs so people can refer to previous versions and the relevant docs.(eg how would this even be done spread across packages? Also, more integration (or even a reference to) the core next docs from graphene)
It makes more sense to install and require based on versions / releases vs switching entire packages. Install @4.x or above or more than 2 less than 4. Features on 4.x only, maintenence (and bug fix if the contributor provides a compatible pr for that release) for the rest
mvanlonden commentedon Apr 6, 2019
Agree with @Nabellaleen.
graphql-core
is a better name. I think it would make sense to movegraphql-core-next
intographql-core
as a branch and use semver when we are ready to move the version forward.Cito commentedon Apr 29, 2019
I suggest to get the ball ralling, we call the Py3-only version 3, and use this version numbers also for the other projects - i.e. Graphene 3 should be Py3-only and use graphql-core-next. If somebody still wants to create and maintain the Py2+3-compatible branch, it can still be released as 2.5 then. I think that is more intuitive than using versions 3 and 4, particularly if 3 never happens.
changeling commentedon May 4, 2019
I completely support the idea of graphql-core-next becoming graphql-core version 3.
I suggest there be a very, very clear point of communication outside the
Issue
discussions, pointedly available for all related and dependent packages illustrating the plan, the roadmap and intended changes to core packages. I'd suggest that at this point there may be some value in using wiki, duplicated in both packages, presenting what's actually going on. However, if allocating time to ensuring the wiki is current proves unlikely, a ROADMAP that is maintained might be more applicable.Or, rather, I think at this point there's great value in establishing a single point of canonical information the userspace can look to for current status information and evolutionary planning, particularly addressing what happens when the merge hits. i.e. graph-core-next dependencies should be updated to graphql-core:^3 or equivalent versioning.
Which brings up a question. Does graph-core-next go away at that point? Are Issues, if relevant, preserved in some way? Commit history? Does anyone care about those things? Etcetera.
On a personal note, I'm trying to follow the
Issue
level conversations and finding it frustrating. This may be limiting adoption by others. I was on the verge of dismissing this as a viable long-term dependency, particularly after a brief scan of the opening post for graphql-python/graphene#884, which reads like a common death-knell for open sourced projects.Upon further digging, I saw that there was renewed support for ongoing development, and decided to keep learning. And I suspect I'm not alone. I was encouraged by this only because I was diligently watching the Issues. Not all 'searchers' will be digging that deeply.
This rant, and yeah... I'm kinda ranting. Mea culpa... was in part inspired by graphql-python/graphql-core#21
But yes. By all means, core version 3. And please give a single-point source for what the... well.. f or h, your choice of profanity level, is going on and about to happen. ::cha-grin::
I so, so want this to rock the world. Or at least my use-case world. Thank you for re-invigorating this project.
Cito commentedon May 4, 2019
I definitely care. My idea is to keep core and core-next as separate repositories. They would be released under the same graphql-core distribution name on PyPI, differentiated by their version number ranges. I'm still waiting for more feedback from the community and from Syrus, who also needs to give push access to the PyPI project. That's why for now I have still published the current release as graphql-core-next 1.0.3. Things were a lot easier when everything was managed by one person, who did an amazing job and was so incredibly productive. But in the long run I think the project will be better off when the responsibility is spread to different people - even if decisions, coordination and realization of ideas takes more time and can be frustratingly slow since all of us have day jobs and families and life often gets into the way of all our good plans and ambitions. Proper funding or a BDFL would help, but currently we need to do without these. I'm confident that everything will work out.
eMerzh commentedon May 4, 2019
Yeah sounds good to me, let start with a version 3! And avoid wasting too much time on 2 project and let the project stale during this time....
Again thanks a lot(!!) For moving this forward.
changeling commentedon May 4, 2019
That approach gets my vote!
It's honestly kinda stunning how far it came as a one-person project. Major kudos and thanks, @syrusakbary.
eMerzh commentedon May 22, 2019
@Cito doesn't want to push you here,
but do you have an idea if your plan is settled? and if yes do you have an estimated timeframe for the publish of the version 3. ?
10 remaining items