0

我的 Web 应用程序Cerberus对每个请求使用架构验证(当前版本是 1.2)。为此,我在 YAML 中编写模式,在应用程序启动时加载它并进行验证,并使用大量反向引用来优化我的工作,如下面的模式所示。

在测试/运行时捕获模式错误是非常不幸的。如何在应用程序启动时验证模式本身而不为每个模式编写虚拟值?

---
_required_string: &required_string
  type: string
  empty: False
  required: True
  nullable: False

# Sign in request body
signin:
  type: dict
  empty: False
  nullable: False
  schema:
    name: *required_string
    password: *required_string
4

1 回答 1

0

我希望这能回答你的问题,因为我不太确定我是否理解正确。这确实有点像一种解决方法,但它也会做你想做的事。听起来您想在多个地方重用一组需求。我看到的最佳选择是创建一个自定义验证器子类并添加一个自定义验证器方法来处理共享规则集。鉴于您提供的示例,下面的代码应该可以工作。

from cerberus import Validator
import yaml

class MyValidator(Validator):
    def _validator_required_string(self, field, value):
        # Check the type
        if type(value) != str:
            self._error(field, "Must be of type 'str'")
        # Check the length
        if len(value) == 0:
            self._error(field, "Cannot be blank")

data = {"signin": { "name": "myusername",
                    "password": "mypassword"}}

schema = '''
signin:
    type: dict
    empty: False
    nullable: False
    schema:
        name:
            validator: required_string
        password:
            validator: required_string
'''

v = MyValidator(yaml.load(schema))

您可以在此处查看自定义验证器文档以了解命名要求。附带说明一下,如果您可以在 Python 代码而不是 YAML 中定义架构,则可以定义一个required_string变量,该变量包含您要使用的实际规则的字典,然后在更大的架构定义中引用该变量。这将允许您使用实际规则,而不必定义函数来实现规则。

于 2018-10-08T04:12:40.293 回答