摘要:在使用的時(shí)候,發(fā)現(xiàn)文檔中的一些功能并不能滿足構(gòu)建測試服務(wù)的需求,需要自己開發(fā)一些功能。使用場景的話小游戲的里面的抽獎(jiǎng),訂單提交,耗時(shí)較長的功能等。在實(shí)際的業(yè)務(wù)邏輯中,很可能會有短時(shí)間內(nèi)不允許提交多次,請求多次的需求。
在使用moco API的時(shí)候,發(fā)現(xiàn)文檔中的一些功能并不能滿足構(gòu)建測試服務(wù)的需求,需要自己開發(fā)一些功能。之前兩篇主要講了moco本身的補(bǔ)充,本篇說說moco文檔之外的功能:limit。
主要是用于限制訪問次數(shù),并不針對某個(gè)session或者同一個(gè)用戶(本人暫時(shí)沒有這方面的需求,故沒有開發(fā))。
使用場景的話:小游戲的里面的抽獎(jiǎng),訂單提交,耗時(shí)較長的功能等。在實(shí)際的業(yè)務(wù)邏輯中,很可能會有短時(shí)間內(nèi)不允許提交多次,請求多次的需求。
下面上代碼:
package com.fun.moco.support; import com.fun.utils.Time; import com.github.dreamhead.moco.HttpRequest; 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.github.dreamhead.moco.model.MessageContent; import com.google.common.base.Function; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; /** * 循環(huán)的responsehandle */ @SuppressWarnings("all") public class LimitHandle extends AbstractResponseHandler { private final ResponseHandler limit; private final ResponseHandler unlimit; private Maptatal = new ConcurrentHashMap<>(); private int interval; private LimitHandle(final ResponseHandler limit, final ResponseHandler unLimit, int interval) { this.limit = limit; this.unlimit = unLimit; this.interval = interval; } public static ResponseHandler newSeq(final ResponseHandler limit, final ResponseHandler unLimit, int interval) { return new LimitHandle(limit, unLimit, interval); } /** * 返回響應(yīng) * * @param context */ @Override public void writeToResponse(final SessionContext context) { HttpRequest request = (HttpRequest) context.getRequest(); String uri = request.getUri(); MessageContent content = request.getContent(); (limited(uri + content) ? limit : unlimit).writeToResponse(context); } @Override public ResponseHandler apply(final MocoConfig config) { if (config.isFor(MocoConfig.RESPONSE_ID)) { return super.apply(config); } return new LimitHandle(limit, unlimit, interval); } private Function applyConfig(final MocoConfig config) { return new Function () { @Override public ResponseHandler apply(final ResponseHandler input) { return input.apply(config); } }; } /** * 判斷是否被限制 * * 通過記錄每一次響應(yīng)的時(shí)間戳,判斷兩次請求間隔達(dá)到limit目的 *
* * @param info * @return */ public boolean limited(String info) { long fresh = Time.getTimeStamp(); long old = tatal.containsKey(info) ? tatal.get(info) : 0L; tatal.put(info, fresh); return fresh - old > interval; } }
使用方法如下:
/** * 限制請求頻次,默認(rèn)1000ms * @param limit * @param unlimit * @return */ static ResponseHandler limit(String limited, String unlimited) { limit contentResponse(limited), contentResponse(unlimited) } static ResponseHandler limit(JSONObject limited, JSONObject unlimited) { limit jsonResponse(limited), jsonResponse(unlimited) } static ResponseHandler limit(ResponseHandler limited, ResponseHandler unlimited) { limit limited, unlimited, 1000 } /** * 限制請求頻次 * @param limit * @param unlimit * @param interval 單位ms * @return */ static ResponseHandler limit(String limited, String unlimited, int interval) { limit contentResponse(limited), contentResponse(unlimited), interval } static ResponseHandler limit(JSONObject limited, JSONObject unlimited, int interval) { limit limited.toString(), unlimited.toString(), interval } static ResponseHandler limit(ResponseHandler limit, ResponseHandler unlimit, int interval) { LimitHandle.newSeq(limit, unlimit, interval) }
groovy是一種基于JVM的動態(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://systransis.cn/yun/75420.html
摘要:在使用做接口虛擬化的過程中遇到一個(gè)比較棘手的問題,就是根據(jù)官方文檔提供的案例,并不能跑通請求在處理傳參格式的虛擬化。的絕大部分庫,都是可以直接拿來就用的。此段文字為了撐字?jǐn)?shù)強(qiáng)加的,與內(nèi)容無關(guān)。歡迎有興趣的童鞋一起交流 在使用moco API做接口虛擬化的過程中遇到一個(gè)比較棘手的問題,就是根據(jù)官方文檔提供的案例,并不能跑通post請求在處理json傳參格式的虛擬化。經(jīng)過查詢源碼,發(fā)現(xiàn)了一...
摘要:我在使用框架過程中,遇到一個(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è)cyc...
摘要:雖然前后端分離已經(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)境, 將高效的約定分工合作模式理解很淺。 ...
摘要:事件風(fēng)暴事件風(fēng)暴就是把所有的關(guān)鍵參與者都召集到一個(gè)很寬敞的屋子里來開會,并且使用便利貼來描述系統(tǒng)中發(fā)生的事情。一張桔黃色的便利貼代表一個(gè)領(lǐng)域事件,在上面用一句過去時(shí)的話描述曾經(jīng)發(fā)生過什么事情,格式一般是已。 一周前,參加了公司的一個(gè)架構(gòu)設(shè)計(jì)與建模的工作坊——『事件風(fēng)暴』。從某種意義上來說,這是一個(gè)關(guān)于架構(gòu)設(shè)計(jì)與軟件建模的工作坊。于是便閃現(xiàn)了一個(gè)靈感,便有了 Stepping.js。 當(dāng)...
閱讀 2435·2021-09-01 10:41
閱讀 1451·2019-08-30 14:12
閱讀 520·2019-08-29 12:32
閱讀 2868·2019-08-29 12:25
閱讀 2943·2019-08-28 18:30
閱讀 1713·2019-08-26 11:47
閱讀 989·2019-08-26 10:35
閱讀 2597·2019-08-23 18:06