搜尋
首頁web前端css教學人類的反應組件測試

人類的反應組件測試

制定有效的反應組件測試應直觀,直接且易於維護。但是,當前的測試庫生態系統通常會落後,阻礙開發人員始終如一地編寫強大的JavaScript測試。測試REACT組件,DOM經常需要在Jest或Mocha等流行的測試跑者周圍更高級別的包裝紙。

挑戰:乏味而令人困惑的測試

當前的測試方法通常證明是乏味而令人困惑的。表達測試邏輯的類似jQuery的鍊式風格很麻煩,並且與React的組件體系結構不符。即使是使用酶的看似可讀的代碼也可能變得過於冗長:

期待(screet.find(“。查看”)。hasclass(“ Technologies”)。to.equal(true);
期待(screen.find(“ h3”)。text())。 to equal(“ Technologies:”);
期望(screet.find(“ ul”)。兒童())。
期待(屏幕。
  // ...
]))。
期待(screen.find(“ button”)。text())。 to equal(“ back”);
期待(screet.find(“ button”)。hasclass(“ small”))。 to. equal(true);

這對應於一個相對簡單的DOM結構:

<div classname="view technologies">
  <h3 id="技術">技術:</h3>
  <ul>
<li>JavaScript</li>
<li> Reactjs</li>
<li> nodejs</li>
<li> webpack</li>
</ul>
  <button classname="small">後退</button>
</div>

測試更複雜的組件會放大這些問題,從而使過程更加笨拙。 React生成HTML的原理與測試方法之間的斷開連接導致效率低下且難以維護的測試。簡單的JavaScript鏈接不足以用於長期可維護性。

出現了兩個關鍵問題:

  • 特定於組件的測試方法:如何有效編寫針對組件行為的測試。
  • 最小化冗餘:如何消除不必要的代碼並提高測試可讀性。

讓我們在探索實際解決方案之前解決這些問題。

一種反應組件測試的重點方法

考慮基本的反應組件:

歡迎功能(道具){
  返回<h1 id="你好-props-name">你好,{props.name}</h1> ;
}

此功能接受props並使用JSX返回DOM節點。由於組件本質上是功能,因此測試它們涉及驗證功能行為:參數如何影響返回的結果。對於React組件,這轉化為設置props並驗證渲染的DOM。還需要通過編程觸發來修改UI的用戶交互(單擊,鼠標等)。

增強測試的可讀性:安排效果模式

清晰,可讀的測試至關重要。這是通過簡潔的措辭和一致的結構來實現的。安排效果 - 批准(AAA)模式是理想的:

  1. 安排:準備組件道具。
  2. ACT:渲染組件並觸髮用戶交互。
  3. 斷言:基於組件的標記驗證預期結果。

例子:

它(“應該單擊一個大按鈕”,()=> {
  // 安排
  props.size =“大”;

  // 行為
  const組件=安裝(send);
  仿真(組件,{type:“ click”});

  //斷言
  期望(組件,“要載”,“單擊”);
});

對於更簡單的測試,可以組合階段:

它(“應該用自定義文本渲染”,()=> {
  期望(發​​送,“安裝”,“要具有文本”,“ send”);
});

改善當前測試實踐

以前的示例雖然從概念上講是聽起來,但使用標準工具不容易實現。考慮這種更常見的方法:

 (“應顯示技術視圖”,()=> {
  const容器= document.createelement(“ div”);
  document.body.body.appendchild(容器);

  act(()=> {
    Reactdom.render(<profilecard></profilecard> , 容器);
  });

  const button = container.queryselector(“ button”);

  act(()=> {
    button.dispatchevent(new window.mouseevent(“ click”,{bubbles:true}));
  });

  const詳細信息= container.queryselector(“。詳細信息”);

  期待(lidess.classlist.contains(“ Technologies”))。 tobe(true);
});

將此與更抽象的版本進行比較:

 (“應顯示技術視圖”,()=> {
  const組件=安裝(<profilecard></profilecard> );

  仿真(組件,{type:“ click”,target:“ button”});

  期望(組件,“查詢測試ID”,“詳細信息”,“將類”,“ Technologies”);
});

這更乾淨,更可讀。意外J可以實現這種抽像水平。

用意外J進行測試

意外J是與各種測試框架兼容的可擴展斷言庫。其插件系統和語法簡化了React組件測試。我們將重點介紹用法和示例,而不是深入研究Intirantjs的內部工作。

示例:配置卡組件

我們將測試一個ProfileCard組件(省略了簡短的代碼,但在引用的GitHub存儲庫中可用)。

設置項目

要遵循,請克隆GITHUB存儲庫,然後按照說明設置項目並運行測試。

組件測試

