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


Python json_format.MessageToDict方法代碼示例

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


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

示例1: environ

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def environ(self, *proto_msgs, **kwargs):
    """Sets environment data for this test case."""
    ret = self.test(None)

    to_apply = []

    for msg in proto_msgs:
      if not isinstance(msg, PBMessage):
        raise ValueError(
            'Positional arguments for api.properties must be protobuf messages.'
            ' Got: %r (type %r)' % (msg, type(msg)))
      to_apply.append(jsonpb.MessageToDict(
          msg, preserving_proto_field_name=True))

    to_apply.append(kwargs)

    for dictionary in to_apply:
      for key, value in dictionary.iteritems():
        if not isinstance(value, (int, float, basestring)):
          raise ValueError(
              'Environment values must be int, float or string. '
              'Got: %r=%r (type %r)' % (key, value, type(value)))
        ret.environ[key] = str(value)

    return ret 
開發者ID:luci,項目名稱:recipes-py,代碼行數:27,代碼來源:test_api.py

示例2: _transform

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def _transform(pb_node):
    fields = []
    for i in pb_node.items:
        item_type = i.WhichOneof('value')
        if item_type == 'field':
            if not i.field.name:
                raise TypeError('Field name is empty: {!r}'.format(i))
            options = None
            if i.field.HasField('options'):
                options = MessageToDict(i.field.options)
            fields.append(Field(i.field.name, options))
        elif item_type == 'link':
            if not i.link.name:
                raise TypeError('Link name is empty: {!r}'.format(i))
            options = None
            if i.link.HasField('options'):
                options = MessageToDict(i.link.options)
            fields.append(Link(i.link.name, _transform(i.link.node), options))
        else:
            raise TypeError('Node item is empty: {!r}'.format(i))
    return Node(fields) 
開發者ID:vmagamedov,項目名稱:hiku,代碼行數:23,代碼來源:protobuf.py

示例3: GenTests

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def GenTests(api):
  yield (
      api.test('basic') +
      api.buildbucket.simulated_get(build_pb2.Build(
          id=9016911228971028736, status=common_pb2.SUCCESS,
      )) +
      api.buildbucket.simulated_get_multi([
        build_pb2.Build(id=9016911228971028736, status=common_pb2.SUCCESS),
        build_pb2.Build(id=9016911228971028737, status=common_pb2.SUCCESS),
      ]) +
      api.buildbucket.simulated_buildbucket_output(None, step_name='legacy_get')
  )


  yield (
      api.test('failed request') +
      api.step_data(
          'buildbucket.get',
          api.json.output_stream(
              json_format.MessageToDict(builds_service_pb2.BatchResponse(
                  responses=[dict(error=dict(message='there was a problem'))],
              )),
          ),
        )
  ) 
開發者ID:luci,項目名稱:recipes-py,代碼行數:27,代碼來源:get.py

示例4: __call__

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def __call__(self, hostname=None, triggers=None):
    """Emulates scheduler module state.

    triggers must be None or a list of triggers_pb2.Trigger objects.
    """
    assert hostname is None or isinstance(hostname, basestring)
    assert not triggers or all(
        isinstance(t, triggers_pb2.Trigger) for t in triggers)
    ret = self.test(None)
    ret.properties.update(**{
      '$recipe_engine/scheduler': {
        'hostname': hostname,
        'triggers': [json_format.MessageToDict(t) for t in triggers or []],
      },
    })
    return ret 
開發者ID:luci,項目名稱:recipes-py,代碼行數:18,代碼來源:test_api.py

示例5: test_rolls

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def test_rolls(recipe_deps, verbose_json):
  candidates, rejected_candidates, repos = get_roll_candidates(recipe_deps)

  roll_details = []
  picked_roll_details = None
  trivial = True
  if candidates:
    trivial, picked_roll_details, roll_details = process_candidates(
        recipe_deps, candidates, repos, verbose_json)

  ret = {
    # it counts as success if there are no candidates at all :)
    'success': bool(not candidates or picked_roll_details),
    'trivial': trivial,
    'roll_details': roll_details,
    'picked_roll_details': picked_roll_details,
    'rejected_candidates_count': len(rejected_candidates),
  }
  if verbose_json:
    ret['rejected_candidate_specs'] = [
      jsonpb.MessageToDict(c.repo_spec, preserving_proto_field_name=True)
      for c in rejected_candidates
    ]
  return ret 
