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

Fix the Surreal.patch method #100

Closed

Conversation

Wouterkoorn
Copy link

Change request method type from "modify" to "patch". And fix type annotations.

What is the motivation?

Surreal.patch is currently not usable.
Fixing type annotations improved developer experience.

Type of Change

  • 📚 Examples / docs / tutorials / dependencies update
  • 🔧 Bug fix (non-breaking change which fixes an issue)
  • 🥂 Improvement (non-breaking change which improves an existing feature)
  • 🚀 New feature (non-breaking change which adds functionality)
  • 💥 Breaking change (fix or feature that would cause existing functionality to change)
  • 🔐 Security fix

What does this change do?

  1. Changes the Surreal.patch request method type from "modify" to "patch"
  2. Changes the Surreal.patch's data parameter type to Optional[List[Dict[str, Any]]]
  3. Changes the Surreal.patch return type to Union[dict[str, Any], List[Dict[str, Any]]]

What is your testing strategy?

mypy OK
pre-commit OK
./scripts/run_tests.sh OK
manual testing OK

Is this related to any issues?

Yes: #99

Have you read the Contributing Guidelines?

Change request method type from "modify" to "patch". And fix type annotations.
@@ -598,6 +600,7 @@ async def patch(
{ 'op': "remove", "path": "/temp" },
])
"""
data = data or []
Copy link
Author

@Wouterkoorn Wouterkoorn Apr 2, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is for backwards compatibility, making the change non-breaking.
The typing was Optional, but the server requires an array, None is invalid.

@tobiemh
Copy link
Member

tobiemh commented Nov 25, 2024

Closing this pull-request as the latest codebase has now been significantly updated, now making use of a native Python with binary communication with remote databases, and support for embedded database usage. The native Python library now has support for custom types, including datetimes, durations, decimals, geojson types, Record IDs, ranges, and tables 🎉.

@tobiemh tobiemh closed this Nov 25, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants