摘要:我在使用框架過程中,遇到一個(gè)問題,在官方文檔中給出了的方法,表示循環(huán)返回一個(gè)數(shù)組里面的,但是在查看的時(shí)候并沒有發(fā)現(xiàn)這個(gè)方法,所以覺得自己寫了一個(gè),并且重寫了方法。方法主要用在請求次數(shù)相關(guān)的內(nèi)容,比如訂單提交資源刪除等場景。
我在使用moco框架過程中,遇到一個(gè)問題,在官方文檔中給出了cycle的方法,表示循環(huán)返回一個(gè)數(shù)組里面的response,但是在查看API的時(shí)候并沒有發(fā)現(xiàn)這個(gè)cycle()方法,所以覺得自己寫了一個(gè)responsehandle,并且重寫了cycle()方法。
cycle方法主要用在請求次數(shù)相關(guān)的內(nèi)容,比如訂單提交、資源刪除等場景。
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; /** * 循環(huán)的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,有興趣可以轉(zhuǎn)成java): /** * 循環(huán)返回 * @param content * @param contents * @return */ static ResponseHandler cycle(String content, String... contents) { CycleHandle.newSeq(FluentIterable.from(asIterable(content, contents)).transform(textToResource())) } /** * 循環(huán)返回 * @param handler * @param handlers * @return */ static ResponseHandler cycle(final ResponseHandler handler, final ResponseHandler... handlers) { CycleHandle.newSeq(asIterable(handler, handlers)) }
groovy是一種基于JVM的動(dòng)態(tài)語言,我覺得最大的優(yōu)勢有兩點(diǎn),第一:于java兼容性非常好,大部分時(shí)候吧groovy的文件后綴改成java直接可以用,反之亦然。java的絕大部分庫,groovy都是可以直接拿來就用的。這還帶來了另外一個(gè)有點(diǎn),學(xué)習(xí)成本低,非常低,直接上手沒問題,可以慢慢學(xué)習(xí)groovy不同于Java的語法;第二:編譯器支持變得更好,現(xiàn)在用的intellij的ide,總體來說已經(jīng)比較好的支持groovy語言了,寫起代碼來也是比較順滑了,各種基于groovy的框架工具也比較溜,特別是Gradle構(gòu)建工具,比Maven爽很多。----此段文字為了撐字?jǐn)?shù)強(qiáng)加的,與內(nèi)容無關(guān)。
歡迎有興趣的童鞋一起交流
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/75408.html
摘要:在使用做接口虛擬化的過程中遇到一個(gè)比較棘手的問題,就是根據(jù)官方文檔提供的案例,并不能跑通請求在處理傳參格式的虛擬化。的絕大部分庫,都是可以直接拿來就用的。此段文字為了撐字?jǐn)?shù)強(qiáng)加的,與內(nèi)容無關(guān)。歡迎有興趣的童鞋一起交流 在使用moco API做接口虛擬化的過程中遇到一個(gè)比較棘手的問題,就是根據(jù)官方文檔提供的案例,并不能跑通post請求在處理json傳參格式的虛擬化。經(jīng)過查詢源碼,發(fā)現(xiàn)了一...
摘要:在使用的時(shí)候,發(fā)現(xiàn)文檔中的一些功能并不能滿足構(gòu)建測試服務(wù)的需求,需要自己開發(fā)一些功能。使用場景的話小游戲的里面的抽獎(jiǎng),訂單提交,耗時(shí)較長的功能等。在實(shí)際的業(yè)務(wù)邏輯中,很可能會(huì)有短時(shí)間內(nèi)不允許提交多次,請求多次的需求。 在使用moco API的時(shí)候,發(fā)現(xiàn)文檔中的一些功能并不能滿足構(gòu)建測試服務(wù)的需求,需要自己開發(fā)一些功能。之前兩篇主要講了moco本身的補(bǔ)充,本篇說說moco文檔之外的功能:...
摘要:雖然前后端分離已經(jīng)流行很多年了,仍有很多團(tuán)隊(duì)不能夠充分的利用前后端分離的優(yōu)勢。主要體現(xiàn)在前端過分依賴服務(wù)環(huán)境將高效的約定分工合作模式理解很淺。在這里推薦一種的解決方案。不支持簡潔的文件格式不符合的標(biāo)準(zhǔn)。所以使用集成,參考前后端分離方案整合 雖然前后端分離已經(jīng)流行很多年了,仍有很多團(tuán)隊(duì)不能夠充分的利用前后端分離的優(yōu)勢。主要體現(xiàn)在前端過分依賴服務(wù)環(huán)境, 將高效的約定分工合作模式理解很淺。 ...
摘要:雖然前后端分離已經(jīng)流行很多年了,仍有很多團(tuán)隊(duì)不能夠充分的利用前后端分離的優(yōu)勢。主要體現(xiàn)在前端過分依賴服務(wù)環(huán)境將高效的約定分工合作模式理解很淺。在這里推薦一種的解決方案。不支持簡潔的文件格式不符合的標(biāo)準(zhǔn)。所以使用集成,參考前后端分離方案整合 雖然前后端分離已經(jīng)流行很多年了,仍有很多團(tuán)隊(duì)不能夠充分的利用前后端分離的優(yōu)勢。主要體現(xiàn)在前端過分依賴服務(wù)環(huán)境, 將高效的約定分工合作模式理解很淺。 ...
摘要:我們將使用,這是一個(gè)現(xiàn)代,簡單,漂亮的框架,在內(nèi)部使用并將響應(yīng)式編程概念應(yīng)用于前端編程。驅(qū)動(dòng)程序采用從我們的應(yīng)用程序發(fā)出數(shù)據(jù)的,它們返回另一個(gè)導(dǎo)致副作用的。我們將使用來呈現(xiàn)我們的應(yīng)用程序。僅采用長度超過兩個(gè)字符的文本。 Rxjs 響應(yīng)式編程-第一章:響應(yīng)式Rxjs 響應(yīng)式編程-第二章:序列的深入研究Rxjs 響應(yīng)式編程-第三章: 構(gòu)建并發(fā)程序Rxjs 響應(yīng)式編程-第四章 構(gòu)建完整的We...
閱讀 1751·2021-09-27 14:02
閱讀 3100·2021-09-27 13:36
閱讀 1046·2019-08-30 12:46
閱讀 1834·2019-08-30 10:51
閱讀 3571·2019-08-29 17:02
閱讀 941·2019-08-29 16:38
閱讀 1846·2019-08-29 16:37
閱讀 3004·2019-08-26 10:32