*

単体テストの効率化を考える(3)-スタブの引数

公開日: : 最終更新日:2020/05/10 徒然, 開発

どもです。

「単体テストの効率化について考える」の3回目です。
1回目、2回目はコチラ:
単体テストの効率化を考える(1)-はじめに
単体テストの効率化を考える(2)-スタブの戻り値

1.振り返り

前回から、

  • スタブを自動生成して単体テストを効率化するために、スタブで行うべき処理について考える。

というテーマについて考えたことを書いています。
前回のエントリでは、関数/引数の戻り値に着目し、

  • スタブでは、呼び出し回数をカウントする。
  • 戻り値がある関数のスタブは、返す値を設定しておくバッファを配列で用意しておく。
  • 戻り値がある関数のスタブは、呼び出される度に配列から値を取得し、それを返す。

という結論になりました。
今回は、「関数の引数」について考えます。

2.関数の引数

関数の引数、特に組み込み開発で使用されるC言語では、関数の引数は「値を渡す」(値渡し)場合とポインタにより「アドレスを渡す」(アドレス渡し)場合があります。
それぞれの「渡し方」に対してスタブで行うべき処理、実装は異なってくると思います。
そのため、それぞれの場合についてスタブで行うべき処理、実装を検討していきます。

2.1.値渡し

値渡しの場合は、実にシンプルです。
バッファを用意して、引数を代入/コピーして保持しておくのがよいと考えています。
実際のコードは、下記のようになるかと思います。

少し解説すると、最初にバッファ(FuncArg_arg)に値をコピーし、その後に呼び出し回数をインクリメントしています。
この順番で処理を行わないと、引数が正しい順番でバッファに代入/保持がされません。
※処理順を逆にした場合、例えば1回目の呼び出された場合でも、バッファ(FuncArg_arg)の先頭ではなく、2番目に引数の値が代入されます。

2.2.アドレス渡し

アドレス渡し、即ち引数がポインタの場合は、注意すべき点があります。
それは、引数が「入力」なのか「出力」なのか、です。
引数のポインタが「出力」の場合、ポインタの実体に値を設定することで何らかの結果の値を呼び出し元関数に返します。
スタブでは、この「出力」する処理を代替するように実装する必要があります。
これが、「注意すべき点」です。

2.2.1.入力の場合

引数がポインタでも、それが入力の場合は、特に問題がありません。
「値渡し」の場合と同様の処理を行えばよいです。
即ち、スタブの実装は下記の様になるかと思います。

2.2.2.出力の場合

関数が、ポインタを介して(戻り値以外で)値を返す場合です。
この場合、スタブで行うべき処理、実装は「入力」の場合よりも考える必要があるかと思います。
即ち、

  • 引数で渡されたアドレスの保持
  • 出力する値の代入(設定)

の両方の処理、実装が必要になります。
スタブは、下記のように実装することで解決/対応ができると思います。

しかしこの処理、実装では少し問題があります。
上記のスタブで対応できるのは、引数のポインタが指す先が配列ではない場合のみです。
ポインタが配列を指す場合、上記の実装で対応できるのは配列の先頭の値を書き換える場合のみです。
配列の2番目以降の値を書き換える必要がある場合は、上記の方法では対応ができません。
ポインタが配列を指す、かつ配列の先頭以外を書き換える場合には、スタブの処理を以下のように実装することで、対応ができるかと思います。

この例では、先頭から4コ分のデータを連続して引数に代入しています。
実際に何個分のデータをコピーするかについては、適宜変更するのがよいかと思います。
(自動化の際には、別途設定できるようにする…?)

3.続く!!

おなじみですが、長くなってきたので、今回のエントリはこの辺りで終了します。

