我们正在为Apache Beam管道构建集成测试,并且遇到了一些问题.有关背景信息,请参见

有关我们管道的详情:

>我们使用PubsubIO作为我们的数据源(无界PCollection)
>中间变换包括自定义CombineFn和非常简单的窗口/触发策略
>我们的最终转换是JdbcIO,使用org.neo4j.jdbc.Driver写入Neo4j

目前的测试方法:

>在运行测试的计算机上运行Google Cloud的发布/订阅模拟器
>构建内存中的Neo4j数据库,并将其URI传递给我们的管道选项
>通过调用OurPipeline.main运行管道(TestPipeline.convertToArgs(options)
>使用Google Cloud的Java Pub / Sub客户端库将消息发布到测试主题(使用Pub / Sub仿真器),PubsubIO将从中读取
>数据应该流经管道并最终命中我们的Neo4j内存实例
>在Neo4j中对这些数据的存在做出简单的断言

这是一个简单的集成测试,它将验证我们的整个管道是否按预期运行.

我们目前面临的问题是,当我们运行我们的管道时,它会阻塞.我们正在使用DirectRunner和pipeline.run()(而不是pipeline.run().waitUntilFinish()),但测试似乎在运行管道后挂起.因为这是一个无限制的PCollection(以流模式运行),所以管道不会终止,因此不会到达任何代码.

所以,我有几个问题:

1)有没有办法运行管道然后稍后手动停止?

2)有没有办法异步运行管道?理想情况下,它会启动管道(然后将继续轮询Pub / Sub以获取数据),然后转到负责发布到Pub / Sub的代码.

3)这种集成测试方法是否合理,或者是否有更好的方法可能更直接?这里的任何信息/指导将不胜感激.

如果我能提供任何额外的代码/背景,请告诉我 – 谢谢!

解决方法

您可以通过将isBlockOnRun管道选项设置为false来使用DirectRunner异步运行管道.只要保留对可用返回的PipelineResult的引用,对该结果调用cancel()就应该停止管道.

对于第三个问题,您的设置似乎合理.但是,如果您希望对管道进行较小规模的测试(需要较少的组件),则可以将所有处理逻辑封装在自定义PTransform中.此PTransform应采用已从输入源完全解析的输入,并生成尚未为输出接收器解析的输出.

当做到这一点,您可以使用创建(这一般不会行使触发)或TestStream(这可能,这取决于你如何构建TestStream)与DirectRunner产生输入数据的有限的量,将此处理PTransform到PCollection,并在输出PCollection上使用PAssert来验证管道是否生成了您期望的输出.

有关测试的更多信息,B​​eam网站在Programming Guide和blog post中提供了有关使用TestStream测试管道的这些测试样式的信息.

