IEC60870-5-104采用传输协议集的101网络访问通信协议测试

1 前言

IEC60870-5-104规定了采用标准传输协议子集的IEC60870-5-101网络访问。IEC60870-5-101基本远动任务通信规约提供了在主站和远动子站之间发送基本远动报文的通信文件集, 在主站和每个远动子站之间是采用固定连接的数据电路,用于厂站与调度主站间通讯。相关的国家标准有DL/T634.5104-2002通信协议。
本文将以DL/T634.5104-2002通信协议为基础,介绍如何使用格西烽火通信测试软件进行编写测试项目,进行测试符合DL/T634.5104-2002通信协议的设备。

2 通信协议

2.1 术语

信息对象组(group of information object)
一个信息对象的组是公共地址或信息地址一个集。

控制方向control direction
从控制站(主站)到被控站(子站)的传输方向。

监视方向monitoring direction
从被控站(子站)到控制站(主站)的传输方向。

2.2 通信接口

支持以太网接口,支持多点连接,支持TCP/IP协议,保留2404端口访问。

2.3 应用层

DL/T634.5104-2002通信协议定义了
应用规约数据单元:APDU(Application protocal data unit)
应用规约控制信息:APCI(Application protocal control information)
应用服务数据单元:ASDU(Application service data unit)
三个部分的关系为APDU=APCI + ASDU。

2.3.1 帧格式

帧是传送信息的基本单元。应用规约数据单元APDU格式如下图所示。

说明:
1)长度规范:报文最大长度255字节,应用规约数据单元的最大长度为253字节,控制域的长度是4字节,应用服务数据单元的最大长度为249字节。
2)控制域:控制域定义抗报文丢失和重复传送的控制信息、报文传输的启动和停止、传输连接的监视。控制域的这些类型被用于完成计数的信息传输的(I格式)、计数的监视功能(S格式)和不计数控制功能(U格式)。

2.3.2 控制域

控制域定义抗报文丢失和重复传送的控制信息、报文传输的启动和停止、传输连接的监视。控制域的这些类型被用于完成计数的信息传输的(I格式)、计数的监视功能(S格式)和不计数控制功能(U格式)。

2.3.3 应用服务数据单元ASDU

标准规定每一个应用规约数据单元(APDU)只有一个应用服务数据单元(ASDU)。应用服务数据单元由数据单元标识符和一个或多个信息体所组成。数据单元标识符在所有应用服务数据单元中常有相同的结构,一个应用服务数据单元中的信息体常有相同的结构和类型,它们由类型标识域所定义。
ASDU结构如下图所示。

ASDU类型标识1字节,在主站侧表示的是主站召唤的数据类型,在子站侧表示的是子站上传的信息元素的类型。
信息对象地址分配如下:

2.3.4 规约交互过程

当主站软件重新启动或链路故障时,主站将向子站发出建立链路的请求报文。当链路建立后,主站召唤一次全数据,随后定时召唤全数据,子站主动传送变化数据。主站收到数据帧后发送数据确认帧。

3 测试项目编制

3.1 基本协议编制

3.1.1 协议项分类

利用格西烽火软件的协议激励的功能,把DL/T634.5104-2002通信规约按照树形结构分类组织,使得管理上更加有条理,查找也更加方便。
首先,根据DL/T634.5104-2002通信协议的控制功能码,建立命令模版协议集,作为基本规约模版使用。
然后,根据ASDU类型标识编码表进行协议分类,建立基本命令集。一条命令由数条子命令构成,命令的执行是一个数个回合的交互过程。
按照树形结构分类组织的规约项目结构如图所示。

3.1.2 协议项编制

根据协议帧格式,为了方便控制和显示,把协议项的数据按照功能进行拆分。
例子1:命令模版的“对时”命令编制方法。

主站请求帧

从站应答帧

基本命令集的命令是由子命令构成的,子命令从命令模版中引用并作修改。

基本命令的“总召唤”命令编制方法。
首先,创建一个协议集,命名为“总召唤”;
其次,通过复制和粘贴功能,从命令模版中把对应命令复制到协议集“总召唤”中,实际运行测试用例,需要根据返回帧的数量调整接收数据的接收次数。

3.1.3 公共协议库

通过对基本协议项的编写、测试和验证,建立一个由基本协议项组成的公共协议库。

3.2 测试用例编制

测试用例(Test Case)是为某个特殊目标而编制的一组测试输入、执行条件以及预期结果,以便测试某个程序路径或核实是否满足某个特定需求。通信协议测试属于黑盒测试,可以采用黑盒测试常用的等价类划分法、边界值分析法、错误推测法、因果图法等基本方法来设计测试用例。

测试方案设计完成后,格西烽火软件能够利用编制完成的公共协议库,采用搭积木的方式,通过复制和粘贴命令即可非常快捷的创建测试用例。测试用例的组织方式通常是根据测试方案的设计层次采用树形结构分类组织。

4 测试方法

4.1 测试系统构成

4.2 单项测试与整体测试

格西烽火软件支持单项测试和整体测试,一次测试一个测试项或者整个测试集。执行的方法是选中需要测试的测试项或者测试集,然后执行激励命令即可。
下面以执行“总召唤”测试项为例说明。

协议数据解析界面

协议激励报告界面

4.3 单次测试与循环测试

格西烽火软件支持单次测试和循环测试,能很好满足各种调试测试和性能测试的需求。执行的方法是选中需要测试的测试项或者测试集,然后执行激励或循环激励命令即可。

4.4 脚本控制测试

格西烽火软件支持协议脚本,能够使用C#、VB、Jscript三种语言控制测试流程,设置和管理通信参数和协议帧数据,调用插件扩展测试功能。
协议脚本能够调用基于Microsoft .NET Framework的托管代码组件扩展测试功能,使用插件非常方便,只要把编译好的组件拷贝到Plugins目录中,就可以直接在脚本的函数中调用插件所提供的公共服务。
例如,使用例子插件ParallelPort,包含Geshe.Utils命名空间,即可直接使用ParallelPort.Read方法。


下载示例


BIGtheme.net Joomla 3.3 Templates