FiddlerScript高級技巧---自定義Fiddler菜單

Tips

書接上回, Fiddler插件 在團隊內部試用後,效果很不錯,小夥伴們也提出了不少改進的建議;html

最近一段Fiddler使用的仍較爲頻繁,之前碰到一些特殊測試需求時,老是本身在FiddlerScript中改來改去,略有些不便;android

因而花了點時間,
將一些經常使用的測試功能封裝成了菜單項,作到一鍵切換,方便以後的測試工做ios

如下各菜單,Android和IOS都可使用api

1、 域名映射到測試環境

HostMapping

  • 在測試過程當中,常常須要修改或切換測試環境;以Android爲例,須要再返回首頁切換環境
  • 使用線上Release包時,沒法切換到灰度或測試環境;且目前Elong-Test-D只做IP映射,默認鏈接的是灰度1(端口默認爲80)
//映射線上Host到灰度等測試環境; 在class中增長以下代碼
RulesString("HostMapping",true)
RulesStringValue(0,"灰度1", "10.35.45.84")
RulesStringValue(1,"灰度2", "10.35.45.84:8080")
RulesStringValue(2,"233.94", "192.168.233.94")
RulesStringValue(3,"14.206", "192.168.14.206")
RulesStringValue(4,"9.28", "192.168.9.28")
public static var m_host: String = null;

// 在 OnBeforeRequest 方法中增長以下 

if(null != m_host && oSession.HostnameIs("mobile-api2011.elong.com") ){

	oSession.host=m_host;

}

2、DeviceID切換,用於ABTest測試

abtest

  • 公司內部的MVT測試(即ABTest)是由DeviceID來控制其命中策略的,修改相應的DeviceID便可命中不一樣的策略;
  • 另外,增長了一個新用戶的DeviceID;用於模擬新用戶
  • 因爲MVT接口是在APP啓動時獲取的,所以需重啓app才能生效
  • 使用該方式,就不用在APP的Debug工具中輸入DeviceID了;同時適用於Android和IOS

代碼以下網絡

//替換DeviceID,模擬MVT測試及新用戶 
//在class中增長以下代碼
	
RulesString("ABTest測試",true)
RulesStringValue(0,"測試組", "12345678-1234-5678-9012-123456789010")
RulesStringValue(1,"對照組", "12345678-1234-5678-9012-123456789011")
RulesStringValue(2,"新用戶", "12345678-1234-5678-9012-122211133344")
public static var m_deviceid: String = null;
	
// 在 OnBeforeRequest 方法中增長以下 
if(null != m_deviceid && oSession.oRequest.headers.Exists("DeviceId") &&oSession.oRequest.headers.Exists("ClientType") ){			
    oSession.oRequest["DeviceId"] = m_deviceid;				
}

3、網速模擬測試

networklimit

  • 在測試過程當中,常常須要模擬不一樣網絡速度,尤爲是低網速下的一些測試場景;
  • 經過測試代理網速傳輸延時來達到模擬網速的目的
  • 無需重啓app,即時生效
代碼以下 :
//經過設置網絡延時,來模擬不一樣的網速場景
//在class中增長以下代碼 ;增長菜單項
RulesString("網速模擬",true)
RulesStringValue(0,"Simulate &Modem Speeds", "150")
RulesStringValue(1,"Simulate 2G(25KB)", "40")
RulesStringValue(2,"Simulate 3G(250KB)", "4")
public static var m_networkSpeed: String = null; 

// 在 OnBeforeRequest 方法中增長以下
if(m_networkSpeed){
    //網速模擬測試
    oSession["request-trickle-delay"] = (parseInt(m_networkSpeed)*2).ToString(); 
    oSession["response-trickle-delay"] = m_networkSpeed; 
}

4、其它小功能

image

  • 將全部HTTPS請求標識爲紅色;
  • 在Fiddler中,只展現Mapi請求,忽略其它全部請求(潔癖患者推薦)
//在class中增長以下代碼
//增長菜單項
public static RulesOption("標記HTTPS", "Other")
var m_https: boolean = false; 

//只展現來自APP的Mapi請求,其它類型所有過濾 
public static RulesOption("Only Show Mapi", "Other")
var m_OnlyMapi: boolean = false;


// 在 OnBeforeRequest 方法中增長以下

//將域名中包含elong的HTTPS請求,標記爲紅色
if ( m_https && oSession.isHTTPS && oSession.fullUrl.indexOf("elong")>0){			
	oSession["ui-color"] = "red";				
}

//只展現APP過來的請求,非app請求直接過濾掉
if(m_OnlyMapi && !oSession.oRequest.headers.Exists("DeviceId") && !oSession.oRequest.headers.Exists("ClientType")){
	oSession["ui-hide"] = "true";
}

5、主窗口中增長兩列:ClientIP和HTTP請求方式

  • 顯示HTTP請求方法,如GET Or POST ;
  • 展現客戶端IP來源;
代碼以下
//在class中增長以下代碼便可 

public static BindUIColumn("ClientIP", 120)
function FillClientIPColumn(oS: Session): String {
    //oS.oResponse.headers.
	return oS.clientIP.Split(':')[3];
}
    
public static BindUIColumn("Method", 60)
function FillMethodColumn(oS: Session): String {
    return oS.RequestMethod;
}

參考資料

fiddler官方資料app

相關文章
相關標籤/搜索