2

我有一个OpenAPI 3.0规范,我想将它与Connexion一起使用来运行 Python 服务。

API规范的相关部分在这里:

paths:
  /find:
    post:
      summary: XXX
      description: XXX
      operationId: service.controllers.api.find
      requestBody:
        content:
          application/json:
            schema:
              type: object
              [...]
servers:
  - url: /v2
[...]

Python 代码的结构如下:

├── lib
│   └── service
│       ├── controllers
│       │   ├── api.py
│       │   ├── __init__.py
│       ├── __init__.py
│       ├── models
│       │   └── __init__.py
│       └── resources
│           └── openapi
│               └── openapi.yaml

的内容api.py

def find():
    return "TEST"

find函数本身按预期工作:

import service.controllers.api
service.controllers.api.find_skills()

'TEST'

在 Python 中,Connexion 可以很好地加载 API:

import connexion
app = connexion.FlaskApp(__name__, 
specification_dir='lib/service/resources/openapi/')
app.add_api('openapi.yaml')                                                                                                

<connexion.apis.flask_api.FlaskApi at 0x7f2241e35b38>

app.run()

现在,我可以成功调用端点:

$ curl -X POST http://localhost:5000/v2/find

但是,当我使用Connexion CLI运行它时,我看到ModuleNotFoundError

$ connexion run lib/service/resources/openapi/openapi.yaml

输出:

ERROR:connexion.apis.abstract:Failed to add operation for POST /v2/find
Traceback (most recent call last):
  File "/home/XXX/anaconda3/envs/find/lib/python3.6/site-packages/connexion/apis/abstract.py", line 206, in add_paths
    self.add_operation(path, method)
[...]
  File "/home/XXX/anaconda3/envs/find/lib/python3.6/site-packages/connexion/resolver.py", line 64, in resolve_function_from_operation_id
raise ResolverError(msg, sys.exc_info())
connexion.exceptions.ResolverError: <ResolverError: Cannot resolve operationId "service.controllers.api.find"! Import error was "No module named 'service'">

在这种情况下,路径/包名称可能有问题。但是,我也尝试了从lib目录等中调用它的许多变体,但没有运气。另外,我尝试仅使用方法名称并在x-swagger-router-controller属性中指定包,但也没有运气。

我无法operationId在 Connexion 文档中找到有关如何正确指定的更多具体细节,所以我什至不清楚这是否与 Python 模块本身、OpenAPI 规范或调用 Connexion 的方式有关。

关于从哪里开始挖掘的任何提示?为什么命令行客户端找不到service模块?相对于工作目录,模块应该驻留在哪里?

4

1 回答 1

3

我无法重现您的问题,但我相信它是由于 PYTHONPATH 造成的。

尝试执行:

PYTHONPATH=. connexion run lib/service/resources/openapi/openapi.yaml

于 2019-04-09T13:29:47.427 回答