java – Apache Beam – 无界PCollection的集成测试的更多相关文章

  1. 浅谈如何提高PHP代码质量之端到端集成测试

    在本系列的前几部分中,我们建立了一个构建工具,一些静态代码分析器,并开始编写单元测试。为了使我们的测试堆栈更完整,有一些测试可以检查你的代码是否在真实环境中运行,以及它是否能在更复杂的业务场景中运行良好。

  2. 详解Yaf框架PHPUnit集成测试方法

    这篇文章主要介绍了详解Yaf框架PHPUnit集成测试方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  3. 集成测试PHPUnit和Phinx

    我正在创建一个PHPRESTapi,使用PHPUnit进行单元测试和集成测试.我希望将phinx集成到数据库迁移.我实际上有两个问题:>我如何使用phinx进行数据库设置?phinx通常用作命令行工具,但我需要一些方法来调用我的单元测试类中的setup方法.>我将如何进行集成测试我编写的迁移类?我想要一些验证,在每次迁移步骤之后,我的数据库处于某种预期状态这是一个解决方案.简短又甜蜜.

  4. 如何在PHP中执行集成测试?

    我正在对我的代码执行单元测试,但是我已经阅读了很多有关集成测试的内容.>在PHP中是否有任何工具来执行?有什么好的教程吗地方?

  5. java – 在每次单元测试后创建一个bean的新实例

    我是spring框架的新手,并且使用SpringContext对其依赖注入功能有疑问.这是我正在尝试编写集成测试的类:在我的测试中我想确保调用这四个项目,所以我创建了如下测试:然而,所有测试都失败了,说我多次调用该方法.我唯一的猜测是UserServicebean在所有测试开始时创建一次,但在每次测试后都不会重新加载.在我的测试配置中,我使用以下xml来决定要注入的bean:有任何想法吗?

  6. java – 使用RESTEasy跨GWT和Appengine devmodes进行JUnit集成测试

    我想运行一个测试,我的GWT代码向我的AppEngine服务器发出请求并等待响应.我的服务器使用RESTEasy来设置请求路径.我的客户端使用一些AutoBean魔法,它使用GWT.create(),所以这个测试必须是一个GWTTestCase.为测试设置appengine开发模式的完整模拟,我需要做什么?docs提到了设置appengine所依赖的每个服务的方法,但我想提升整个事情.解决方法由于不熟悉GWTTestCase,我不完全明白你在这里需要什么.不是一件简单的事:您可以根据需要向助手添加更多测试

  7. junit – 集成测试基于Spring Boot的微服务

    我已经阅读了很多关于使用SpringBoot和RESTful服务的指南,其中许多包含有关运行单元测试的信息,最着名的是“使用SpringBoot构建应用程序”.但是,我还没有看到任何有关如何对使用/依赖其他SpringBoot应用程序的SpringBoot应用程序进行单元测试的示例,这在云微服务架构中很常见.因此,例如,我们有以下SpringBoot服务:ServiceMediator,适配器1,适配器2ServiceMediator根据输入调用Adapter1或Adapter2.有没有办法在Spring

  8. java – @WebAppConfiguration和Spring Boot Thymeleaf的@ContextConfiguration

    让用户受到了满意的欢迎!在http://localhost:8080/,但Spring的“上下文”的连接似乎不适用于集成测试:项目布局和/或测试中的配置注释有什么问题?

  9. java – 使用Redis进行集成测试

    我在Jedis图书馆的帮助下开始在我的项目中使用Redis.所有的工作正常,但现在我有一个问题,我的功能测试需要Redis,我想避免在我的持续集成.这样做最好的方法是什么?

  10. java – Maven Failsafe插件:如何使用前后集成测试阶段

    对于我来说,如何最好地使用MavenFailsafe插件进行集成测试还不是很清楚.我的用例是测试针对本地MySQL数据库的SQL查询.我了解数据库应该在预集成测试阶段启动,并在后整合测试期间关闭.但是如何指定呢?有没有我应该放在我的pom.xml中的命令行?解决方法在正常的built-inmavenlifecycles(jar,war…

随机推荐

  1. 基于EJB技术的商务预订系统的开发

    用EJB结构开发的应用程序是可伸缩的、事务型的、多用户安全的。总的来说,EJB是一个组件事务监控的标准服务器端的组件模型。基于EJB技术的系统结构模型EJB结构是一个服务端组件结构,是一个层次性结构,其结构模型如图1所示。图2:商务预订系统的构架EntityBean是为了现实世界的对象建造的模型,这些对象通常是数据库的一些持久记录。

  2. Java利用POI实现导入导出Excel表格

    这篇文章主要为大家详细介绍了Java利用POI实现导入导出Excel表格,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  3. Mybatis分页插件PageHelper手写实现示例

    这篇文章主要为大家介绍了Mybatis分页插件PageHelper手写实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  4. (jsp/html)网页上嵌入播放器(常用播放器代码整理)

    网页上嵌入播放器,只要在HTML上添加以上代码就OK了,下面整理了一些常用的播放器代码,总有一款适合你,感兴趣的朋友可以参考下哈,希望对你有所帮助

  5. Java 阻塞队列BlockingQueue详解

    本文详细介绍了BlockingQueue家庭中的所有成员,包括他们各自的功能以及常见使用场景,通过实例代码介绍了Java 阻塞队列BlockingQueue的相关知识,需要的朋友可以参考下

  6. Java异常Exception详细讲解

    异常就是不正常,比如当我们身体出现了异常我们会根据身体情况选择喝开水、吃药、看病、等 异常处理方法。 java异常处理机制是我们java语言使用异常处理机制为程序提供了错误处理的能力,程序出现的错误,程序可以安全的退出,以保证程序正常的运行等

  7. Java Bean 作用域及它的几种类型介绍

    这篇文章主要介绍了Java Bean作用域及它的几种类型介绍,Spring框架作为一个管理Bean的IoC容器,那么Bean自然是Spring中的重要资源了,那Bean的作用域又是什么,接下来我们一起进入文章详细学习吧

  8. 面试突击之跨域问题的解决方案详解

    跨域问题本质是浏览器的一种保护机制,它的初衷是为了保证用户的安全,防止恶意网站窃取数据。那怎么解决这个问题呢?接下来我们一起来看

  9. Mybatis-Plus接口BaseMapper与Services使用详解

    这篇文章主要为大家介绍了Mybatis-Plus接口BaseMapper与Services使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  10. mybatis-plus雪花算法增强idworker的实现

    今天聊聊在mybatis-plus中引入分布式ID生成框架idworker,进一步增强实现生成分布式唯一ID,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

返回
顶部