當前位置: 首頁>>代碼示例>>Python>>正文


Python graphql.graphql方法代碼示例

本文整理匯總了Python中graphql.graphql方法的典型用法代碼示例。如果您正苦於以下問題:Python graphql.graphql方法的具體用法?Python graphql.graphql怎麽用?Python graphql.graphql使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在graphql的用法示例。


在下文中一共展示了graphql.graphql方法的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: execute_query_against_remote

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import graphql [as 別名]
def execute_query_against_remote(host, query, variables):
    parsed_url = urlparse(host)
    if not (parsed_url.scheme and parsed_url.netloc):
        raise click.UsageError(
            'Host {host} is not a valid URL. Host URL should include scheme ie http://localhost'.format(
                host=host
            )
        )

    sanity_check = requests.get(urljoin(host, '/dagit_info'))
    sanity_check.raise_for_status()
    if 'dagit' not in sanity_check.text:
        raise click.UsageError(
            'Host {host} failed sanity check. It is not a dagit server.'.format(host=host)
        )

    response = requests.post(
        urljoin(host, '/graphql'), params={'query': query, 'variables': variables}
    )
    response.raise_for_status()
    str_res = response.json()
    return str_res 
開發者ID:dagster-io,項目名稱:dagster,代碼行數:24,代碼來源:cli.py

示例2: execute_dagster_graphql

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import graphql [as 別名]
def execute_dagster_graphql(context, query, variables=None):
    result = graphql(
        create_schema(),
        query,
        context=context,
        variables=variables,
        allow_subscriptions=True,
        return_promise=False,
    )

    # has to check attr because in subscription case it returns AnonymousObservable
    if hasattr(result, 'errors') and result.errors:
        first_error = result.errors[0]
        if hasattr(first_error, 'original_error') and first_error.original_error:
            raise result.errors[0].original_error

        raise result.errors[0]

    return result 
開發者ID:dagster-io,項目名稱:dagster,代碼行數:21,代碼來源:utils.py

示例3: test_correctly_refetches_rebels

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import graphql [as 別名]
def test_correctly_refetches_rebels():
    query = """
      query RebelsRefetchQuery {
        node(id: "RmFjdGlvbjox") {
          id
          ... on Faction {
            name
          }
        }
      }
    """
    expected = {
        "node": {"id": "RmFjdGlvbjox", "name": "Alliance to Restore the Republic"}
    }
    result = await graphql(StarWarsSchema, query)
    assert result == (expected, None) 
開發者ID:graphql-python,項目名稱:graphql-relay-py,代碼行數:18,代碼來源:test_star_wars_object_identification.py

示例4: _format_error

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import graphql [as 別名]
def _format_error(error: Exception) -> Dict[str, Any]:
        """Format given exception `error` to send over a network."""
        if isinstance(error, graphql.error.GraphQLError):
            return dict(graphql.error.format_error(error))

        return {"message": f"{type(error).__name__}: {str(error)}"} 
開發者ID:datadvance,項目名稱:DjangoChannelsGraphqlWs,代碼行數:8,代碼來源:graphql_ws_consumer.py

示例5: test_correctly_fetches_id_name_rebels

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import graphql [as 別名]
def test_correctly_fetches_id_name_rebels():
    query = """
      query RebelsQuery {
        rebels {
          id
          name
        }
      }
    """
    expected = {
        "rebels": {"id": "RmFjdGlvbjox", "name": "Alliance to Restore the Republic"}
    }
    result = await graphql(StarWarsSchema, query)
    assert result == (expected, None) 
開發者ID:graphql-python,項目名稱:graphql-relay-py,代碼行數:16,代碼來源:test_star_wars_object_identification.py

示例6: test_correctly_fetches_id_name_empire

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import graphql [as 別名]
def test_correctly_fetches_id_name_empire():
    query = """
      query EmpireQuery {
        empire {
          id
          name
        }
      }
    """
    expected = {"empire": {"id": "RmFjdGlvbjoy", "name": "Galactic Empire"}}
    result = await graphql(StarWarsSchema, query)
    assert result == (expected, None) 
