-
Notifications
You must be signed in to change notification settings - Fork 768
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
Convert Django form / DRF decimals to Graphene decimals #958
Conversation
b3e60eb
to
7cd95a4
Compare
95ad7e5
to
2ab41dd
Compare
ab9143f
to
827f918
Compare
827f918
to
e5d47a9
Compare
e5d47a9
to
7a93319
Compare
7a93319
to
752c3ab
Compare
752c3ab
to
43457e6
Compare
43457e6
to
ef272cf
Compare
#91 is fixed, is this still relevant? What's this about |
@zbyte64 I don't think this is still relevant, i'll test and update it asap. The issue with the test, as far as i remember, registering a decimal as string affected incoming data type in pagination, paginator was expecting a decimal value (not sure how and why). |
ef272cf
to
db08426
Compare
db08426
to
4bf1871
Compare
4bf1871
to
aaa15c8
Compare
c1e6d28
to
aaa15c8
Compare
@@ -671,7 +671,7 @@ def resolve_all_reporters(self, info, **args): | |||
schema = Schema(query=Query) | |||
query = """ | |||
query NodeFilteringQuery { | |||
allReporters(limit: 1) { | |||
allReporters(limit: "1") { |
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.
@zbyte64 I couldn't understand why this change is necessary and i can use some help 🙂
The filter here uses NumberFilter
from django-filters and it expects a decimal input. Decimal(1) == Decimal("1")
is true but when that input is numeric 1, the test fails with
FAILED graphene_django/filter/tests/test_fields.py::test_should_query_filter_node_limit - assert not [GraphQLError('Argument "limit" has invalid value 1.\nExpected type "Decimal", found 1.')]
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.
I experimented with adding the following above line 671:
assert Query.all_reporters.filtering_args["limit"].type is Decimal, str(
Query.all_reporters.filtering_args["limit"].type
)
Interestingly this line did not fail. So we know we're generating the right graphene type at least.
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.
It is easier to get a stack trace with v3 than v2, still working on this :/
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.
Something interesting happened when I branched and rebased off v3, that particular error went away but then it stopped applying the limit, filter_limit
no longer gets called. BUT if I then switch the form conversion back to float the method gets called by django filter. Digging further the args being passed into DjangoFilterConnectoinField.resolve_queryset
as limit
as None
when we convert to Decimal but not Float.
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.
Traced the issue to graphene, I'll be sending them a PR in a moment
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.
This should fix the issue we were seeing: graphql-python/graphene#1295
9914e94
to
c995be9
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.
LGTM thanks @ulgens
(this should probably be part of the v3 release since it's a breaking change)
@zbyte64 Why did we just merge it? 🙂 graphene didn't release a v2 version with decimal fix. I was intended to revert 1 -> "1" after that fix. |
Fixes #91
(Branch name is outdated. I can create a new PR if it's necessary.)