開發者ID:luci,項目名稱:recipes-py,代碼行數:26,代碼來源:cmd.py

示例6: testExtensionSerializationDictMatchesProto3Spec

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def testExtensionSerializationDictMatchesProto3Spec(self):
    """See go/proto3-json-spec for spec.
    """
    message = unittest_mset_pb2.TestMessageSetContainer()
    ext1 = unittest_mset_pb2.TestMessageSetExtension1.message_set_extension
    ext2 = unittest_mset_pb2.TestMessageSetExtension2.message_set_extension
    message.message_set.Extensions[ext1].i = 23
    message.message_set.Extensions[ext2].str = 'foo'
    message_dict = json_format.MessageToDict(
        message
    )
    golden_dict = {
        'messageSet': {
            '[protobuf_unittest.'
            'TestMessageSetExtension1.messageSetExtension]': {
                'i': 23,
            },
            '[protobuf_unittest.'
            'TestMessageSetExtension2.messageSetExtension]': {
                'str': 'foo',
            },
        },
    }
    self.assertEqual(golden_dict, message_dict) 
開發者ID:ryfeus,項目名稱:lambda-packs,代碼行數:26,代碼來源:json_format_test.py

示例7: test_update_product_no_explicit_name

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def test_update_product_no_explicit_name(self, get_conn):
        # Given
        product = Product()
        update_product_method = get_conn.return_value.update_product
        update_product_method.return_value = product
        product_name = ProductSearchClient.product_path(PROJECT_ID_TEST, LOC_ID_TEST, PRODUCT_ID_TEST)
        # When
        result = self.hook.update_product(
            location=LOC_ID_TEST,
            product_id=PRODUCT_ID_TEST,
            product=product,
            update_mask=None,
            project_id=PROJECT_ID_TEST,
            retry=None,
            timeout=None,
            metadata=None,
        )
        # Then
        self.assertEqual(result, MessageToDict(product))
        update_product_method.assert_called_once_with(
            product=Product(name=product_name), metadata=None, retry=None, timeout=None, update_mask=None
        ) 
開發者ID:apache,項目名稱:airflow,代碼行數:24,代碼來源:test_vision.py

示例8: execute

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def execute(self, context):
        hook = CloudAutoMLHook(gcp_conn_id=self.gcp_conn_id)
        self.log.info("Creating model.")
        operation = hook.create_model(
            model=self.model,
            location=self.location,
            project_id=self.project_id,
            retry=self.retry,
            timeout=self.timeout,
            metadata=self.metadata,
        )
        result = MessageToDict(operation.result())
        model_id = hook.extract_object_id(result)
        self.log.info("Model created: %s", model_id)

        self.xcom_push(context, key="model_id", value=model_id)
        return result 
開發者ID:apache,項目名稱:airflow,代碼行數:19,代碼來源:automl.py

示例9: execute

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def execute(self, context):
        hook = CloudDLPHook(gcp_conn_id=self.gcp_conn_id)
        try:
            template = hook.create_deidentify_template(
                organization_id=self.organization_id,
                project_id=self.project_id,
                deidentify_template=self.deidentify_template,
                template_id=self.template_id,
                retry=self.retry,
                timeout=self.timeout,
                metadata=self.metadata,
            )
        except AlreadyExists:
            template = hook.get_deidentify_template(
                organization_id=self.organization_id,
                project_id=self.project_id,
                template_id=self.template_id,
                retry=self.retry,
                timeout=self.timeout,
                metadata=self.metadata,
            )

        return MessageToDict(template) 
開發者ID:apache,項目名稱:airflow,代碼行數:25,代碼來源:dlp.py

