Search code examples
pythongraphqlaiohttpgraphene-python

aiohttp-graphql AsyncioExecutor GraphQLLocatedError: 'NoneType' object is not callable


I'm starting with asyncio + GraphQL, but cannot get even the simplest example to work:

from aiohttp import web
from aiohttp_graphql import GraphQLView
from graphql.execution.executors.asyncio import AsyncioExecutor
from graphql import GraphQLSchema, GraphQLObjectType, GraphQLField, GraphQLString

async def resolve_hello(root, info):
    return 'World!'

Schema = GraphQLSchema(
    query=GraphQLObjectType(
        name='RootQueryType',
        fields={
            'hello': GraphQLField(
                type=GraphQLString,
                resolver=resolve_hello),
        },
    ))

app = web.Application()
GraphQLView.attach(
    app,
    route_path='/graphql',
    schema=Schema,
    graphiql=True,
    executor=AsyncioExecutor)

if __name__ == '__main__':
    web.run_app(app)

Console:

$ venv/bin/python example.py
======== Running on http://0.0.0.0:8080 ========
(Press CTRL+C to quit)
An error occurred while resolving field RootQueryType.hello
Traceback (most recent call last):
  File "/.../venv/lib/python3.7/site-packages/graphql/execution/executor.py", line 447, in resolve_or_error
    return executor.execute(resolve_fn, source, info, **args)
  File "/.../venv/lib/python3.7/site-packages/graphql/execution/executors/asyncio.py", line 69, in execute
    result = fn(*args, **kwargs)
TypeError: 'NoneType' object is not callable
Traceback (most recent call last):
  File "/.../venv/lib/python3.7/site-packages/graphql/execution/executor.py", line 447, in resolve_or_error
    return executor.execute(resolve_fn, source, info, **args)
  File "/.../venv/lib/python3.7/site-packages/graphql/execution/executors/asyncio.py", line 69, in execute
    result = fn(*args, **kwargs)
graphql.error.located_error.GraphQLLocatedError: 'NoneType' object is not callable

Error message in /graphql graphiql interface:

{
  "errors": [
    {
      "message": "wait_until_finished() missing 1 required positional argument: 'self'"
    }
  ]
}

Solution

  • The problem was in the executor setup:

    GraphQLView.attach(
        ...
        executor=AsyncioExecutor)
    

    should be

    GraphQLView.attach(
        ...
        executor=AsyncioExecutor())