《Vue.js》公式サイトを参考にテストコードの導入方法を解説

vue

Vue.jsのテスト

使用するテストフレームワーク

vue-test-utilsと呼ばれるテストフレームワークを使用します。Vue.jsの公式サイトにて推奨されているものです。

vuejs/vue-test-utils
🔬 Utilities for testing Vue components. Contribute to vuejs/vue-test-utils development by creating an account on GitHub.

vue-test-utilsはコンポーネントを個々に分離してにマウントして、必要な入力をモックしたり、や出力をアサートしたりすることでテストを行います。

テストコードの概略を解説

テストコードの主要なメソッド

先ほど紹介したgithubに置かれているコードを使いながらテストコードについて解説していきます。まず下のコードがテストをする対象のコンポーネントのコードです。

このコンポーネントはボタンをクリックするとカウンターが1ずつ増えていくものです。次のコードがテストコードです。

まずmountメソッドによってマウントされたcomponentはWrapper内に返されます。このWrapperはVueインスタンスを操作(mainpluating)、トラバース(travers)、クエリ(querying)したりするためのメソッドを公開しています。今回使ったメソッドは以下の4つ

html

string型のhtml要素を返す

contains

指定したhtml要素を返す

find

指定したDOM NodeまたはVueコンポーネントを返す

vm

Vueインスタンスを返す

この指定した要素に対して、出力条件を定義し、テストをしていきます。

Vueのテストを実行してみる

itに該当するテストの名前をつけることができます。以下のコードは<span class=”count”>0</span>が正しくレンダリングされたかどうかを確かめるコードです。

ではnpm testを叩いて上手くいくかどうかをテストしてみましょう。

renders the correct markupの部分にチェックが通ってテストが無事成功していることがわかります。では最後にあえてテストが失敗するようにテストコードを変更してみましょう。

実際のコードの初期値は0ですが、1に変更してテストを実行してみましょう。

renders the correct markupでテストがこけていることが確認できました。

Vue-test-unitsを導入する方法

では実際に自分のVueのプロジェクトで使っているテスト環境構築方法について紹介します。package.jsonに以下の記述を追加します。

次に.babelrcを追加します。

この状態でパッケージをインストールした後、npm run test を叩くとテストをすることができます。

筆者
筆者

Vue.jsの単体テストvue-test-utilsの概要解説は以上です。間違い等がございましたらご指摘していただければ幸いです。

参考サイト

Getting Started | Vue Test Utils
Utilities for testing Vue components

エンジニアにイチ押しアイテム

目の疲労回復グッズ

ディスプレイをずっと見続けた時の目の疲労感ってすごいですよね。血行が悪くなっているというかズーンて重い感じがして、ひどい時は気持ち悪くなったりした経験をもつ人も多いのではないのかと思います。目って今後生きて行く上で非常に大切なものですし、ちゃんとにケアしていきたいものです。そこで私が日常的に使っている目のマッサージアイテムを紹介します。

アイマッサージャー 二年間保証 最新グラフェン加熱技術 目元マッサージャー

私は寝る前必ず使用しています。15分間目を40°で保温&マッサージしてくれて、本当に極楽の時間です。その後は快眠で、翌日の朝の目の疲労度が全くなくなりました。Amazonのレビューがこの商品の良さを物語っています。

筆者
筆者
303件レビューがついてて、評価が4.7と購入した方の殆どが「非常に満足」しているコスパ最強!超オススメのアイテムです!

コスパ最強20㎏×2ダンベル

実は筋トレって記憶力を向上させる効果があるんです。米国のジョージア工科大学が筋トレを20分間行なうと、記憶力が10%ほど向上するこという研究結果を最近発表したほどです。私はここのところ、老化からか体型が崩れてきたのに危機感を覚え購入。実際に筋トレしてみると筋トレ後のすっきり感がやばい。勉強の集中力も確かに上がるような気がしました。また、腕立てとかじゃ鍛えにくい肩なんかもパンパンになるので、男らしい体型を手に入れたいなと少しでも思っている人は買うべきアイテムだと思います。中でも以下のダンベルはAmazon内での評価が非常に高いので迷ったらこれを買いましょう。

ダンベル 【最新進化版・3in1】Wolfyok 純鋼製アレー アレイ 20kgセット(10kgx2) 30kgセット(15kgx2)
筆者
筆者
マシンを使って筋トレすると自重の筋トレ系、腕立て・腹筋・背筋が だいぶ楽になるので習慣化しました!また積極的にランニングしたり食生活を気に掛けるようになるので購入することをお勧めします! (体験談)

座椅子DIYで疲労防止

長い間椅子に座って作業することはエンジニア、理系学生にとってはつきものだと思います。ですが、この椅子の性能によって作業後の疲労感が全く異なるということを意識したことがありますか?私は以下の2つのアイテムを使って座椅子をゲーミングチェア並みにアップデートしました。おかげで姿勢が安定し、作業後の疲労感も減りました。また何より集中して作業に打ち込めるようになりました。

IKSTAR クッション 低反発 座布団 第五世代 オフィス IKSTAR クッション 低反発【メーカー直営・1年保証付】 ランバーサポート
筆者
筆者
座椅子にホールド感が出て、座り心地が格段に向上します。長時間座っていても疲れにくくなるので引きこもりにならないように注意しましょう!作業に夢中で1日中座りっぱなしだった経験があるので...

コードの可読性を高める

自分が大型ベンチャーの内定インターンに初めて参加した時、周りの超優秀なエンジニアの方々のコードをみて自分のコードの汚さに絶望しました。その時自分のマネージャーに勧められた本がリーダブルコード ―より良いコードを書くためのシンプルで実践的なテクニックという超有名な一冊です。美しいコードを書くためのエッセンスが凝縮されています。エンジニアを職種として選ぶ方は読まない理由がない一冊です。自分もこの本を読んで、かなりコーディングスキルが向上したと感じています。

ネットワークの基礎を押さえる本

ITの基礎がおぼつかなくて、ネットワークの話についていけなかった時、早稲田大学のエンジニアの友人が勧めてくれたのがネットワークはなぜつながるのか 第2版 という本です。ハードウエアから、理論までネットワークの基礎が非常にわかりやすく解説されています。「TCP」「IP」「リゾルバ」という用語を説明できないエンジニアは間違いなく買ったほうがいいです。自分は知らなくてバカにされたので。笑

タイトルとURLをコピーしました