今回のエントリでは、自動生成するスタブでの引数に対する処理について考えてみました。
結論ですが、

  • ポインタではない場合には、渡された値をそのまま代入/保持するためのバッファを用意する。
  • ポインタの場合は、「入力」であれば渡されたアドレスを代入/保持するためのバッファを用意する。
  • ポインタでありかつ「出力」の場合には、ポインタの実体に設定する値を保持するバッファを用意する。
  • ポインタでありかつ「出力」の場合には、呼び出される度に、用意したバッファの値をポインタの実体に代入して値を返す。
  • ポインタでありかつ「出力」かつポインタが「配列」を指す場合には、用意するバッファは2次元配列がよい。
    (ただし、自動化の際には工夫が必要。)

です。
次回も、引き続きスタブの引数、特にダブルポインタについて書きます。

ではっ!

続きはコチラ

単体テストの効率化を考える(4)-スタブの引数(ダブルポインタ)
単体テストの効率化を考える(5)-スタブの自動生成への入力
単体テストの効率化を考える(6)-スタブの自動生成ツール

関連記事

no image

QtでRaspberryPi/GUI開発(3):ためしに時計を作ってみた(其の参)-StyleSheetの適用

どもです。 前回のエントリーでは、グループ化されたボタンに対するイベントハンドラについて書きました

記事を読む

iot_at_home_eye_catch

IoT開発(1)-ESP-WROOM-02のセットアップ

どもです。 前回までのエントリで、「DHT11の測定結果をクラウドで見える化する」という内容を書い

記事を読む

no image

自宅で電子工作(1):ブレッドボードでの配線を省略する

どもです。 突然ですが、電子工作を始めてみました。 1.背景 これまで、Raspber

記事を読む

no image

PC自作2019 – Windows10への移行

どもです。 突然ですが、PCを交換しました。 1. 何があった!? これまで自作PC(

記事を読む

no image

C言語でEV3開発(12)-opOUTPUT_TIME_POWERコマンド

どもです。 今回のエントリーでは、これまた前回に引き続き、モーターを動かすためのコマンドについて書

記事を読む

Arduino_Logo

1台のarduinno nanoで割込みとSPIの同時使用

どもです。 先日手に入れたArduino nano(中華)で遊んでいます。 今回、この1台のAr

記事を読む

iot_raspberrypi_gateway_001_eye_catch

IoT開発(7)
RaspberryPiをIoTゲートウェイにする(II)
VM上の開発環境にWEBサーバーをインストール

どもです。 このエントリは、前回の続きです。 今回は、前回のエントリで作成したVM上のRaspb

記事を読む

eclipse_cdt_top_100

C言語でEV3開発(3)

どもです。 今回のエントリーの内容は、前回まででセットアップした環境で、実際にEV3上で動く実行フ

記事を読む

MindStormControl_SprachScreen

EV3開発サポートツール(2)-C#のユーザーコントロール開発(2つ目)

どもです。 前回に引き続き、今回もC#/WPFでの独自UI(ユーザーコントロール)の作成についての

記事を読む

raspberry-pi

RaspberryPi3を購入しました

どもです。 突然ですが、「Raspberry Pi3 model B」を購入しました。 今回のエ

記事を読む

Message

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

CAPTCHA


次のHTML タグと属性が使えます: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code class="" title="" data-url=""> <del datetime=""> <em> <i> <q cite=""> <strike> <strong> <pre class="" title="" data-url=""> <span class="" title="" data-url="">

arduino_relay_switch_002_ae_g5v_drv_eye_catch
Arduinoでリレースイッチ(2)-AE-G5V-DRV

どもです。 前回の記事では、「フォトカプラリレー」を使用したLチ

tlp222af_001_eye_catch
Arduinoでリレースイッチ(1)-TLP222AF

どもです。 つい先日、やっとのことでリレースイッチを手に入れるこ

c_sharp_eye_catch
外部からMariaDbにアクセスする(2)-C#からMariaDbにアクセスする。

どもです。 前回のエントリで、外部からMariaDbにアクセスす

c_sharp_eye_catch
外部からMariaDbにアクセスする(1)-データベースの設定

どもです。 今回は、Linux上のMariaDbにWindows

think_about_utest
middle_unit
最小…よりも(ほんの)少し大きいテストフレームワーク

どもです。 今回は、単体テストのフレームワークについて書きます。

→もっと見る

PAGE TOP ↑