React 16 Jest ES6級(jí)模擬 - 監(jiān)視并監(jiān)視模擬情況

轉(zhuǎn)載地址

React 16 Jest ES6級(jí)模擬 - 監(jiān)視并監(jiān)視模擬情況

項(xiàng)目初始化

git clone https://github.com/durban89/webpack4-react16-reactrouter-demo.git 
cd webpack4-react16-reactrouter-demo
git fetch origin
git checkout v_1.0.32
npm install

ES6 Class Mocks(使用ES6語(yǔ)法類的模擬)

Jest可用于模擬導(dǎo)入到要測(cè)試的文件中的ES6語(yǔ)法的類惕它。

ES6語(yǔ)法的類是具有一些語(yǔ)法糖的構(gòu)造函數(shù)富岳。因此冰抢,ES6語(yǔ)法的類的任何模擬都必須是函數(shù)或?qū)嶋H的ES6語(yǔ)法的類(這也是另一個(gè)函數(shù))。
所以可以使用模擬函數(shù)來(lái)模擬它們达址。如下

跟蹤使用情況(監(jiān)視模擬)(Keeping track of usage (spying on the mock))

注入測(cè)試實(shí)現(xiàn)很有幫助卓研,但我們可能還想測(cè)試是否使用正確的參數(shù)調(diào)用類構(gòu)造函數(shù)和方法。

監(jiān)視構(gòu)造函數(shù)(Spying on the constructor)

為了跟蹤對(duì)構(gòu)造函數(shù)的調(diào)用歇式,用一個(gè)Jest模擬函數(shù)替換HOF返回的函數(shù)。
使用jest.fn()創(chuàng)建它胡野,然后使用mockImplementation()指定它的實(shí)現(xiàn)材失。如下

import SoundPlayer from '../lib/sound-player';
jest.mock('../lib/sound-player', () => {
  // 檢查構(gòu)造函數(shù)的調(diào)用
  return jest.fn().mockImplementation(() => {
    return {
      choicePlaySoundFile: () => {},
      playSoundFile: () => {},
    };
  });
});

我們使用SoundPlayer.mock.calls來(lái)檢查我們的模擬類的用法:expect(SoundPlayer).toHaveBeenCalled();
或接近等價(jià)的:expect(SoundPlayer.mock.calls.length).toEqual(1);

監(jiān)視類的方法(Spying on methods of our class)

我們的模擬類需要提供將在測(cè)試期間調(diào)用的任何成員函數(shù)(示例中為playSoundFile),否則我們將因調(diào)用不存在的函數(shù)而出錯(cuò)硫豆。
但是我們可能也希望監(jiān)視對(duì)這些方法的調(diào)用龙巨,以確保使用預(yù)期的參數(shù)調(diào)用它們。

每次在測(cè)試期間調(diào)用模擬構(gòu)造函數(shù)時(shí)熊响,都會(huì)創(chuàng)建一個(gè)新對(duì)象旨别。
為了監(jiān)視所有這些對(duì)象中的方法調(diào)用,我們使用另一個(gè)mock函數(shù)填充playSoundFile汗茄,并在我們的測(cè)試文件中存儲(chǔ)對(duì)同一個(gè)mock函數(shù)的引用秸弛,因此它在測(cè)試期間可用。

import SoundPlayer from '../lib/sound-player';
const mockPlaySoundFile = jest.fn();
const mockChoicePlaySoundFile = jest.fn();
jest.mock('../lib/sound-player', () => {
  return jest.fn().mockImplementation(() => {
    return {
      choicePlaySoundFile: mockChoicePlaySoundFile,
      playSoundFile: mockPlaySoundFile,
    };
  });
});

手動(dòng)模擬等效于此:

export const mockChoicePlaySoundFile = jest.fn();
const mockPlaySoundFile = jest.fn();

const mock = jest.fn().mockImplementation(() => {
  const data = {
    choicePlaySoundFile: mockChoicePlaySoundFile,
    playSoundFile: mockPlaySoundFile,
  };

  return data;
});

export default mock;

用法類似于模塊工廠函數(shù)洪碳,除了可以省略jest.mock()中的第二個(gè)參數(shù)胆屿,并且必須將模擬方法導(dǎo)入到測(cè)試文件中,因?yàn)樗辉僭谀抢锒x偶宫。
使用原始模塊路徑;
不包括mocks

在測(cè)試之間進(jìn)行清理(Cleaning up between tests)

要清除對(duì)mock構(gòu)造函數(shù)及其方法的調(diào)用記錄非迹,我們?cè)赽eforeEach()函數(shù)中調(diào)用mockClear():

前面的文章分別做了4個(gè)實(shí)例,分別是下面四個(gè)文件,可以自己打開項(xiàng)目去具體看下,這里就不在展示了

src/__tests/jest_sound_player.test.js
src/__tests/jest_sound_player_2.test.js
src/__tests/jest_sound_player_3.test.js
src/__tests/jest_sound_player_4.test.js

實(shí)踐項(xiàng)目地址

git clone https://github.com/durban89/webpack4-react16-reactrouter-demo.git
git checkout v_1.0.32
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末纯趋,一起剝皮案震驚了整個(gè)濱河市憎兽,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌吵冒,老刑警劉巖纯命,帶你破解...
    沈念sama閱讀 218,036評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異痹栖,居然都是意外死亡亿汞,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門揪阿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)疗我,“玉大人,你說(shuō)我怎么就攤上這事南捂∥饪悖” “怎么了?”我有些...
    開封第一講書人閱讀 164,411評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵溺健,是天一觀的道長(zhǎng)麦牺。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么剖膳? 我笑而不...
    開封第一講書人閱讀 58,622評(píng)論 1 293
  • 正文 為了忘掉前任魏颓,我火速辦了婚禮,結(jié)果婚禮上吱晒,老公的妹妹穿的比我還像新娘甸饱。我一直安慰自己,他們只是感情好枕荞,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評(píng)論 6 392
  • 文/花漫 我一把揭開白布柜候。 她就那樣靜靜地躺著,像睡著了一般躏精。 火紅的嫁衣襯著肌膚如雪渣刷。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,521評(píng)論 1 304
  • 那天矗烛,我揣著相機(jī)與錄音辅柴,去河邊找鬼。 笑死瞭吃,一個(gè)胖子當(dāng)著我的面吹牛碌嘀,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播歪架,決...
    沈念sama閱讀 40,288評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼股冗,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了和蚪?” 一聲冷哼從身側(cè)響起止状,我...
    開封第一講書人閱讀 39,200評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎攒霹,沒(méi)想到半個(gè)月后怯疤,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,644評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡催束,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評(píng)論 3 336
  • 正文 我和宋清朗相戀三年集峦,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片抠刺。...
    茶點(diǎn)故事閱讀 39,953評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡塔淤,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出矫付,到底是詐尸還是另有隱情凯沪,我是刑警寧澤,帶...
    沈念sama閱讀 35,673評(píng)論 5 346
  • 正文 年R本政府宣布买优,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏杀赢。R本人自食惡果不足惜烘跺,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望脂崔。 院中可真熱鬧滤淳,春花似錦、人聲如沸砌左。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)汇歹。三九已至屁擅,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間产弹,已是汗流浹背派歌。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留痰哨,地道東北人胶果。 一個(gè)月前我還...
    沈念sama閱讀 48,119評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像斤斧,于是被迫代替她去往敵國(guó)和親早抠。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容