前端調(diào)試技巧:瀏覽器按F12 可以觀察控制臺(tái)輸出的變量,可以看請(qǐng)求的情況(請(qǐng)求路徑、參數(shù)等) ,這些都是常用的,每個(gè)瀏覽器不同。一般都是火狐的firebug 和谷歌瀏覽器brconsole.log(var tem); //控制臺(tái)打印變量bralert("tem"); //彈出框彈出變量后臺(tái)調(diào)試:eclipse IDE就是在相對(duì)應(yīng)的java代碼處打斷點(diǎn),看變量值等
成都創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站建設(shè)、做網(wǎng)站、南通網(wǎng)絡(luò)推廣、小程序制作、南通網(wǎng)絡(luò)營(yíng)銷、南通企業(yè)策劃、南通品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠(chéng)為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);成都創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供南通建站搭建服務(wù),24小時(shí)服務(wù)熱線:18980820575,官方網(wǎng)址:www.cdcxhl.com
雖然說我們?cè)诠ぷ髦幸辉僖蟠蠹乙J(rèn)真細(xì)心,但是對(duì)于許多的新手來說,依然會(huì)在不知不覺中犯錯(cuò)誤。
下面甘肅電腦培訓(xùn)就通過軟件測(cè)試崗位做為分析案例,了解一下,一個(gè)軟床測(cè)試新人都容易犯的測(cè)試錯(cuò)誤都有哪些。
1.沒有測(cè)試我們很容易毫無原因地掉入這個(gè)陷阱。
從現(xiàn)在開始,制定計(jì)劃添加測(cè)試到你現(xiàn)在正在處理的代碼中,并添加測(cè)試到將來的項(xiàng)目中。
2.沒有從項(xiàng)目一開始就啟動(dòng)測(cè)試我們很難再回過頭去添加測(cè)試,并且可能需要改變架構(gòu)才能添加測(cè)試,這樣做終將需要你花更長(zhǎng)的時(shí)間才能產(chǎn)出可信任的代碼。
從一開始就在項(xiàng)目的生命周期添加測(cè)試可以節(jié)省時(shí)間和精力。
3.編寫失敗的測(cè)試TDD方法的普及將紅—綠—重構(gòu)的理念帶到軟件測(cè)試世界。
這個(gè)理念常常被誤認(rèn)為應(yīng)該“通過編寫一個(gè)失敗的測(cè)試開始”。
其實(shí)并非如此。
在寫代碼之前創(chuàng)建測(cè)試的目的是定義系統(tǒng)的正確行為應(yīng)該是什么。
在許多情況下,它是一個(gè)失敗的測(cè)試(紅色表示),但它可能會(huì)通過一個(gè)非決定性的或未實(shí)現(xiàn)的測(cè)試來表示。
4.擔(dān)心未實(shí)現(xiàn)測(cè)試軟件開發(fā)中的一個(gè)大問題就是,代碼和任何關(guān)于系統(tǒng)實(shí)際上應(yīng)該做什么的文檔之間的溝壑。
通過擁有一個(gè)名稱中明確定義你終想要實(shí)現(xiàn)的預(yù)期行為的測(cè)試,你將從測(cè)試中得到一定的價(jià)值,即使將怎么寫測(cè)試目前還不得知。
5.沒有很好地命名測(cè)試命名軟件這件事出了名的很難做好,這同樣適用于測(cè)試。
關(guān)于如何命名測(cè)試有幾種流行的約定。
無論你使用哪一種都沒有關(guān)系,只要你能夠一貫使用,并準(zhǔn)確描述正在測(cè)試什么。
6.讓測(cè)試做太多事情又長(zhǎng)又復(fù)雜的名字通常說明了你想同時(shí)測(cè)試多件事情。
單個(gè)測(cè)試應(yīng)該只測(cè)試一件事情。
如果失敗了也應(yīng)該在代碼中注明是什么地方出了錯(cuò)。
你沒有必要為了知道代碼中出了什么問題而查看是哪部分測(cè)試失敗。
這并不意味著你不應(yīng)該在測(cè)試中有多個(gè)斷言,但這些斷言應(yīng)該緊密相關(guān)。
例如,一個(gè)查看訂單處理系統(tǒng)輸出,并確認(rèn)輸出中是否有一個(gè)單一項(xiàng)目以及它是否包含具體項(xiàng)目的測(cè)試,是ok的。
但一個(gè)驗(yàn)證相同系統(tǒng)的輸出的測(cè)試,既創(chuàng)建一個(gè)特定項(xiàng)目,又記錄到數(shù)據(jù)庫(kù)中,還發(fā)送確認(rèn)電子郵件,就不行了。
7.沒有實(shí)際測(cè)試代碼經(jīng)常可以看到測(cè)試新手創(chuàng)建過于復(fù)雜的模型以及不能實(shí)際測(cè)試代碼的設(shè)置程序。
他們可能會(huì)驗(yàn)證模擬代碼是否正確,或者模擬代碼是否和真正代碼做相同的事情,或沒有任何斷言而只是執(zhí)行代碼。
這樣的“測(cè)試”都是白費(fèi)力氣,特別是如果它們的存在只是為了提高代碼覆蓋率水平的話。
8.擔(dān)心代碼覆蓋率代碼覆蓋率的理念很崇高,但往往實(shí)際價(jià)值有限。
知道運(yùn)行測(cè)試的時(shí)候有多少代碼被執(zhí)行應(yīng)該是有用的,但因?yàn)樗豢紤]正在執(zhí)行代碼的測(cè)試的質(zhì)量,因此就變得沒有意義。
代碼覆蓋率在它數(shù)值非常高或非常低的時(shí)候,是挺博人眼球的。
如果非常高,就表明,比起帶來的價(jià)值,過多的代碼可能正在被測(cè)試。
非常低的代碼覆蓋率表明有可能代碼的測(cè)試不夠。
因?yàn)檫@樣模棱兩可的意思,有的人就不知道單一片段的代碼是否應(yīng)該進(jìn)行測(cè)試。
我用一個(gè)簡(jiǎn)單的問題來明確這一點(diǎn):代碼是否包含重大的復(fù)雜性?如果包含,那么你需要一些測(cè)試。
如果沒有的話,你就不需要。
測(cè)試屬性訪問器不過是浪費(fèi)時(shí)間。
如果它們失敗的話,那么比起你正在寫的代碼,你的代碼體系出現(xiàn)了一些更根本的問題。
如果你不用看一段代碼,就立即知道一切,那么它就不重大。
這不僅適用于代碼,也適用于你寫代碼。
如果我們?cè)谌我恻c(diǎn)重訪代碼,那么它就需要測(cè)試。
如果在現(xiàn)有代碼中發(fā)現(xiàn)過bug,那就說明這一塊的代碼對(duì)其復(fù)雜性沒有進(jìn)行充分的測(cè)試。
9.著眼于一種類型的測(cè)試一旦你開始測(cè)試,很容易只糾結(jié)于一種風(fēng)格的測(cè)試。
這是一個(gè)錯(cuò)誤。
只用一種類型的測(cè)試,你就不能充分測(cè)試系統(tǒng)的所有部分。
你需要單元測(cè)試來確認(rèn)代碼的各個(gè)組件是否能夠正確工作。
你需要集成測(cè)試來確認(rèn)不同組件是否能夠協(xié)同工作。
你需要自動(dòng)化UI測(cè)試來驗(yàn)證軟件是否可以如預(yù)期使用。
后,你需要為任何不容易自動(dòng)化的部分和探索性嘗試進(jìn)行手動(dòng)測(cè)試。
需要寫JUnit測(cè)試,要把所有的測(cè)試情況都列出來,每個(gè)測(cè)試情況都是一個(gè)@Test,有一部分方法應(yīng)該沒辦法用JUnit測(cè):比如依賴系統(tǒng)變量,或者只有在runtime才可以測(cè)試等等