測試(在src/components/ProfileCard/ProfileCard.test.js中)使用AAA模式:

  1. ProP設置:設置beforeEach設置默認道具。
 each(()=> {
  props = {
    數據: {
      名稱:“賈斯汀案”,
      帖子:45,
      CreationDate:“ 01.01.2021”,
    },,
  };
});
  1. 特定的測試用例:示例包括“在線”圖標,生物文本,技術視圖(有和沒有數據)的測試,位置顯示,回調功能執行以及使用默認道具進行渲染。每個測試案例清楚地證明了安排 - 分配模式。 (省略了詳細的測試案例,但可在GitHub儲備庫中使用)。

  2. 運行測試:所有測試均通過yarn test執行。

結論

此示例展示了一種更有效的反應組件測試方法。通過將組件視為功能並採用AAA模式,您可以創建更可維護和可讀的測試。測試庫的選擇應以其有效處理組件渲染和DOM比較的能力來指導;在這方面,意外J是強大的競爭者。探索提供的GitHub存儲庫,以進行完整的理解和進一步的實驗。

以上是人類的反應組件測試的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
使用頁面CMS進行靜態站點內容管理使用頁面CMS進行靜態站點內容管理May 13, 2025 am 09:24 AM

我知道,我知道:有大量的內容管理系統選項可用,而我進行了幾個測試,但實際上沒有一個是一個,y&#039;知道嗎?怪異的定價模型,艱難的自定義,有些甚至最終成為整個&

鏈接HTML中CSS文件的最終指南鏈接HTML中CSS文件的最終指南May 13, 2025 am 12:02 AM

鏈接CSS文件到HTML可以通過在HTML的部分使用元素實現。 1)使用標籤鏈接本地CSS文件。 2)多個CSS文件可通過添加多個標籤實現。 3)外部CSS文件使用絕對URL鏈接,如。 4)確保正確使用文件路徑和CSS文件加載順序,優化性能可使用CSS預處理器合併文件。

CSS Flexbox與網格:全面評論CSS Flexbox與網格:全面評論May 12, 2025 am 12:01 AM

選擇Flexbox還是Grid取決於佈局需求:1)Flexbox適用於一維佈局,如導航欄;2)Grid適合二維佈局,如雜誌式佈局。兩者在項目中可結合使用,提升佈局效果。

如何包括CSS文件:方法和最佳實踐如何包括CSS文件:方法和最佳實踐May 11, 2025 am 12:02 AM

包含CSS文件的最佳方法是使用標籤在HTML的部分引入外部CSS文件。 1.使用標籤引入外部CSS文件,如。 2.對於小型調整,可以使用內聯CSS,但應謹慎使用。 3.大型項目可使用CSS預處理器如Sass或Less,通過@import導入其他CSS文件。 4.為了性能,應合併CSS文件並使用CDN,同時使用工具如CSSNano進行壓縮。

Flexbox vs Grid:我應該學習兩者嗎?Flexbox vs Grid:我應該學習兩者嗎?May 10, 2025 am 12:01 AM

是的,youshouldlearnbothflexboxandgrid.1)flexboxisidealforone-demensional,flexiblelayoutslikenavigationmenus.2)gridexcelstcelsintwo-dimensional,confffferDesignssignssuchasmagagazineLayouts.3)blosebothenHancesSunHanceSlineHancesLayOutflexibilitibilitibilitibilitibilityAnderibilitibilityAndresponScormentilial anderingStruction

軌道力學(或我如何優化CSS KeyFrames動畫)軌道力學(或我如何優化CSS KeyFrames動畫)May 09, 2025 am 09:57 AM

重構自己的代碼看起來是什麼樣的?約翰·瑞亞(John Rhea)挑選了他寫的一個舊的CSS動畫,並介紹了優化它的思維過程。

CSS動畫:很難創建它們嗎?CSS動畫:很難創建它們嗎?May 09, 2025 am 12:03 AM

CSSanimationsarenotinherentlyhardbutrequirepracticeandunderstandingofCSSpropertiesandtimingfunctions.1)Startwithsimpleanimationslikescalingabuttononhoverusingkeyframes.2)Useeasingfunctionslikecubic-bezierfornaturaleffects,suchasabounceanimation.3)For

@KeyFrames CSS:最常用的技巧@KeyFrames CSS:最常用的技巧May 08, 2025 am 12:13 AM

@keyframesispopularduetoitsversatoryand and powerincreatingsmoothcsssanimations.keytricksinclude:1)definingsmoothtransitionsbetnestates,2)使用AnimatingMultatingMultationMultationProperPertiessimultane,3)使用使用4)使用BombingeNtibalibility,4)使用CombanningWiThjavoFofofofoftofofo

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器