CN109254917A - 用于测试信息流系统的方法和装置 - Google Patents

用于测试信息流系统的方法和装置 Download PDF

Info

Publication number
CN109254917A
CN109254917A CN201811014620.5A CN201811014620A CN109254917A CN 109254917 A CN109254917 A CN 109254917A CN 201811014620 A CN201811014620 A CN 201811014620A CN 109254917 A CN109254917 A CN 109254917A
Authority
CN
China
Prior art keywords
information flow
flow system
test
data
information
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201811014620.5A
Other languages
English (en)
Other versions
CN109254917B (zh
Inventor
孙敬云
姚旭晨
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Baidu Netcom Science and Technology Co Ltd
Shanghai Xiaodu Technology Co Ltd
Original Assignee
Beijing Baidu Netcom Science and Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Beijing Baidu Netcom Science and Technology Co Ltd filed Critical Beijing Baidu Netcom Science and Technology Co Ltd
Priority to CN201811014620.5A priority Critical patent/CN109254917B/zh
Publication of CN109254917A publication Critical patent/CN109254917A/zh
Application granted granted Critical
Publication of CN109254917B publication Critical patent/CN109254917B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/3668Software testing
    • G06F11/3672Test management
    • G06F11/3688Test management for test execution, e.g. scheduling of test suites

Abstract

本申请实施例公开了用于测试信息流系统的方法和装置。该方法的一具体实施方式包括:接收终端发送的测试请求,其中,测试请求包括待测试信息流系统文件和测试数据集,其中,待测试信息流系统文件包括用于对信息流进行处理的信息流处理节点集合中的信息流处理节点的节点信息,测试数据包括关联存储的输入数据和输出数据;使用待测试信息流系统文件创建信息流系统实例;对于测试数据集中的测试数据,执行以下测试步骤:将该测试数据的输入数据输入信息流系统实例,得到针对该测试数据的测试输出数据;将得到的测试输出数据与该测试数据的输出数据进行对比,得到对比结果。该实施方式实现了对待测试信息流系统文件对应的待测试信息流系统的测试。

Description

用于测试信息流系统的方法和装置
技术领域
本申请实施例涉及计算机技术领域,具体涉及用于测试信息流系统的方法和装置。
背景技术
随着人工智能的发展,聊天机器人越来越受到关注。例如,可以通过智能在线客服机器人、手机助手等智能交互机器人为使用者提供服务。例如,使用者在聊天窗口输入信息之后,智能在线客服机器人会基于使用者的输入信息,按照一定的逻辑自动在聊天窗口给出相关的语句。又例如,手机助手可以基于使用者的语音信息为使用者提供服务。
实践中,针对每一种智能交互机器人都需要预先定义信息流系统来支撑使用者输入信息后给予正确的反馈。信息流系统定义完成之后,需要对信息流系统进行测试,以确保信息流系统被智能交互机器人使用后能够正常工作。
发明内容
本申请实施例提出了用于测试信息流系统的方法和装置。
第一方面,本申请实施例提供了一种用于测试信息流系统的方法,该方法包括:接收终端发送的测试请求,其中,上述测试请求包括待测试信息流系统文件和测试数据集,其中,上述待测试信息流系统文件包括用于对信息流进行处理的信息流处理节点集合中的信息流处理节点的节点信息,测试数据包括关联存储的输入数据和输出数据;使用上述待测试信息流系统文件创建信息流系统实例;对于上述测试数据集中的测试数据,执行以下测试步骤:将该测试数据的输入数据输入上述信息流系统实例,得到针对该测试数据的测试输出数据;将得到的测试输出数据与该测试数据的输出数据进行对比,得到对比结果。
在一些实施例中,上述测试数据集是通过以下方式得到的:获取预设时间段内、部署于生产环境中的线上信息流系统所产生的信息处理记录,其中,上述信息处理记录包括输入数据和上述线上信息流系统针对输入数据所输出的输出数据;将上述信息处理记录中的输入数据和对应的输出数据关联存储到测试数据集。
在一些实施例中,上述方法还包括:根据得到的对比结果,从上述测试数据集中选取出至少一个测试数据作为目标测试数据;根据得到的对比结果生成对比报告,并在上述对比报告中标识出上述目标测试数据;将上述对比报告发送给上述终端,以供上述终端进行显示。
在一些实施例中,上述待测试信息流系统文件是通过以下方式生成的:接收上述终端发送的信息流系统导出指令,其中,上述信息流系统导出指令包括信息流系统标识;将上述信息流系统标识对应的信息流系统的信息流处理节点的节点信息存储为目标信息流系统文件,以及将上述目标信息流系统文件发送给上述终端,以供上述终端将上述目标信息流系统文件作为待测试信息流系统文件发送测试请求。
在一些实施例中,上述方法还包括:响应于确定上述测试数据集中的测试数据被上述信息流系统实例处理完成,将上述信息流系统实例销毁。
第二方面,本申请实施例提供了一种用于测试信息流系统的装置,装置包括:接收单元,被配置成接收终端发送的测试请求,其中,上述测试请求包括待测试信息流系统文件和测试数据集,其中,上述待测试信息流系统文件包括用于对信息流进行处理的信息流处理节点集合中的信息流处理节点的节点信息,测试数据包括关联存储的输入数据和输出数据;创建单元,被配置成使用上述待测试信息流系统文件创建信息流系统实例;测试单元,被配置成对于上述测试数据集中的测试数据,执行以下测试步骤:将该测试数据的输入数据输入上述信息流系统实例,得到针对该测试数据的测试输出数据;将得到的测试输出数据与该测试数据的输出数据进行对比,得到对比结果。
在一些实施例中,上述测试数据集是通过以下方式得到的:获取预设时间段内、部署于生产环境中的线上信息流系统所产生的信息处理记录,其中,上述信息处理记录包括输入数据和上述线上信息流系统针对输入数据所输出的输出数据;将上述信息处理记录中的输入数据和对应的输出数据关联存储到测试数据集。
在一些实施例中,上述装置还包括:选取单元,被配置成根据得到的对比结果,从上述测试数据集中选取出至少一个测试数据作为目标测试数据;生成单元,被配置成根据得到的对比结果生成对比报告,并在上述对比报告中标识出上述目标测试数据;发送单元,被配置成将上述对比报告发送给上述终端,以供上述终端进行显示。
在一些实施例中,上述待测试信息流系统文件是通过以下方式生成的:接收上述终端发送的信息流系统导出指令,其中,上述信息流系统导出指令包括信息流系统标识;将上述信息流系统标识对应的信息流系统的信息流处理节点的节点信息存储为目标信息流系统文件,以及将上述目标信息流系统文件发送给上述终端,以供上述终端将上述目标信息流系统文件作为待测试信息流系统文件发送测试请求。
在一些实施例中,上述装置还包括:销毁单元,被配置成响应于确定上述测试数据集中的测试数据被上述信息流系统实例处理完成,将上述信息流系统实例销毁。
第三方面,本申请实施例提供了一种服务器,该服务器包括:一个或多个处理器;存储装置,其上存储有一个或多个程序,当上述一个或多个程序被上述一个或多个处理器执行时,使得上述一个或多个处理器实现如第一方面中任一实现方式描述的方法。
第四方面,本申请实施例提供了一种计算机可读介质,其上存储有计算机程序,其中,该计算机程序被处理器执行时实现如第一方面中任一实现方式描述的方法。
本申请实施例提供的用于测试信息流系统的方法和装置,首先接收终端发送的测试请求,而后使用待测试信息流系统文件创建信息流系统实例,然后,对于测试数据集中的测试数据,执行以下测试步骤:将该测试数据的输入数据输入信息流系统实例,得到针对该测试数据的测试输出数据,之后将得到的测试输出数据与该测试数据的输出数据进行对比,得到对比结果,从而实现了对待测试信息流系统文件对应的待测试信息流系统的测试。
附图说明
通过阅读参照以下附图所作的对非限制性实施例所作的详细描述,本申请的其它特征、目的和优点将会变得更明显:
图1是本申请的一个实施例可以应用于其中的示例性系统架构图;
图2是根据本申请的用于测试信息流系统的方法的一个实施例的流程图;
图3是待测试信息流系统的一个示例的结构示意图;
图4是根据本申请的用于测试信息流系统的方法的一个应用场景的示意图;
图5是根据本申请的生成测试数据集的方法的一个实施例的流程图;
图6是根据本申请的用于测试信息流系统的装置的一个实施例的结构示意图;
图7是适于用来实现本申请实施例的服务器的计算机系统的结构示意图。
具体实施方式
下面结合附图和实施例对本申请作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释相关发明,而非对该发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与有关发明相关的部分。
需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。下面将参考附图并结合实施例来详细说明本申请。
图1示出了可以应用本申请的用于测试信息流系统的方法或用于测试信息流系统的装置的实施例的示例性系统架构100。
如图1所示,系统架构100可以包括终端设备101、102、103,网络104和服务器105。网络104用以在终端设备101、102、103和服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备101、102、103通过网络104与服务器105交互,以接收或发送消息等。终端设备101、102、103上可以安装有各种客户端应用,例如网页浏览器应用、购物类应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等。
终端设备101、102、103可以是具有显示屏并且支持通过聊天机器人(chatbot)开发页面接收和发送信息的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。
服务器105可以是提供各种服务的服务器,例如对终端设备101、102、103上显示的聊天机器人(chatbot)开发页面提供支持的后台服务器。后台服务器可以接收用户通过聊天机器人(chatbot)开发页面发送的各种开发信息,并根据开发信息创建信息流系统,以及可以根据用户发送的测试请求对待测试信息流系统文件对应的待测试信息流系统进行测试。
需要说明的是,服务器105可以是硬件,也可以是软件。当服务器为硬件时,可以实现成多个服务器组成的分布式服务器集群,也可以实现成单个服务器。当服务器为软件时,可以实现成多个软件或软件模块(例如用来提供分布式服务),也可以实现成单个软件或软件模块。在此不做具体限定。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
需要说明的是,本申请实施例所提供的用于测试信息流系统的方法一般由服务器105执行,相应地,用于测试信息流系统的装置一般设置于服务器105中。
继续参考图2,示出了根据本申请的用于测试信息流系统的方法的一个实施例的流程200。该用于测试信息流系统的方法,包括以下步骤:
步骤201,接收终端发送的测试请求。
在本实施例中,用于测试信息流系统的方法的执行主体(例如图1所示的服务器105)可以通过有线连接方式或者无线连接方式从用户利用其进行聊天机器人(chatbot)开发平台访问的终端(例如图1所示的终端设备101、102、103)接收测试请求。在这里,测试请求可以包括待测试信息流系统文件和测试数据集。其中,待测试信息流系统文件可以包括用于对信息流进行处理的信息流处理节点集合中的每一个信息流处理节点的节点信息。作为示例,节点信息可以包括但不限于节点的标识、功能信息、位置信息、连接关系信息等等。测试数据集中的测试数据可以包括关联存储的输入数据和输出数据。
在这里,待测试信息流系统文件所对应的待测试信息流系统可以包括用于对信息流进行处理的信息流处理节点集合,信息流从信息流处理节点集合中的、作为入口的输入节点流入以及在流经信息流处理节点集合中的至少一个信息流处理节点之后流出待测试信息流系统。其中,信息流处理节点集合中的各个信息流处理节点之间可以存在连接关系,一个节点的输出可以作为下一个节点的输入。实践中,信息流处理节点可以是硬件,也可以是软件,此处不做限定。
举例来说,假设某一个待测试信息流系统(如图3所示)用于提供智能在线客服服务,则该待测试信息流系统可以包括用于接收客户输入信息的聊天输入(Chat in)节点。聊天输入(Chat in)节点对客户输入信息进行预定的处理之后可以将结果按照连接关系发送给自然语言理解(Natural Language Understanding,简称NLU)节点,NLU节点对输入的数据进行自然语言解析后,可以将解析结果发送给路由(router)节点。路由节点可以根据接收的解析结果以及预先设定的选取规则,从多个处理节点中选取一个处理节点,并将解析结果发送给所选取的处理节点。该处理节点对解析结果处理完成之后,可以将处理结果发送给状态(state)节点,由状态节点进行相应的处理之后将结果发送给路由节点,并最终由路由节点将处理结果(例如反馈信息)发送给聊天输出(Chat out)节点。需要说明的是,图3中虽然未示出路由节点与处理节点、状态节点之间的连线,但是路由节点与处理节点、状态节点之间存在连接关系。需要说明的是,本例中待测试信息流系统的节点数量以及各个节点所拥有的功能、使用方式等仅仅是示例性的,实践中,可以根据实际需要进行设定,此处不做限定。
作为示例,待测试信息流系统可以是使用终端的用户通过上述聊天机器人开发平台的可视化界面创建的。举例来说,聊天机器人开发平台可以为ChatFlow,ChatFlow是一个提供开发聊天机器人(chatbot)的各种模块(或节点)的软件平台,同时具有多轮对话追踪能力。用户通过终端设备登录ChatFlow之后可以在可视化开发界面上通过拖拽的方式自由地选择需要用到的模块,像画流程图一样将各个模块串好,辅以对应的代码,完成待测试信息流系统的创建。实践中,为了方便用户使用,聊天机器人开发平台可以支持用户将所创建的待测试信息流系统导出为待测试信息流系统文件。
在本实施例的一些可选的实现方式中,待测试信息流系统文件可以是通过以下步骤生成的:
首先,执行主体接收终端发送的信息流系统导出指令,其中,信息流系统导出指令可以包括信息流系统标识。
在这里,使用终端的用户通过上述聊天机器人开发平台的可视化界面创建了待测试信息流系统之后,可以针对待测试信息流系统向执行主体发送信息流系统导出指令,该信息流系统导出指令可以包括待测试信息流系统的信息流系统标识,信息流系统标识可以用于唯一标识一个信息流系统。实践中,执行主体可以在聊天机器人开发平台的可视化界面的预定区域中设置一个按钮,使用终端访问该可视化界面的用户可以通过点击该按钮向执行主体发送信息流系统导出指令。为了方便用户使用,可以设置该按钮的显示标签以提示用户点击该按钮所能实现的功能,例如,可以设置该按钮的标签为“导出信息流系统”。
然后,执行主体可以将信息流系统标识对应的信息流系统的信息流处理节点的节点信息存储为目标信息流系统文件,并将目标信息流系统文件发送给终端,以供终端将目标信息流系统文件作为待测试信息流系统文件发送测试请求。
在这里,执行主体可以将接收到的信息流系统标识对应的信息流系统的信息流处理节点的节点信息以特定格式存储为目标信息流系统文件。其中,特定格式可以是实际需要设定的,举例来说,特定格式可以是JSON(JavaScript Object Notation,JS对象简谱)数据格式,其中,JSON数据格式是一种轻量级的数据交换格式。执行主体还可以将目标信息流系统文件发送给终端,以供终端将目标信息流系统文件作为待测试信息流系统文件发送测试请求。
步骤202,使用待测试信息流系统文件创建信息流系统实例。
在本实施例中,执行主体可以使用步骤201中接收到的待测试信息流系统文件创建信息流系统实例。作为示例,信息流系统实例可以是ChatFlow通过多线程创建的一个子线程。实践中,该信息流系统实例可以接收访问,例如,接收访客发送的信息。每一次访问可以作为一个信息流输入到信息流系统实例,信息流系统实例对输入的信息流进行处理后,会针对输入的信息流生成输出信息,从而实现对访问的应答。
步骤203,对于测试数据集中的测试数据,执行主体可以执行以下测试步骤:
步骤2031,将该测试数据的输入数据输入信息流系统实例,得到针对该测试数据的测试输出数据。
在本实施例中,执行主体可以将该测试数据的输入数据输入信息流系统实例,信息流系统实例可以对输入的输入数据进行处理,从而得到针对该测试数据的输入数据的测试输出数据。
步骤2032,将得到的测试输出数据与该测试数据的输出数据进行对比,得到对比结果。
在本实施例中,执行主体可以将步骤2031中得到的测试输出数据与该测试数据的输出数据进行对比,得到对比结果。作为示例,对比结果可以包括以下结论:测试输出数据与该测试数据的输出数据相同,或测试输出数据与该测试数据的输出结果不同。
在本实施例的一些可选的实现方式中,上述用于测试信息流系统的方法还可以包括图2中未示出的以下内容:
步骤S1,根据得到的对比结果,从测试数据集中选取出至少一个测试数据作为目标测试数据。
在本实现方式中,执行主体可以根据步骤2032得到的对比结果,从测试数据集中选取出至少一个测试数据作为目标测试数据。作为一个示例,执行主体可以将对比结果为测试输出数据与该测试数据的输出结果不同的测试数据作为目标测试数据。
步骤S2,根据得到的对比结果生成对比报告,并在对比报告中标识出目标测试数据。
在本实现方式中,执行主体可以根据步骤2032得到的对比结果,生成对比结果报告。作为示例,该对比结果报告可以为一个表格,该表格中可以记载有测试数据集中的每个测试数据的输入数据、测试输出数据、输出数据以及得到的对比结果等等。执行主体还可以在对比报告中标识出目标测试数据,例如,执行主体可以设定使用不同的颜色标识出目标测试数据的测试输出数据、输出数据以及得到的对比结果等等。
步骤S3,将对比报告发送给终端,以供终端进行显示。
在本实现方式中,执行主体可以将步骤S2得到的对比报告发送给终端,以供终端进行显示。这样,使用终端的用户可以直观的看到根据待测试信息流系统文件创建的信息流系统实例输出的测试输出数据与测试数据的输出数据的差异。作为示例,该对比报告可以支持用户的搜索,例如,用户输入想要搜索的关键词之后,该对比报告中可以高亮显示搜索到的结果。
在本实施例的一些可选的实现方式中,上述用于测试信息流系统的方法还可以包括图2中未示出的以下内容:响应于确定测试数据集中的测试数据被信息流系统实例处理完成,将信息流系统实例销毁。
在本实现方式中,响应于确定测试数据集中的测试数据被信息流系统实例处理完成,即测试数据集中的全部测试数据的输入数据输入信息流信息实例并得到测试输出数据,执行主体可以将信息流系统实例销毁。需要明白的是,如何销毁实例是目前广为研究和应用的技术,此处不再赘述。
继续参见图4,图4是根据本实施例的用于测试信息流系统的方法的应用场景的一个示意图。在图4的应用场景中,服务器401接收终端402发送的测试请求,其中,测试请求包括待测试信息流系统文件和测试数据集,测试数据包括关联存储的输入数据A和输出数据A1。而后服务器401可以使用待测试信息流系统文件创建信息流系统实例,对于测试数据集中的每一个测试数据,服务器401可以执行以下测试步骤:首先,服务器401可以将该测试数据的输入数据A输入信息流系统实例,得到针对该测试数据的测试输出数据A2;之后,服务器401可以将得到的测试输出数据A2与该测试数据的输出数据A1进行对比,得到对比结果。
本申请的上述实施例提供的方法可以使用待测试信息流系统文件创建信息流系统实例,通过将测试数据的输入数据输入信息流系统实例可以得到测试输出数据,并将得到的测试输出数据与测试数据的输出数据进行对比,从而实现了对待测试信息流系统文件对应的待测试信息流系统的测试。
进一步参考图5,其示出了生成测试数据集的方法的一个实施例的流程500。该生成测试数据集的方法的流程500,包括以下步骤:
步骤501,获取预设时间段内、部署于生产环境中的线上信息流系统所产生的信息处理记录。
在本实施例中,生成测试数据集的方法的执行主体(例如图1所示的服务器105)可以获取预设时间段内、部署于生产环境中的线上信息流系统所产生的信息处理记录。其中,信息处理记录可以包括输入数据和线上信息流系统针对输入数据所输出的输出数据。在这里,预设时间段可以是根据实际需要设定的时间段。线上信息流系统可以是指部署于生产环境中的、提供对外服务的信息流系统。
实践中,信息流系统可以部署于生产环境中,生产环境可以是指信息流系统上线后正式使用的运营环境,是指正式提供对外服务的环境。信息流系统部署到生产环境之后,可以接收访问,每一次访问的数据可以作为输入数据输入到信息流系统,信息流系统对输入的信息流进行处理后,会针对输入的信息流生成输出数据,从而实现对访问的应答。
步骤502,将信息处理记录中的输入数据和对应的输出数据关联存储到测试数据集。
在本实施例中,执行主体可以将信息处理记录中的输入数据和对应的输出数据关联存储到测试数据集。执行主体还可以将测试数据集发送终端,以供终端向执行主体发送测试请求时使用。作为示例,执行主体可以将信息处理记录中的输入数据和对应的输出数据以特定格式存储。其中,特定格式可以是根据实际需要设定的,举例来说,特定格式可以是JSON数据格式。
本申请的上述实施例提供的生成测试数据集的方法可以基于线上信息流系统所产生的信息处理记录生成测试数据集,因此所生成的测试数据集中的数据更加真实、有效,使用该测试数据集对待测试信息流系统文件对应的待测试信息流系统进行测试,可以使测试更加准确。
进一步参考图6,作为对上述各图所示方法的实现,本申请提供了一种用于测试信息流系统的装置的一个实施例,该装置实施例与图2所示的方法实施例相对应,该装置具体可以应用于各种电子设备中。
如图6所示,本实施例的用于测试信息流系统的装置600包括:接收单元601、创建单元602和测试单元603。其中,接收单元601被配置成接收终端发送的测试请求,其中,上述测试请求包括待测试信息流系统文件和测试数据集,其中,上述待测试信息流系统文件包括用于对信息流进行处理的信息流处理节点集合中的信息流处理节点的节点信息,测试数据包括关联存储的输入数据和输出数据;创建单元602被配置成使用上述待测试信息流系统文件创建信息流系统实例;测试单元603被配置成对于上述测试数据集中的测试数据,执行以下测试步骤:将该测试数据的输入数据输入上述信息流系统实例,得到针对该测试数据的测试输出数据;将得到的测试输出数据与该测试数据的输出数据进行对比,得到对比结果。
在本实施例中,用于测试信息流系统的装置600的接收单元601、创建单元602和测试单元603的具体处理及其所带来的技术效果可分别参考图2对应实施例中步骤201、步骤202和步骤203的相关说明,在此不再赘述。
在本实施例的一些可选的实现方式中,上述测试数据集可以是通过以下方式得到的:获取预设时间段内、部署于生产环境中的线上信息流系统所产生的信息处理记录,其中,上述信息处理记录包括输入数据和上述线上信息流系统针对输入数据所输出的输出数据;将上述信息处理记录中的输入数据和对应的输出数据关联存储到测试数据集。
在本实施例的一些可选的实现方式中,上述装置600还可以包括:选取单元(图中未示出),被配置成根据得到的对比结果,从上述测试数据集中选取出至少一个测试数据作为目标测试数据;生成单元(图中未示出),被配置成根据得到的对比结果生成对比报告,并在上述对比报告中标识出上述目标测试数据;发送单元(图中未示出),被配置成将上述对比报告发送给上述终端,以供上述终端进行显示。
在本实施例的一些可选的实现方式中,上述待测试信息流系统文件可以是通过以下方式生成的:接收上述终端发送的信息流系统导出指令,其中,上述信息流系统导出指令包括信息流系统标识;将上述信息流系统标识对应的信息流系统的信息流处理节点的节点信息存储为目标信息流系统文件,以及将上述目标信息流系统文件发送给上述终端,以供上述终端将上述目标信息流系统文件作为待测试信息流系统文件发送测试请求。
在本实施例的一些可选的实现方式中,上述装置600还可以包括:销毁单元(图中未示出),被配置成响应于确定上述测试数据集中的测试数据被上述信息流系统实例处理完成,将上述信息流系统实例销毁。
下面参考图7,其示出了适于用来实现本申请实施例的服务器的计算机系统700的结构示意图。图7示出的服务器仅仅是一个示例,不应对本申请实施例的功能和使用范围带来任何限制。
如图7所示,计算机系统700包括中央处理单元(CPU,Central Processing Unit)701,其可以根据存储在只读存储器(ROM,Read Only Memory)702中的程序或者从存储部分706加载到随机访问存储器(RAM,Random Access Memory)703中的程序而执行各种适当的动作和处理。在RAM 703中,还存储有系统700操作所需的各种程序和数据。CPU 701、ROM702以及RAM 703通过总线704彼此相连。输入/输出(I/O,Input/Output)接口705也连接至总线704。
以下部件连接至I/O接口705:包括硬盘等的存储部分706;以及包括诸如LAN(局域网,Local Area Network)卡、调制解调器等的网络接口卡的通信部分707。通信部分707经由诸如因特网的网络执行通信处理。驱动器708也根据需要连接至I/O接口705。可拆卸介质709,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器708上,以便于从其上读出的计算机程序根据需要被安装入存储部分706。
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分707从网络上被下载和安装,和/或从可拆卸介质709被安装。在该计算机程序被中央处理单元(CPU)701执行时,执行本申请的方法中限定的上述功能。
需要说明的是,本申请所述的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本申请中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本申请中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言或其组合来编写用于执行本申请的操作的计算机程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
附图中的流程图和框图,图示了按照本申请各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本申请实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的单元也可以设置在处理器中,例如,可以描述为:一种处理器包括接收单元、创建单元和测试单元。其中,这些单元的名称在某种情况下并不构成对该单元本身的限定,例如,接收单元还可以被描述为“接收终端发送的测试请求的单元”。
作为另一方面,本申请还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的装置中所包含的;也可以是单独存在,而未装配入该装置中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该装置执行时,使得该装置:接收终端发送的测试请求,其中,上述测试请求包括待测试信息流系统文件和测试数据集,其中,上述待测试信息流系统文件包括用于对信息流进行处理的信息流处理节点集合中的信息流处理节点的节点信息,测试数据包括关联存储的输入数据和输出数据;使用上述待测试信息流系统文件创建信息流系统实例;对于上述测试数据集中的测试数据,执行以下测试步骤:将该测试数据的输入数据输入上述信息流系统实例,得到针对该测试数据的测试输出数据;将得到的测试输出数据与该测试数据的输出数据进行对比,得到对比结果。
以上描述仅为本申请的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本申请中所涉及的发明范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述发明构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本申请中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。

Claims (12)

1.一种用于测试信息流系统的方法,包括:
接收终端发送的测试请求,其中,所述测试请求包括待测试信息流系统文件和测试数据集,其中,所述待测试信息流系统文件包括用于对信息流进行处理的信息流处理节点集合中的信息流处理节点的节点信息,测试数据包括关联存储的输入数据和输出数据;
使用所述待测试信息流系统文件创建信息流系统实例;
对于所述测试数据集中的测试数据,执行以下测试步骤:将该测试数据的输入数据输入所述信息流系统实例,得到针对该测试数据的测试输出数据;将得到的测试输出数据与该测试数据的输出数据进行对比,得到对比结果。
2.根据权利要求1所述的方法,其中,所述测试数据集是通过以下方式得到的:
获取预设时间段内、部署于生产环境中的线上信息流系统所产生的信息处理记录,其中,所述信息处理记录包括输入数据和所述线上信息流系统针对输入数据所输出的输出数据;
将所述信息处理记录中的输入数据和对应的输出数据关联存储到测试数据集。
3.根据权利要求1所述的方法,其中,所述方法还包括:
根据得到的对比结果,从所述测试数据集中选取出至少一个测试数据作为目标测试数据;
根据得到的对比结果生成对比报告,并在所述对比报告中标识出所述目标测试数据;
将所述对比报告发送给所述终端,以供所述终端进行显示。
4.根据权利要求1所述的方法,其中,所述待测试信息流系统文件是通过以下方式生成的:
接收所述终端发送的信息流系统导出指令,其中,所述信息流系统导出指令包括信息流系统标识;
将所述信息流系统标识对应的信息流系统的信息流处理节点的节点信息存储为目标信息流系统文件,以及将所述目标信息流系统文件发送给所述终端,以供所述终端将所述目标信息流系统文件作为待测试信息流系统文件发送测试请求。
5.根据权利要求1所述的方法,其中,所述方法还包括:
响应于确定所述测试数据集中的测试数据被所述信息流系统实例处理完成,将所述信息流系统实例销毁。
6.一种用于测试信息流系统的装置,包括:
接收单元,被配置成接收终端发送的测试请求,其中,所述测试请求包括待测试信息流系统文件和测试数据集,其中,所述待测试信息流系统文件包括用于对信息流进行处理的信息流处理节点集合中的信息流处理节点的节点信息,测试数据包括关联存储的输入数据和输出数据;
创建单元,被配置成使用所述待测试信息流系统文件创建信息流系统实例;
测试单元,被配置成对于所述测试数据集中的测试数据,执行以下测试步骤:将该测试数据的输入数据输入所述信息流系统实例,得到针对该测试数据的测试输出数据;将得到的测试输出数据与该测试数据的输出数据进行对比,得到对比结果。
7.根据权利要求6所述的装置,其中,所述测试数据集是通过以下方式得到的:
获取预设时间段内、部署于生产环境中的线上信息流系统所产生的信息处理记录,其中,所述信息处理记录包括输入数据和所述线上信息流系统针对输入数据所输出的输出数据;
将所述信息处理记录中的输入数据和对应的输出数据关联存储到测试数据集。
8.根据权利要求6所述的装置,其中,所述装置还包括:
选取单元,被配置成根据得到的对比结果,从所述测试数据集中选取出至少一个测试数据作为目标测试数据;
生成单元,被配置成根据得到的对比结果生成对比报告,并在所述对比报告中标识出所述目标测试数据;
发送单元,被配置成将所述对比报告发送给所述终端,以供所述终端进行显示。
9.根据权利要求6所述的装置,其中,所述待测试信息流系统文件是通过以下方式生成的:
接收所述终端发送的信息流系统导出指令,其中,所述信息流系统导出指令包括信息流系统标识;
将所述信息流系统标识对应的信息流系统的信息流处理节点的节点信息存储为目标信息流系统文件,以及将所述目标信息流系统文件发送给所述终端,以供所述终端将所述目标信息流系统文件作为待测试信息流系统文件发送测试请求。
10.根据权利要求6所述的装置,其中,所述装置还包括:
销毁单元,被配置成响应于确定所述测试数据集中的测试数据被所述信息流系统实例处理完成,将所述信息流系统实例销毁。
11.一种服务器,包括:
一个或多个处理器;
存储装置,其上存储有一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-5中任一所述的方法。
12.一种计算机可读介质,其上存储有计算机程序,其中,所述程序被处理器执行时实现如权利要求1-5中任一所述的方法。
CN201811014620.5A 2018-08-31 2018-08-31 用于测试信息流系统的方法和装置 Active CN109254917B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811014620.5A CN109254917B (zh) 2018-08-31 2018-08-31 用于测试信息流系统的方法和装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811014620.5A CN109254917B (zh) 2018-08-31 2018-08-31 用于测试信息流系统的方法和装置

Publications (2)

Publication Number Publication Date
CN109254917A true CN109254917A (zh) 2019-01-22
CN109254917B CN109254917B (zh) 2019-11-29

Family

ID=65049948

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811014620.5A Active CN109254917B (zh) 2018-08-31 2018-08-31 用于测试信息流系统的方法和装置

Country Status (1)

Country Link
CN (1) CN109254917B (zh)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109815154A (zh) * 2019-02-22 2019-05-28 深圳市网心科技有限公司 一种测试方法、装置、系统及介质
CN110928788A (zh) * 2019-11-22 2020-03-27 泰康保险集团股份有限公司 服务验证方法及设备
CN112765039A (zh) * 2021-02-03 2021-05-07 上海复深蓝软件股份有限公司 测试数据消费染色方法、装置、计算机设备及存储介质
CN112799907A (zh) * 2021-01-21 2021-05-14 安徽心驰信息科技有限公司 一种信息系统测试维护方法
CN113360365A (zh) * 2020-03-03 2021-09-07 北京同邦卓益科技有限公司 一种流程测试方法和流程测试系统

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110181309A1 (en) * 2010-01-26 2011-07-28 Advantest Corporation Test apparatus and test module
CN103810085A (zh) * 2012-11-08 2014-05-21 百度在线网络技术(北京)有限公司 一种通过数据比对进行模块测试的方法及装置
CN106326114A (zh) * 2016-08-16 2017-01-11 北京控制工程研究所 一种近自然语言测试用例脚本的航天软件自动测试方法
CN106959683A (zh) * 2017-03-27 2017-07-18 傅朝阳 分布式机器人系统的灰盒自主测试方法及系统

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110181309A1 (en) * 2010-01-26 2011-07-28 Advantest Corporation Test apparatus and test module
CN103810085A (zh) * 2012-11-08 2014-05-21 百度在线网络技术(北京)有限公司 一种通过数据比对进行模块测试的方法及装置
CN106326114A (zh) * 2016-08-16 2017-01-11 北京控制工程研究所 一种近自然语言测试用例脚本的航天软件自动测试方法
CN106959683A (zh) * 2017-03-27 2017-07-18 傅朝阳 分布式机器人系统的灰盒自主测试方法及系统

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109815154A (zh) * 2019-02-22 2019-05-28 深圳市网心科技有限公司 一种测试方法、装置、系统及介质
CN110928788A (zh) * 2019-11-22 2020-03-27 泰康保险集团股份有限公司 服务验证方法及设备
CN110928788B (zh) * 2019-11-22 2023-09-19 泰康保险集团股份有限公司 服务验证方法及设备
CN113360365A (zh) * 2020-03-03 2021-09-07 北京同邦卓益科技有限公司 一种流程测试方法和流程测试系统
CN113360365B (zh) * 2020-03-03 2024-04-05 北京同邦卓益科技有限公司 一种流程测试方法和流程测试系统
CN112799907A (zh) * 2021-01-21 2021-05-14 安徽心驰信息科技有限公司 一种信息系统测试维护方法
CN112765039A (zh) * 2021-02-03 2021-05-07 上海复深蓝软件股份有限公司 测试数据消费染色方法、装置、计算机设备及存储介质
CN112765039B (zh) * 2021-02-03 2022-05-06 上海复深蓝软件股份有限公司 测试数据消费染色方法、装置、计算机设备及存储介质

Also Published As

Publication number Publication date
CN109254917B (zh) 2019-11-29

Similar Documents

Publication Publication Date Title
CN109254917B (zh) 用于测试信息流系统的方法和装置
CN108153901A (zh) 基于知识图谱的信息推送方法和装置
CN103927321B (zh) 使用众包改进情感分析的方法和系统
CN108459953A (zh) 测试方法和装置
CN109213486A (zh) 用于生成用户定制的可视化组件的方法和装置
CN109241141A (zh) 深度学习的训练数据处理方法和装置
CN109992498A (zh) 测试用例的生成方法及系统、计算机系统
CN109117378B (zh) 用于显示信息的方法和装置
CN108510081A (zh) 机器学习方法和平台
WO2020143557A1 (zh) 用于显示信息的方法和装置
CN108121800A (zh) 基于人工智能的信息生成方法和装置
CN108197036A (zh) 用于确定增量代码的覆盖率信息的方法和装置
CN109190114A (zh) 用于生成回复信息的方法和装置
CN109901987B (zh) 一种生成测试数据的方法和装置
CN109934242A (zh) 图片识别方法和装置
CN109783197A (zh) 用于程序运行时环境的调度方法和装置
CN109271556A (zh) 用于输出信息的方法和装置
CN109976995A (zh) 用于测试的方法和装置
CN110543297A (zh) 用于生成源码的方法和装置
CN109284342A (zh) 用于输出信息的方法和装置
US20190266183A1 (en) Unbounded list processing
CN109376534A (zh) 用于检测应用的方法和装置
CN109543068A (zh) 用于生成视频的评论信息的方法和装置
CN109614327A (zh) 用于输出信息的方法和装置
CN110083351A (zh) 用于生成代码的方法和装置

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant
TR01 Transfer of patent right
TR01 Transfer of patent right

Effective date of registration: 20210510

Address after: 100085 Baidu Building, 10 Shangdi Tenth Street, Haidian District, Beijing

Patentee after: BEIJING BAIDU NETCOM SCIENCE AND TECHNOLOGY Co.,Ltd.

Patentee after: Shanghai Xiaodu Technology Co.,Ltd.

Address before: 100085 Baidu Building, 10 Shangdi Tenth Street, Haidian District, Beijing

Patentee before: BEIJING BAIDU NETCOM SCIENCE AND TECHNOLOGY Co.,Ltd.