開發者ID:graphql-python,項目名稱:graphql-relay-py,代碼行數:14,代碼來源:test_star_wars_object_identification.py

示例7: test_correctly_refetches_empire

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import graphql [as 別名]
def test_correctly_refetches_empire():
    query = """
      query EmpireRefetchQuery {
        node(id: "RmFjdGlvbjoy") {
          id
          ... on Faction {
            name
          }
        }
      }
    """
    expected = {"node": {"id": "RmFjdGlvbjoy", "name": "Galactic Empire"}}
    result = await graphql(StarWarsSchema, query)
    assert result == (expected, None) 
開發者ID:graphql-python,項目名稱:graphql-relay-py,代碼行數:16,代碼來源:test_star_wars_object_identification.py

示例8: test_correctly_refetches_xwing

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import graphql [as 別名]
def test_correctly_refetches_xwing():
    query = """
      query XWingRefetchQuery {
        node(id: "U2hpcDox") {
          id
          ... on Ship {
            name
          }
        }
      }
    """
    expected = {"node": {"id": "U2hpcDox", "name": "X-Wing"}}
    result = await graphql(StarWarsSchema, query)
    assert result == (expected, None) 
開發者ID:graphql-python,項目名稱:graphql-relay-py,代碼行數:16,代碼來源:test_star_wars_object_identification.py

示例9: test_correctly_mutates_dataset

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import graphql [as 別名]
def test_correctly_mutates_dataset():
    query = """
      mutation AddBWingQuery($input: IntroduceShipInput!) {
        introduceShip(input: $input) {
          ship {
            id
            name
          }
          faction {
            name
          }
          clientMutationId
        }
      }
    """
    params = {
        "input": {"shipName": "B-Wing", "factionId": "1", "clientMutationId": "abcde"}
    }
    expected = {
        "introduceShip": {
            "ship": {"id": "U2hpcDo5", "name": "B-Wing"},
            "faction": {"name": "Alliance to Restore the Republic"},
            "clientMutationId": "abcde",
        }
    }
    result = await graphql(StarWarsSchema, query, variable_values=params)
    assert result == (expected, None) 
開發者ID:graphql-python,項目名稱:graphql-relay-py,代碼行數:29,代碼來源:test_star_wars_mutations.py

示例10: execute

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import graphql [as 別名]
def execute(self, request_context, params):
        return graphql(
            self.schema, **dict(params, allow_subscriptions=True)) 
開發者ID:graphql-python,項目名稱:graphql-ws,代碼行數:5,代碼來源:base.py

示例11: _send_gql_data

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import graphql [as 別名]
def _send_gql_data(
        self, operation_id, data: dict, errors: Optional[Sequence[Exception]]
    ):
        """Send GraphQL `data` message to the client.

        Args:
            data: Dict with GraphQL query response.
            errors: List of exceptions occurred during processing the
                GraphQL query. (Errors happened in resolvers.)

        """
        self._assert_thread()
        # Log errors with tracebacks so we can understand what happened
        # in a failed resolver.
        for ex in errors or []:
            # Typical exception here is `GraphQLLocatedError` which has
            # reference to the original error raised from a resolver.
            tb = ex.__traceback__
            if (
                isinstance(ex, graphql.error.located_error.GraphQLLocatedError)
                and ex.original_error is not None
            ):
                tb = ex.stack
                ex = ex.original_error
            LOG.error(
                "GraphQL resolver failed on operation with id=%s:\n%s",
                operation_id,
                "".join(traceback.format_exception(type(ex), ex, tb)).strip(),
            )

        await self.send_json(
            {
                "type": "data",
                "id": operation_id,
                "payload": {
                    "data": data,
                    **(
                        {"errors": [self._format_error(e) for e in errors]}
                        if errors
                        else {}
                    ),
                },
            }
        ) 
