摘要:我在使用框架过程中,遇到一个问题,在官方文档中给出了的方法,表示循环返回一个数组里面的,但是在查看的时候并没有发现这个方法,所以觉得自己写了一个,并且重写了方法。方法主要用在请求次数相关的内容,比如订单提交资源删除等场景。
我在使用moco框架过程中,遇到一个问题,在官方文档中给出了cycle的方法,表示循环返回一个数组里面的response,但是在查看API的时候并没有发现这个cycle()方法,所以觉得自己写了一个responsehandle,并且重写了cycle()方法。
cycle方法主要用在请求次数相关的内容,比如订单提交、资源删除等场景。
package com.fun.moco.support; import com.github.dreamhead.moco.MocoConfig; import com.github.dreamhead.moco.ResponseHandler; import com.github.dreamhead.moco.handler.AbstractResponseHandler; import com.github.dreamhead.moco.internal.SessionContext; import com.google.common.base.Function; import com.google.common.collect.FluentIterable; import com.google.common.collect.ImmutableList; import com.google.common.collect.Iterables; import static com.google.common.base.Preconditions.checkArgument; import static com.google.common.collect.FluentIterable.from; import static com.google.common.collect.ImmutableList.copyOf; /** * 循环的responsehandle */ @SuppressWarnings("all") public class CycleHandle extends AbstractResponseHandler { private final ImmutableListhandlers; private int index; private CycleHandle(final Iterable handlers) { this.handlers = copyOf(handlers); } public static ResponseHandler newSeq(final Iterable handlers) { checkArgument(Iterables.size(handlers) > 0, "Sequence contents should not be null"); return new CycleHandle(handlers); } @Override public void writeToResponse(final SessionContext context) { handlers.get((index++) % handlers.size()).writeToResponse(context); } @Override public ResponseHandler apply(final MocoConfig config) { if (config.isFor(MocoConfig.RESPONSE_ID)) { return super.apply(config); } FluentIterable transformedResources = from(copyOf(handlers)).transform(applyConfig(config)); return new CycleHandle(transformedResources.toList()); } private Function applyConfig(final MocoConfig config) { return new Function () { @Override public ResponseHandler apply(final ResponseHandler input) { return input.apply(config); } }; } } 使用方法如下(groovy,有兴趣可以转成java): /** * 循环返回 * @param content * @param contents * @return */ static ResponseHandler cycle(String content, String... contents) { CycleHandle.newSeq(FluentIterable.from(asIterable(content, contents)).transform(textToResource())) } /** * 循环返回 * @param handler * @param handlers * @return */ static ResponseHandler cycle(final ResponseHandler handler, final ResponseHandler... handlers) { CycleHandle.newSeq(asIterable(handler, handlers)) }
groovy是一种基于JVM的动态语言,我觉得最大的优势有两点,第一:于java兼容性非常好,大部分时候吧groovy的文件后缀改成java直接可以用,反之亦然。java的绝大部分库,groovy都是可以直接拿来就用的。这还带来了另外一个有点,学习成本低,非常低,直接上手没问题,可以慢慢学习groovy不同于Java的语法;第二:编译器支持变得更好,现在用的intellij的ide,总体来说已经比较好的支持groovy语言了,写起代码来也是比较顺滑了,各种基于groovy的框架工具也比较溜,特别是Gradle构建工具,比Maven爽很多。----此段文字为了撑字数强加的,与内容无关。
欢迎有兴趣的童鞋一起交流
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/75408.html
摘要:在使用做接口虚拟化的过程中遇到一个比较棘手的问题,就是根据官方文档提供的案例,并不能跑通请求在处理传参格式的虚拟化。的绝大部分库,都是可以直接拿来就用的。此段文字为了撑字数强加的,与内容无关。欢迎有兴趣的童鞋一起交流 在使用moco API做接口虚拟化的过程中遇到一个比较棘手的问题,就是根据官方文档提供的案例,并不能跑通post请求在处理json传参格式的虚拟化。经过查询源码,发现了一...
摘要:在使用的时候,发现文档中的一些功能并不能满足构建测试服务的需求,需要自己开发一些功能。使用场景的话小游戏的里面的抽奖,订单提交,耗时较长的功能等。在实际的业务逻辑中,很可能会有短时间内不允许提交多次,请求多次的需求。 在使用moco API的时候,发现文档中的一些功能并不能满足构建测试服务的需求,需要自己开发一些功能。之前两篇主要讲了moco本身的补充,本篇说说moco文档之外的功能:...
摘要:虽然前后端分离已经流行很多年了,仍有很多团队不能够充分的利用前后端分离的优势。主要体现在前端过分依赖服务环境将高效的约定分工合作模式理解很浅。在这里推荐一种的解决方案。不支持简洁的文件格式不符合的标准。所以使用集成,参考前后端分离方案整合 虽然前后端分离已经流行很多年了,仍有很多团队不能够充分的利用前后端分离的优势。主要体现在前端过分依赖服务环境, 将高效的约定分工合作模式理解很浅。 ...
摘要:虽然前后端分离已经流行很多年了,仍有很多团队不能够充分的利用前后端分离的优势。主要体现在前端过分依赖服务环境将高效的约定分工合作模式理解很浅。在这里推荐一种的解决方案。不支持简洁的文件格式不符合的标准。所以使用集成,参考前后端分离方案整合 虽然前后端分离已经流行很多年了,仍有很多团队不能够充分的利用前后端分离的优势。主要体现在前端过分依赖服务环境, 将高效的约定分工合作模式理解很浅。 ...
摘要:我们将使用,这是一个现代,简单,漂亮的框架,在内部使用并将响应式编程概念应用于前端编程。驱动程序采用从我们的应用程序发出数据的,它们返回另一个导致副作用的。我们将使用来呈现我们的应用程序。仅采用长度超过两个字符的文本。 Rxjs 响应式编程-第一章:响应式Rxjs 响应式编程-第二章:序列的深入研究Rxjs 响应式编程-第三章: 构建并发程序Rxjs 响应式编程-第四章 构建完整的We...
阅读 1758·2021-09-27 14:02
阅读 3127·2021-09-27 13:36
阅读 1052·2019-08-30 12:46
阅读 1840·2019-08-30 10:51
阅读 3577·2019-08-29 17:02
阅读 946·2019-08-29 16:38
阅读 1852·2019-08-29 16:37
阅读 3020·2019-08-26 10:32