GitXplorerGitXplorer
a

quiz

public
66 stars
4 forks
13 issues

Commits

List of commits on branch main.
Verified
c2e3d7c581a6edad7a225bc1731002076982e452

Merge pull request #738 from ariebovenberg/dependabot/pip/sphinx-approx-eq-8.0.2

aariebovenberg committed a month ago
Verified
2465c059bca743e57808749bf57d0574732d58dc

Update sphinx requirement from ~=7.4.7 to ~=8.0.2

ddependabot[bot] committed a month ago
Verified
88ff1695568e0ef96b19a3b630b2235f6b94a7a0

Merge pull request #739 from ariebovenberg/dependabot/pip/furo-approx-eq-2024.8

aariebovenberg committed a month ago
Verified
44939ae3718751c0f764a099c35b23d2de52d7f8

Update furo requirement from ~=2024.7 to ~=2024.8

ddependabot[bot] committed a month ago
Verified
32c4f26a0b81663a35e687e82e1c2da3f8be4c97

Merge pull request #737 from ariebovenberg/dependabot/pip/sphinx-approx-eq-7.4.7

aariebovenberg committed 2 months ago
Verified
62cd71565acddfeccd54abcefaaef54f24cee68c

Update sphinx requirement from ~=7.4.6 to ~=7.4.7

ddependabot[bot] committed 2 months ago

README

The README file for this repository.

🎱 Quiz

.. image:: https://img.shields.io/pypi/v/quiz.svg?style=flat-square :target: https://pypi.python.org/pypi/quiz

.. image:: https://img.shields.io/pypi/l/quiz.svg?style=flat-square :target: https://pypi.python.org/pypi/quiz

.. image:: https://img.shields.io/pypi/pyversions/quiz.svg?style=flat-square :target: https://pypi.python.org/pypi/quiz

.. image:: https://img.shields.io/readthedocs/quiz.svg?style=flat-square :target: http://quiz.readthedocs.io/

.. image:: https://img.shields.io/codecov/c/github/ariebovenberg/quiz.svg?style=flat-square&logo= :target: https://codecov.io/gh/ariebovenberg/quiz

.. image:: https://img.shields.io/badge/code%20style-black-000000.svg?style=flat-square :target: https://github.com/psf/black

Capable GraphQL client for Python.

Features:

  • Sync/async compatible, pluggable HTTP clients.
  • Auto-generate typed and documented python APIs
  • ORM-like syntax to write GraphQL.

Note that this project is in an early alpha stage. Some features are not yet implemented (see the roadmap below), and it may be a little rough around the edges. If you encounter a problem or have a feature request, don't hesitate to open an issue in the issue tracker <https://github.com/ariebovenberg/quiz/issues>_.

Quickstart

A quick 'n dirty request to GitHub's new V4 API:

.. code-block:: python3

import quiz query = ''' ... { ... repository(owner: "octocat", name: "Hello-World") { ... createdAt ... description ... } ... } ... ''' quiz.execute(query, url='https://api.github.com/graphql', ... auth=('me', 'password')) {"repository": ...}

Features

  1. Adaptability. Built on top of snug <http://snug.readthedocs.io/>_, quiz supports different HTTP clients

    .. code-block:: python3

    import requests result = quiz.execute(query, ..., client=requests.Session())

    as well as async execution (optionally with aiohttp <http:aiohttp.readthedocs.io/>_):

    .. code-block:: python3

    result = await quiz.execute_async(query, ...)

  2. Typing. Convert a GraphQL schema into documented python classes:

    .. code-block:: python3

    schema = quiz.Schema.from_url('https://api.github.com/graphql', ... auth=('me', 'password')) help(schema.Repository) class Repository(Node, ProjectOwner, Subscribable, Starrable, UniformResourceLocatable, RepositoryInfo, quiz.types.Object) | A repository contains the content for a project. | | Method resolution order: | ... | | Data descriptors defined here: | | assignableUsers | : UserConnection | A list of users that can be assigned to issues in this repo | | codeOfConduct | : CodeOfConduct or None | Returns the code of conduct for this repository ...

  3. GraphQL "ORM". Write queries as you would with an ORM:

    .. code-block:: python3

    _ = quiz.SELECTOR query = schema.query[ ... _ ... .repository(owner='octocat', name='Hello-World')[ ... _ ... .createdAt ... .description ... ] ... ] str(query) query { repository(owner: "octocat", name: "Hello-World") { createdAt description } }

  4. Offline query validation. Use the schema to catch errors quickly:

    .. code-block:: python3

    schema.query[ ... _ ... .repository(owner='octocat', name='Hello-World')[ ... _ ... .createdAt ... .foo ... .description ... ] ... ] SelectionError: SelectionError on "Query" at path "repository":

       SelectionError: SelectionError on "Repository" at path "foo":
    
           NoSuchField: field does not exist
    
  5. Deserialization into python objects. Responses are loaded into the schema's types. Use . to access fields:

    .. code-block:: python3

    r = quiz.execute(query, ...) r.repository.description "My first repository on GitHub!" isinstance(r.repository, schema.Repository) True

    If you prefer the raw JSON response, you can always do:

    .. code-block:: python3

    quiz.execute(str(query), ...) {"repository": ...}

Installation

quiz and its dependencies are pure python. Installation is easy as:

.. code-block:: bash

pip install quiz

Contributing

After you've cloned the repo locally, set up the development environment with:

.. code-block:: bash

make init

For quick test runs, run:

.. code-block:: bash

pytest

To run all tests and checks on various python versions, run:

.. code-block:: bash

make test

Generate the docs with:

.. code-block:: bash

make docs

Pull requests welcome!