搜尋
首頁web前端css教學測試用酶和反應測試庫的反應鉤子

測試用酶和反應測試庫的反應鉤子

用鉤子構建強大的反應應用需要嚴格的測試。本教程演示瞭如何使用酶和反應測試庫有效測試鉤子,並利用待辦事項應用程序示例。我們將介紹關鍵的測試方案和最佳實踐,以確保無錯誤的代碼。

本指南熟悉開玩笑和反應測試基本面。如果您不熟悉酶,請考慮在進行之前與JEST在React應用程序中的JEST集成。

測試方案

我們的待辦事項組件將在這些情況下進行測試:

  1. 組件渲染:驗證組件成功渲染。
  2. 初始待辦事項顯示:確認初始待辦事項項目已正確顯示。
  3. 添加一個新的工作:測試添加新項目的功能。
  4. 刪除待辦事項:驗證刪除待辦事項的能力。

這是待辦事項組件:

導入React,{usestate,useref}來自“ React”;

const todo =()=> {
  const [todos,settodos] = usestate([
    {id:1,項目:“ fix bugs”},
    {id:2,項目:“取出垃圾”}
  );
  const todoref = useref();
  const removetodo = id => {
    settodos(todos.filter(todo => todo.id!== id));
  };
  const addtodo = data => {
    令ID = todos.length 1;
    settodos([[
      ... todos,
      {
        ID,
        項目:數據
      }
    );
  };
  const handlenewtodo = e => {
    e.preventDefault();
    const item = todoref.current;
    addtodo(item.Value);
    item.value =“”;
  };
  返回 (
    <div classname="container"> {/ *校正的className to className */}
      <div classname="row"> {/ *校正的className to className */}
        <div classname="col-md-6"> {/ *校正的className to className */}
          <h2 id="添加todo">添加todo</h2>
        </div>
      </div>

      <div classname="row"> {/ *校正的className to className */}
        <div classname="col-md-6"> {/ *校正的className to className */}
          <form onsubmit="{handleNewTodo}"> {/ *添加了表格標籤 */}
            <input type="text" ref="{todoRef}" data-testid="input"> {/ *添加了數據測驗 */}
            <button type="submit" data-testid="add-button">添加任務</button>{/ *添加了數據測驗 */}
          </form>
        </div>
      </div>

      <div classname="row todo-list"> {/ *校正的className to className */}
        <div classname="col-md-6"> {/ *校正的className to className */}
          <h3 id="列表">列表</h3>
          {! todos.length? ((
            <div classname="no-task">沒有任務!</div>
          ):((
            <ul data-testid="todos"> {/ *添加了數據測驗 */}
              {todos.map(todo => {
                返回 (
                  <li key="{todo.id}"> {/ *更正的鑰匙值 */}
                    <div>
                      {todo.item}
                      <button data-testid="delete-button" onclick="{()"> removetodo(todo.id)}> x</button> {/ *添加了數據測驗和onClick */}
                    </div>
                  </li>
                );
              })}}
            </ul>
          )
        </div>
      </div>
    </div>
  );
};

導出默認todo;

注意: classname屬性已糾正到上述代碼中的className 。同樣,已經添加了data-testid屬性,以便使用React測試庫更容易測試。

用酶進行測試

  1. 安裝: npm install --save-dev enzyme enzyme-adapter-react-16
  2. 酶配置(setUptests.js):
從“酶”進口酶;
從“酶 - 適應器反應16”中進口適配器;
emzyme.configure({Adapter:new Adapter()});
  1. 測試(todo.test.js):
從“反應”中導入反應;
從“酶”導入{淺,山};
從“ ../ todo”導入todo;

描述(“ todo”,()=> {
  它(“ renders”,()=> {
    淺的(<todo></todo> );
  });

  它(“顯示初始待辦事項”,()=> {
    const包裝器=安裝(<todo></todo> );
    期待(wrapper.find(“ li”))。
  });

  它(“添加一個新項目”,()=> {
    const包裝器=安裝(<todo></todo> );
    wrapper.find(“ input”)。 instance()。 value =“修復失敗測試”;
    wrapper.find('[type =“ submit”]')。仿真(“ submit”); //模擬提交,而不是點擊
    期待(wrapper.find(“ li”))。
    期待(wrapper.find(“ li”)。last()。text()。tocontain(“修復失敗的測試”); //改善斷言
  });

  它(“刪除項目”,()=> {
    const包裝器=安裝(<todo></todo> );
    wrapper.find('[data-testid =“ delete-button”]')。 first()。仿真(“ click”);
    期待(wrapper.find(“ li”))。
  });
});

用React測試庫進行測試

  1. 安裝: npm install --save-dev @testing-library/jest-dom @testing-library/react
  2. 測試(todo.test.js):
從“反應”中導入反應;
從“@testing-library/react”中導入{渲染,fireevent,屏幕};
從“ ../ todo”導入todo;
導入“@testing-library/jest-dom”;

描述(“ todo”,()=> {
  它(“顯示初始待辦事項”,()=> {
    使成為(<todo></todo> );
    期望(screet.getByTestId(“ todos”)。兒童。lengtth).tobe(2);
  });

  (“添加一個新的to-do”,()=> {
    使成為(<todo></todo> );
    fireevent.change(screen.getByTestId(“ input”),{target:{value:“ new Task”});
    fireevent.click(screen.getByTestId(“ add-button”));
    期待(screet.getByTestId(“ todos”)。兒童。長度).tobe(3);
  });

  它(“刪除to-do”,()=> {
    使成為(<todo></todo> );
    fireevent.click(screet.getAllByTestId(“ delete-button”)[0]);
    期待(screet.getByTestId(“ todos”)。兒童。
  });
});

請記住,根據需要調整項目結構的文件路徑。此改進的版本提供了更健壯和可維護的測試。使用data-testid使測試對組件結構的變化更具彈性。

以上是測試用酶和反應測試庫的反應鉤子的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
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

CSS計數器:自動編號的綜合指南CSS計數器:自動編號的綜合指南May 07, 2025 pm 03:45 PM

CSSCOUNTERSAREDOMANAGEAUTOMANAMBERINGINWEBDESIGNS.1)他們可以使用forterablesofcontents,ListItems,and customnumbering.2)AdvancedsincludenestednumberingSystems.3)挑戰挑戰InclassINCludeBrowsEccerCerceribaliblesibility andperformiballibility andperformissises.4)創造性

使用捲軸驅動動畫的現代滾動陰影使用捲軸驅動動畫的現代滾動陰影May 07, 2025 am 10:34 AM

使用滾動陰影,尤其是對於移動設備,是克里斯以前涵蓋的一個微妙的UX。傑夫(Geoff)涵蓋了一種使用動畫限制屬性的新方法。這是另一種方式。

重新訪問圖像圖重新訪問圖像圖May 07, 2025 am 09:40 AM

讓我們快速進修。圖像地圖一直返回到HTML 3.2,首先是服務器端地圖,然後使用映射和區域元素通過圖像上的單擊區域定義了可單擊區域。

DEV狀態:每個開發人員的調查DEV狀態:每個開發人員的調查May 07, 2025 am 09:30 AM

開發委員會調查現已開始參與,並且與以前的調查不同,它涵蓋了除法:職業,工作場所,以及健康,愛好等。 

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

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

熱工具

SecLists

SecLists

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

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具