【问题标题】:Test coverage of protobuff messages测试 protobuf 消息的覆盖率
【发布时间】:2014-08-05 11:57:52
【问题描述】:

我有一个 .proto 文件,里面有几个 看起来像这样的消息,

Message messageA{
  required double value =1;
  //more fields
} 

Message messageB{
   required int32 value =1;
   //more fields
} 

我想验证添加到文件中的每条消息是否都有一个“值”字段。 如果没有,正确的结果将是单元测试失败。

有没有更好的方法来做到这一点 希望下一个程序员将​​消息实例添加到测试中?

谢谢。

【问题讨论】:

    标签: c++ unit-testing protocol-buffers test-coverage


    【解决方案1】:

    您可以通过协议缓冲区反射来实现这一点。 FileDescriptor 类允许您遍历文件中的所有消息(为此使用“message_type(int index)”函数)。然后,您可以在消息Descriptor 上使用“FindFieldByName()”来确定是否存在名为“value”的字段。

    在一个完全不相关的旁注中,我强烈建议您在协议缓冲区消息中使用“可选”而不是“必需”。应用程序要求最好由应用程序本身而不是在反序列化逻辑中施加;如果不满足此条件,使用“可选”允许应用程序代码更优雅地失败,而“必需”会导致崩溃,不幸的是,稍后将消息中的字段从“必需”更改为“可选”可能非常危险(因为旧的应用程序可能仍认为它是必需的,而后续应用程序可能不再填充它)。

    【讨论】:

    • 谢谢迈克尔。已经找到了:-)。效果很好。我正在使用 protobuf 来执行与外部软件的合同,因此 required 在这里非常有用。
    • @YuvalCarmel,即使对于外部软件,最好在评论中指出并应用您自己的验证,而不是使用 Parse() 来强制执行此验证,因为 1.) 您最终可能会遇到案例您允许字段的替代组合来取代前一个字段 2.) 并非所有实现都强制执行此检查(例如 Python 的 protobuf 实现等同于 ParsePartial,它不检查必填字段)。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-01-07
    • 2018-10-18
    相关资源
    最近更新 更多