摘要:我在使用框架過程中,遇到一個問題,在官方文檔中給出了的方法,表示循環返回一個數組里面的,但是在查看的時候并沒有發現這個方法,所以覺得自己寫了一個,并且重寫了方法。方法主要用在請求次數相關的內容,比如訂單提交資源刪除等場景。
我在使用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爽很多。----此段文字為了撐字數強加的,與內容無關。
歡迎有興趣的童鞋一起交流
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/75408.html
摘要:在使用做接口虛擬化的過程中遇到一個比較棘手的問題,就是根據官方文檔提供的案例,并不能跑通請求在處理傳參格式的虛擬化。的絕大部分庫,都是可以直接拿來就用的。此段文字為了撐字數強加的,與內容無關。歡迎有興趣的童鞋一起交流 在使用moco API做接口虛擬化的過程中遇到一個比較棘手的問題,就是根據官方文檔提供的案例,并不能跑通post請求在處理json傳參格式的虛擬化。經過查詢源碼,發現了一...
摘要:在使用的時候,發現文檔中的一些功能并不能滿足構建測試服務的需求,需要自己開發一些功能。使用場景的話小游戲的里面的抽獎,訂單提交,耗時較長的功能等。在實際的業務邏輯中,很可能會有短時間內不允許提交多次,請求多次的需求。 在使用moco API的時候,發現文檔中的一些功能并不能滿足構建測試服務的需求,需要自己開發一些功能。之前兩篇主要講了moco本身的補充,本篇說說moco文檔之外的功能:...
摘要:雖然前后端分離已經流行很多年了,仍有很多團隊不能夠充分的利用前后端分離的優勢。主要體現在前端過分依賴服務環境將高效的約定分工合作模式理解很淺。在這里推薦一種的解決方案。不支持簡潔的文件格式不符合的標準。所以使用集成,參考前后端分離方案整合 雖然前后端分離已經流行很多年了,仍有很多團隊不能夠充分的利用前后端分離的優勢。主要體現在前端過分依賴服務環境, 將高效的約定分工合作模式理解很淺。 ...
摘要:雖然前后端分離已經流行很多年了,仍有很多團隊不能夠充分的利用前后端分離的優勢。主要體現在前端過分依賴服務環境將高效的約定分工合作模式理解很淺。在這里推薦一種的解決方案。不支持簡潔的文件格式不符合的標準。所以使用集成,參考前后端分離方案整合 雖然前后端分離已經流行很多年了,仍有很多團隊不能夠充分的利用前后端分離的優勢。主要體現在前端過分依賴服務環境, 將高效的約定分工合作模式理解很淺。 ...
摘要:我們將使用,這是一個現代,簡單,漂亮的框架,在內部使用并將響應式編程概念應用于前端編程。驅動程序采用從我們的應用程序發出數據的,它們返回另一個導致副作用的。我們將使用來呈現我們的應用程序。僅采用長度超過兩個字符的文本。 Rxjs 響應式編程-第一章:響應式Rxjs 響應式編程-第二章:序列的深入研究Rxjs 響應式編程-第三章: 構建并發程序Rxjs 響應式編程-第四章 構建完整的We...
閱讀 1760·2021-09-27 14:02
閱讀 3162·2021-09-27 13:36
閱讀 1055·2019-08-30 12:46
閱讀 1842·2019-08-30 10:51
閱讀 3580·2019-08-29 17:02
閱讀 951·2019-08-29 16:38
閱讀 1854·2019-08-29 16:37
閱讀 3028·2019-08-26 10:32