


下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第第頁一枚小Bug的獨(dú)白一枚小Bug的獨(dú)白
發(fā)表于:2023-04-07來源:網(wǎng)易杭州QATeam:君小食堯點(diǎn)擊數(shù):標(biāo)簽:bug
我是一枚潛藏在數(shù)據(jù)庫引擎深處的Bug,躲在一個黑暗的角落很久了,歷經(jīng)多個版本、N輪回歸測試的風(fēng)雨洗禮,我存在,我驕傲。還記得那天,我懷著激動而忐忑的心情等待一位QA新人把我發(fā)布出去……
我是一枚潛藏在(數(shù)據(jù)庫)引擎深處的Bug,躲在一個黑暗的角落很久了,歷經(jīng)多個版本、N輪(回歸)(測試)的風(fēng)雨洗禮,我存在,我驕傲。還記得那天,我懷著激動而忐忑的心情等待一位QA新人把我發(fā)布出去
產(chǎn)品發(fā)布在即,一位頗有經(jīng)驗(yàn)的QA在無意間寫了一條短小精悍的(用例)讓QA新人來執(zhí)行一遍,就是這條不起眼的(用例),使我原形畢露。這個用例看起來很簡單:就是向數(shù)據(jù)庫里插入一條null記錄(還記得我們的MrNull嗎?),一條字符串記錄;再一條null記錄,一條同樣的字符串記錄如此反復(fù),來個5000次,然后啟用創(chuàng)建數(shù)據(jù)字典的功能,將這若干條看似規(guī)律的記錄進(jìn)行壓縮。好歹咱也算經(jīng)歷過風(fēng)風(fēng)雨雨的,每天的持續(xù)回歸測試也沒有拿我怎么樣,可就在執(zhí)行這條小用例時(shí),神奇的事情發(fā)生了數(shù)據(jù)庫發(fā)生了崩潰。
原因分析:
這個難題先后困擾過好幾個人,直到一位研究"炸彈'的(開發(fā))GG①,他對我進(jìn)行了好好的剖析,終于發(fā)現(xiàn)了問題的緣由。具體要從數(shù)據(jù)庫引擎的壓縮機(jī)制開始講起:
記錄壓縮:是基于數(shù)據(jù)字典的壓縮。所謂數(shù)據(jù)字典,就是數(shù)據(jù)庫表所有記錄中出現(xiàn)頻率最大的字符串集合。壓縮時(shí),將記錄中與數(shù)據(jù)字典相同的字符串進(jìn)行替換,替換為數(shù)據(jù)字典的下標(biāo)。由于數(shù)據(jù)字典的下標(biāo)一定會遠(yuǎn)遠(yuǎn)小于字典所代表的字符串,因此就達(dá)到了記錄壓縮的效果。
實(shí)現(xiàn)流程:該引擎的數(shù)據(jù)字典在采集時(shí),是將所有的記錄拼成一條長長的字符串流,然后從字符串流中采集出現(xiàn)頻率最高的子串,作為數(shù)據(jù)字典,而拼接記錄時(shí)并未在記錄間添加分隔符。這種一行null記錄、一行字符串記錄的方式,會使數(shù)據(jù)庫引擎采集的數(shù)據(jù)字典的長度超過記錄的最大長度,導(dǎo)致系統(tǒng)內(nèi)部驗(yàn)證報(bào)錯。
解決辦法:
知道了問題的本質(zhì),解決起來就很方便了,在將記錄拼接為長字符串流時(shí),在每個記錄的拼接處添加分隔符。不能跨越分隔符采集數(shù)據(jù)字典,從而保證了數(shù)據(jù)字典的長度一定小于等于記錄的長度限制,問題解決!
經(jīng)驗(yàn)總結(jié):
注意邊界問題。問題往往出現(xiàn)在邊界情況下,比如最大值/最小值/0值。如果在代碼中加入一些邊界斷言,可以幫助提早發(fā)現(xiàn)問題。
注意"null'的使用。不論開發(fā)還是測試,注意"null'的使用都可以幫助我們少犯一些錯誤,或者多發(fā)現(xiàn)一些問題。
"殺蟲劑困境'②的思考。再嚴(yán)密的單一性測試也不可能發(fā)現(xiàn)100%的Bug。將不同的測試思路和方法相結(jié)合,采用探索式的測試思維或許能幫助發(fā)現(xiàn)更多潛在問題。
說了這么多,我得閉嘴了,不低調(diào)的Bug是不厚道的,
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 防水修繕合同范本
- 借款融資居間服務(wù)合同范本
- 加梯安裝合同范例
- 醫(yī)生技術(shù)股協(xié)議合同范本
- 單位燈具購買合同范本
- 修車合同范本模板
- 農(nóng)村建房買房合同范本
- 農(nóng)村豬場合同范本
- 人事專員勞務(wù)合同范本
- 勞務(wù)供銷合同范例
- 09式 新擒敵拳 教學(xué)教案 教學(xué)法 圖解
- 《網(wǎng)店運(yùn)營與管理》整本書電子教案全套教學(xué)教案
- 打印版 《固體物理教程》課后答案王矜奉
- CAD術(shù)語對照表
- 學(xué)術(shù)論文的寫作與規(guī)范課件
- 香港牛津新魔法Newmagic3AUnit4Mycalendar單元檢測試卷
- 中考《紅星照耀中國》各篇章練習(xí)題及答案(1-12)
- Q∕GDW 11612.43-2018 低壓電力線高速載波通信互聯(lián)互通技術(shù)規(guī)范 第4-3部分:應(yīng)用層通信協(xié)議
- 自動化物料編碼規(guī)則
- 第1本書出體旅程journeys out of the body精教版2003版
- [英語考試]同等學(xué)力英語新大綱全部詞匯
評論
0/150
提交評論