示例10: simulated_search_results

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def simulated_search_results(self, builds, step_name=None):
    """Simulates a buildbucket.search call."""
    assert isinstance(builds, list), builds
    assert all(isinstance(b, build_pb2.Build) for b in builds), builds

    step_name = step_name or 'buildbucket.search'
    lines = [json.dumps(json_format.MessageToDict(b)) for b in builds]
    output = "\n".join(lines)
    return self.step_data(step_name, self.m.raw_io.stream_output(output)) 
開發者ID:luci,項目名稱:recipes-py,代碼行數:11,代碼來源:test_api.py

示例11: simulated_get

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def simulated_get(self, build, step_name=None):
    """Simulates a buildbucket.get call."""
    step_name = step_name or 'buildbucket.get'
    jsonish = json_format.MessageToDict(builds_service_pb2.BatchResponse(
        responses=[dict(get_build=build)],
    ))
    return self.step_data(step_name, self.m.json.output_stream(jsonish)) 
開發者ID:luci,項目名稱:recipes-py,代碼行數:9,代碼來源:test_api.py

示例12: simulated_get_multi

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def simulated_get_multi(self, builds, step_name=None):
    """Simulates a buildbucket.get_multi call."""
    step_name = step_name or 'buildbucket.get_multi'
    jsonish = json_format.MessageToDict(builds_service_pb2.BatchResponse(
        responses=[dict(get_build=b) for b in builds],
    ))
    return self.step_data(step_name, self.m.json.output_stream(jsonish)) 
開發者ID:luci,項目名稱:recipes-py,代碼行數:9,代碼來源:test_api.py

示例13: _simulated_batch_response

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def _simulated_batch_response(self, batch_response, step_name):
    """Simulate that the given step will write the provided batch response into
    step data. The return code will be 1 for step data if the responses contain
    error. Otherwise, 0
    """
    assert isinstance(batch_response, builds_service_pb2.BatchResponse)
    ret_code = int(any(r.HasField('error') for r in batch_response.responses))
    jsonish = json_format.MessageToDict(batch_response)
    return self.step_data(
        step_name, self.m.json.output_stream(jsonish, retcode=ret_code)) 
開發者ID:luci,項目名稱:recipes-py,代碼行數:12,代碼來源:test_api.py

示例14: luci_context

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def luci_context(self, **section_pb_values):
    """Sets the LUCI_CONTEXT for this test case.

    Args:
      * section_pb_values(Dict[str, message.Message]): A mapping of section_key
      to the proto value for that section.
    """
    ret = self.test(None)
    for section_key, pb_val in iteritems(section_pb_values):
      if not isinstance(pb_val, message.Message): # pragma: no cover
          raise ValueError(
              'Expected section value in LUCI_CONTEXT to be proto message;'
              'Got: %r=%r (type %r)' % (section_key, pb_val, type(pb_val)))
      ret.luci_context[section_key] = jsonpb.MessageToDict(pb_val)
    return ret 
開發者ID:luci,項目名稱:recipes-py,代碼行數:17,代碼來源:test_api.py

示例15: serialize

# 需要導入模塊: from google.protobuf import json_format [as 別名]
# 或者: from google.protobuf.json_format import MessageToDict [as 別名]
def serialize(inv_bundle, pretty=False):
  """Serializes invocations to a string.

  The format corresponds to the format used by rdb-ls, unless pretty is True.

  Args:
    inv_bundle: dict {inv_id: Invocation}.
    pretty: if True, returns a better-looking output, but not supported by
      deserialize().
  """
  lines = []

  def add_line(inv_id, key, msg):
    jsonish = {
      'invocationId': inv_id,
      key: json_format.MessageToDict(msg),
    }
    lines.append(
        json.dumps(jsonish, sort_keys=True, indent=2 if pretty else None)
    )

  for inv_id, inv in inv_bundle.iteritems():
    assert isinstance(inv, Invocation), inv
    if inv.proto.ListFields():  # if something is set
      add_line(inv_id, 'invocation', inv.proto)

    for attr_name, typ, key in Invocation._COLLECTIONS:
      for msg in getattr(inv, attr_name):
        assert isinstance(msg, typ), msg
        add_line(inv_id, key, msg)

  return '\n'.join(lines) 
開發者ID:luci,項目名稱:recipes-py,代碼行數:34,代碼來源:common.py


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