Pb协议的接口测试

Protocol Buffers 是谷歌开源的序列化与反序列化框架。它与语言无关、平台无关、具有可扩展的机制。用于序列化结构化数据,此工具对标 XML ,支持自动编码,解码。比 XML 性能好,且数据易于解析。更多有关工具的介绍可参考官网。

Protocol Buffers官网:https://developers.google.com/protocol-buffers 1

Protocol Buffers 为跨平台设计,以 Python 为例,使用者配置 .proto 文件,利用 Protocol Buffers 工具即可生成 Python 代码,此代码就是使用者想要的数据结构。


如果编程语言换成了 Java ,使用者可使用相同的 .proto 文件,利用 Protocol Buffers 工具生成 Java 代码,此代码可被 Java 进行解析。


这么做的好处是可以跨语言交流,试想 Java 与 Python 间的数据通信,只需要利用 .proto 确定格式,就可随心编程,这个过程惬意无比。基于 Protocol Buffers 的测试也无比舒服。

1080×303 63.9 KB


你可选择自己的语言进行测试,比如 Python 。由于数据格式基于 .proto 配置文件,获取到这个文件即可生成数据类,比如下述 .proto 内容通过 protoc --python_out=./ ./addressbook.proto 命令即可生成 addressbook_pb2.py 文件:

syntax = "proto2";

package tutorial;

message Person {
  optional string name = 1;
  optional int32 id = 2;
  optional string email = 3;

  enum PhoneType {
    MOBILE = 0;
    HOME = 1;
    WORK = 2;
  }

  message PhoneNumber {
    optional string number = 1;
    optional PhoneType type = 2 [default = HOME];
  }

  repeated PhoneNumber phones = 4;
}

message AddressBook {
  repeated Person people = 1;
}

测试人员的代码只需导入 addressbook_pb2 ,对其初始化后即可使用,比如对 Person 的字段加入一些测试值:

import addressbook_pb2
person = addressbook_pb2.Person()
person.id = 1234
person.name = "John Doe"
person.email = "jdoe@example.com"
phone = person.phones.add()
phone.number = "555-4321"
phone.type = addressbook_pb2.Person.HOME

最后,将 person 序列化后即可传输到被测对象。如果你的业务采用文件进行数据传输,可参考官方写文件的例子(采用 python2 ):

#! /usr/bin/python

import addressbook_pb2
import sys

# This function fills in a Person message based on user input.
def PromptForAddress(person):
  person.id = int(raw_input("Enter person ID number: "))
  person.name = raw_input("Enter name: ")

  email = raw_input("Enter email address (blank for none): ")
  if email != "":
    person.email = email

  while True:
    number = raw_input("Enter a phone number (or leave blank to finish): ")
    if number == "":
      break

    phone_number = person.phones.add()
    phone_number.number = number

    type = raw_input("Is this a mobile, home, or work phone? ")
    if type == "mobile":
      phone_number.type = addressbook_pb2.Person.PhoneType.MOBILE
    elif type == "home":
      phone_number.type = addressbook_pb2.Person.PhoneType.HOME
    elif type == "work":
      phone_number.type = addressbook_pb2.Person.PhoneType.WORK
    else:
      print "Unknown phone type; leaving as default value."

# Main procedure:  Reads the entire address book from a file,
#   adds one person based on user input, then writes it back out to the same
#   file.
if len(sys.argv) != 2:
  print "Usage:", sys.argv[0], "ADDRESS_BOOK_FILE"
  sys.exit(-1)

address_book = addressbook_pb2.AddressBook()

# Read the existing address book.
try:
  f = open(sys.argv[1], "rb")
  address_book.ParseFromString(f.read())
  f.close()
except IOError:
  print sys.argv[1] + ": Could not open file.  Creating a new one."

# Add an address.
PromptForAddress(address_book.people.add())

# Write the new address book back to disk.
f = open(sys.argv[1], "wb")
f.write(address_book.SerializeToString())
f.close()

也可从被测对象传来的文件中读数据:

#! /usr/bin/python

import addressbook_pb2
import sys

