Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/joeribekker/restorm
RestORM allows you to interact with resources as if they were objects.
https://github.com/joeribekker/restorm
Last synced: 3 months ago
JSON representation
RestORM allows you to interact with resources as if they were objects.
- Host: GitHub
- URL: https://github.com/joeribekker/restorm
- Owner: joeribekker
- License: mit
- Created: 2011-11-14T15:23:21.000Z (about 13 years ago)
- Default Branch: master
- Last Pushed: 2016-02-09T11:46:37.000Z (almost 9 years ago)
- Last Synced: 2024-10-12T07:29:28.329Z (4 months ago)
- Language: Python
- Homepage:
- Size: 213 KB
- Stars: 38
- Watchers: 4
- Forks: 16
- Open Issues: 3
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGES.rst
- License: LICENSE
Awesome Lists containing this project
- awesome-python-models - restorm - RestORM allows you to interact with resources as if they were objects. (ODM, ORM, Active Record)
README
.. image:: https://secure.travis-ci.org/joeribekker/restorm.png?branch=master
:alt: Build Status
:target: http://travis-ci.org/joeribekker/restormRestORM
=======RestORM allows you to interact with resources as if they were objects (object
relational mapping), mock an entire API and incorporate custom client logic.Description
-----------RestORM structures the way you access a RESTful API and allows you to easily
access related resources. It tries to be as generic as possible so it's not
tailored to any specific API or server-side API library. With RestORM you can
mock an entire API and replace the real client with a mock version in unit
tests. RestORM is very extensible but offers many functionalities out of the box
to get you up and running quickly.Currently, RestORM works on Python 2.5+ with Python 3 support on its way.
Features
--------* Object relational mapping of API resources (Django-like but does not depend on
Django at all).
* Flexible client architecture that can be used with your own or third party
clients (like oauth).
* Extensive mocking module allows you to mock API responses, or even
complete API's.
* Examples for Twitter and Flickr API.Quick start
===========This is a compressed version of the tutorial. The full documentation can be
found `here `_.Create a client
---------------A typical client that can talk to a RESTful API using JSON, is no more then:
.. sourcecode:: python
from restorm.clients.jsonclient import JSONClient
client = JSONClient(root_uri='http://www.example.com/api/')
Instead of this client, we mock its intended behaviour.
Create a mock API
-----------------In order to test your client, you can emulate a whole API using the
``MockApiClient`` and add pre-defined responses.The mock API below contains a list of books and a list of authors. To keep it
simple, both list resources contain only 1 item:.. sourcecode:: python
from restorm.clients.mockclient import MockApiClient
mock_client = MockApiClient(
responses={
'book/': {'GET': ({'Status': 200}, [{'isbn': 1, 'title': 'Dive into Python', 'resource_url': 'http://www.example.com/api/book/1'}])},
'book/1': {'GET': ({'Status': 200}, {'isbn': 1, 'title': 'Dive into Python', 'author': 'http://www.example.com/api/author/1'})},
'author/': {'GET': ({'Status': 200}, [{'id': 1, 'name': 'Mark Pilgrim', 'resource_url': 'http://www.example.com/author/1'}])},
'author/1': {'GET': ({'Status': 200}, {'id': 1, 'name': 'Mark Pilgrim'})}
},
root_uri='http://www.example.com/api/'
)Define resources
----------------We start with our main resource, the ``Book`` resource as a subclass of
``Resource``. Two attributes in the inner ``Meta`` class indicate a URL-pattern
how we can access all books (``list``) and a single book (``item``):.. sourcecode:: python
from restorm.resource import Resource
class Book(Resource):
class Meta:
list = r'^book/$'
item = r'^book/(?P\d)$'Bringing it all together
------------------------You can access the ``Book`` resource and the (runtime created) related
``Author`` resource using the ``mock_client``:.. sourcecode:: python
>>> book = Book.objects.get(isbn=1, client=mock_client) # Get book with ISBN number 1.
>>> book.data['title'] # Get the value of the key "name".
u'Dive into Python'
>>> book.data['author'] # Get the value of the key "author".
u'http://www.example.com/api/author/1'
>>> author = book.data.author # Perform a GET on the "author" resource.
>>> author.data['name']
u'Mark Pilgrim'Installation
============RestORM is on PyPI, so you can simply use::
$ pip install restorm
If you want the latest development version, get the code from Github::
$ pip install -e git+git://github.com/joeribekker/restorm.git#egg=restorm