開發者ID:datadvance,項目名稱:DjangoChannelsGraphqlWs,代碼行數:46,代碼來源:graphql_ws_consumer.py

示例12: execute_query

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import graphql [as 別名]
def execute_query(workspace, query, variables=None, use_sync_executor=False, instance=None):
    check.inst_param(workspace, 'workspace', Workspace)
    check.str_param(query, 'query')
    check.opt_dict_param(variables, 'variables')
    instance = (
        check.inst_param(instance, 'instance', DagsterInstance)
        if instance
        else DagsterInstance.get()
    )
    check.bool_param(use_sync_executor, 'use_sync_executor')

    query = query.strip('\'" \n\t')

    locations = [RepositoryLocation.from_handle(x) for x in workspace.repository_location_handles]

    context = DagsterGraphQLContext(locations=locations, instance=instance, version=__version__,)

    executor = SyncExecutor() if use_sync_executor else GeventExecutor()

    result = graphql(
        request_string=query,
        schema=create_schema(),
        context_value=context,
        variable_values=variables,
        executor=executor,
    )

    result_dict = result.to_dict()

    context.drain_outstanding_executions()

    # Here we detect if this is in fact an error response
    # If so, we iterate over the result_dict and the original result
    # which contains a GraphQLError. If that GraphQL error contains
    # an original_error property (which is the exception the resolver
    # has thrown, typically) we serialize the stack trace of that exception
    # in the 'stack_trace' property of each error to ease debugging

    if 'errors' in result_dict:
        check.invariant(len(result_dict['errors']) == len(result.errors))
        for python_error, error_dict in zip(result.errors, result_dict['errors']):
            if hasattr(python_error, 'original_error') and python_error.original_error:
                error_dict['stack_trace'] = get_stack_trace_array(python_error.original_error)

    return result_dict 
開發者ID:dagster-io,項目名稱:dagster,代碼行數:47,代碼來源:cli.py

示例13: test_execute_hammer_through_dagit

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import graphql [as 別名]
def test_execute_hammer_through_dagit():
    # TODO: remove dependency on legacy_examples
    # https://github.com/dagster-io/dagster/issues/2653
    recon_repo = ReconstructableRepository.for_file(
        file_relative_path(
            __file__, '../../../../examples/legacy_examples/dagster_examples/toys/hammer.py'
        ),
        'hammer_pipeline',
    )
    instance = DagsterInstance.local_temp()

    context = DagsterGraphQLContext(
        locations=[InProcessRepositoryLocation(recon_repo)], instance=instance,
    )

    selector = infer_pipeline_selector(context, 'hammer_pipeline')

    executor = SyncExecutor()

    variables = {
        'executionParams': {
            'runConfigData': {
                'storage': {'filesystem': {}},
                'execution': {'dask': {'config': {'cluster': {'local': {}}}}},
            },
            'selector': selector,
            'mode': 'default',
        }
    }

    start_pipeline_result = graphql(
        request_string=LAUNCH_PIPELINE_EXECUTION_MUTATION,
        schema=create_schema(),
        context=context,
        variables=variables,
        executor=executor,
    )

    if start_pipeline_result.errors:
        raise Exception('{}'.format(start_pipeline_result.errors))

    run_id = start_pipeline_result.data['launchPipelineExecution']['run']['runId']

    context.drain_outstanding_executions()

    subscription = execute_dagster_graphql(context, SUBSCRIPTION_QUERY, variables={'runId': run_id})

    subscribe_results = []
    subscription.subscribe(subscribe_results.append)

    messages = [x['__typename'] for x in subscribe_results[0].data['pipelineRunLogs']['messages']]

    assert 'PipelineStartEvent' in messages
    assert 'PipelineSuccessEvent' in messages 
開發者ID:dagster-io,項目名稱:dagster,代碼行數:56,代碼來源:test_graphql.py


注:本文中的graphql.graphql方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。