# Iterates though all people in the AddressBook and prints info about them.
def ListPeople(address_book):
  for person in address_book.people:
    print "Person ID:", person.id
    print "  Name:", person.name
    if person.HasField('email'):
      print "  E-mail address:", person.email

    for phone_number in person.phones:
      if phone_number.type == addressbook_pb2.Person.PhoneType.MOBILE:
        print "  Mobile phone #: ",
      elif phone_number.type == addressbook_pb2.Person.PhoneType.HOME:
        print "  Home phone #: ",
      elif phone_number.type == addressbook_pb2.Person.PhoneType.WORK:
        print "  Work phone #: ",
      print phone_number.number

# Main procedure:  Reads the entire address book from a file and prints all
#   the information inside.
if len(sys.argv) != 2:
  print "Usage:", sys.argv[0], "ADDRESS_BOOK_FILE"
  sys.exit(-1)

address_book = addressbook_pb2.AddressBook()

# Read the existing address book.
f = open(sys.argv[1], "rb")
address_book.ParseFromString(f.read())
f.close()

ListPeople(address_book)

如果数据通过 https 传输,可采用 requests ,其它传输方式同理,请自行查阅数据传输工具。如果测试人员代码与被测对象建立了联系,即可收发测试数据,测试人员对接收到的数据编写测试用例即可。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你! 

  • 7
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PB375 U盘读写汇编程序 性价比超高的U盘读写模块-PB375,兼容CH375读写操作 1. 功能 ● 用于嵌入式系统/单片机读写U 盘、闪盘、闪存盘、USB 移动硬盘、USB 读卡器等。 ● 支持符合USB 相关规范基于Bulk-Only 传输协议的各种U 盘/闪存盘/外置硬盘。 ● 支持文件系统FAT12 和FAT16 及FAT32 ● 文件操作功能:新建、删除、读写数据,打开关闭文件等。 ● SPI接口,支持3.3V电平 ● 兼容CH375模块的操作命令 ● 单芯片解决方案,该模块只需要一个主控芯片外加少量的电容电阻便可,相对于51MCU+SL811/CH375的模块,无论模块尺寸还是成本都有着极大的优势。 ● 可以是模块提供,也可以是芯片提供(只需要简单的几个外围元件就可以了) 具体参数可以下载数据手册或者联系销售人员 基本不需要占用单片机系统的存储空间,最少只需要几个字节的RAM 和几百字节的代码。 下面就是一个很通用的台湾的单片机(可以是holtek 松翰 义隆 富晶等)用汇编操作PB375实现读写操作U盘的代码: USB_FAIL EQU 0AAH USB_SUCC EQU 055H TRY_TIMES EQU 0FFH CMD_DiskReady EQU 071H CMD_FileCreate EQU 065H CMD_ByteWrite equ 07Ch CMD_FileClose equ 067h //设置SPI 端口的输入输出 spi_ini: nop call i2c_delay b0bset spi_sdo_mod b0bset spi_sck_mod b0bset spi_cs_mod b0bclr spi_sdi_mod b0bset spi_cs ;not chose b0bset spi_sck b0bclr spi_sdo b0bclr spi_sdi ret /************************ SPI发一个字节,同时读一个字节 *************************/ spi_send: nop clr epr_num clr spi_in b0bclr spi_sck spi_write_bit: b0bts0 epr_data_b jmp spi_write_h b0bclr spi_sdo jmp spi_read_com spi_write_h: b0bset spi_sdo spi_read_com: call i2c_delay b0bclr fc rlcm spi_in b0bts0 spi_sdi incms spi_in b0bclr fc b0bset spi_sck call i2c_delay b0bclr spi_sck ;sck=0,data variable call i2c_delay rlcm epr_data ;prepare for next incms epr_num nop b0bts1 epr_num_b jmp spi_write_bit call i2c_delay ret //发送命令 spi_send_command: b0bclr spi_cs b0mov rbank,#1 ; 写入命令码 mov a,cmd b0mov rbank,#0 b0mov epr_data,a call spi_send b0mov rbank,#1 ;写入后续参数的长度 mov a,len b0mov rbank,#0 b0mov epr_data,a call spi_send b0mov rbank,#1 ;写入后续参数 mov a,len b0mov rbank,#0 b0bts0 FZ jmp send_len_over ;len=0 b0mov temp,a b0mov Y,#1 b0mov Z,#sendbuf send_len_byte: b0mov a,@YZ b0mov rbank,#0 b0mov epr_data,a call spi_send b0mov rbank,#0 incms Z nop decms temp jmp send_len_byte send_len_over: b0bset spi_cs call i2c_delay ;check the status mov a,#TRY_TIMES b0mov rbank,#1 mov trytime,a check_status: b0mov rbank,#0 b0bclr spi_cs mov a,#0ffh b0mov epr_data,a call spi_send b0bset spi_cs call i2c_delay b0mov a,spi_in sub a,#0ffh b0bts0 FZ jmp wait_1ms ;模块操作尚未完成 b0mov a,spi_in sub a,#00h b0bts0 FZ jmp succ_quit_00 ;操作成功 fail_quit: b0bset spi_cs mov a,#USB_FAIL b0mov rbank,#1 mov usb_reslt,a b0mov rbank,#0 ret wait_1ms: //延时 b0mov z,#0f7h b0mov y,#0e3h ;稳定oscillator,40ms delay_ms_02: b0bset fwdrst nop nop incms z jmp delay_ms_02 nop incms y jmp delay_ms_02 b0mov rbank,#1 decms trytime jmp check_status jmp fail_quit succ_quit_00: b0mov rbank,#0 b0bclr spi_cs mov a,#00h b0mov epr_data,a call spi_send b0mov a,spi_in b0bts0 FZ jmp succ_quit b0mov temp,a b0mov Y,#1 b0mov Z,#recvbuf read_len_byte: mov a,#0 b0mov rbank,#0 b0mov epr_data,a call spi_send b0mov a,spi_in b0mov @YZ,a b0mov rbank,#0 incms Z nop decms temp jmp read_len_byte succ_quit: b0bset spi_cs mov a,#USB_succ b0mov rbank,#1 mov usb_reslt,a b0mov rbank,#0 ret testusb://测试主程序 call spi_ini //初始化spi b0mov rbank,#1 //发送U盘是否连接好命令 mov a,#CMD_DiskReady mov cmd,a mov a,#0 mov len,a b0mov rbank,#0 call spi_send_command b0mov rbank,#1 mov a,usb_reslt b0mov rbank,#0 sub a,#USB_succ b0bts1 FZ ret ;ok diskread ;sendbuf is 92+”TEST.DAT” //创建文件”TEST.DAT” b0mov rbank,#0 b0mov Y,#1 b0mov Z,#sendbuf mov a,#92 b0mov @yz,a incms Z mov a,#116 b0mov @yz,a incms Z mov a,#101 b0mov @yz,a incms Z mov a,#115 b0mov @yz,a incms Z mov a,#116 b0mov @yz,a incms Z mov a,#46 b0mov @yz,a incms Z mov a,#100 b0mov @yz,a incms Z mov a,#97 b0mov @yz,a incms Z mov a,#116 b0mov @yz,a incms Z b0mov rbank,#1 mov a,#CMD_FileCreate //创建文件命令 mov cmd,a mov a,#10 mov len,a b0mov rbank,#0 call spi_send_command b0mov rbank,#1 mov a,usb_reslt b0mov rbank,#0 sub a,#USB_succ b0bts1 FZ ret b0mov rbank,#0 b0mov Y,#1 b0mov Z,#sendbuf mov a,#19 b0mov @yz,a incms Z mov a,#33 b0mov @yz,a incms Z mov a,#34 b0mov @yz,a incms Z mov a,#35 b0mov @yz,a incms Z mov a,#36 b0mov @yz,a incms Z mov a,#37 b0mov @yz,a incms Z mov a,#38 b0mov @yz,a incms Z mov a,#39 b0mov @yz,a incms Z mov a,#40 b0mov @yz,a incms Z mov a,#41 b0mov @yz,a b0mov rbank,#1 mov a,#CMD_ByteWrite //写入数据 mov cmd,a mov a,#10 mov len,a b0mov rbank,#0 call spi_send_command b0mov rbank,#1 mov a,#CMD_FileClose //关闭文件 mov cmd,a mov a,#1 mov len,a b0mov rbank,#0 call spi_send_command ret 欢迎垂询 电话:075529739852 地址:深圳市南山区高新中四道30号龙泰利大厦306 http://www.chinamcu.com

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值