*

単体テストの効率化を考える(4)-スタブの引数(ダブルポインタ)

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

どもです。

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

1.振り返り

前々回から、

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

というテーマで、考えたことを書いています。
前回のエントリでは、関数の引数に着目し、ポインタか否か、ポインタの場合には「入力」か「出力」か毎にスタブでの処理、実装について考えました。
その結果、

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

という結論になりました。
そして今回は前回に引き続き、「関数の引数」について考えます。
特に、「ダブルポインタ」について考えます。

2.ダブルポインタとは?

「そもそも」です。
「ダブルポインタ」とは何か。
それは、「ポインタへのポインタ」です。
それでは、「ポインタへのポインタ」とは何か。
言葉にすると長くなってしまうので、簡単ですが絵にして説明します。
think_about_unit_test_004_01
この絵について解説すると、変数aがPCのメモリ上のどこか(絵の中では、0x000004D6というアドレスの場所)に確保されています。
そこには、値「0x68」がセットされています。
また、別の変数bがメモリ上のどこか(絵の中では0x00002720)に確保されています。
変数bの値には、「0x000004D6」がセットされています。
この値は、変数aの値が格納されている場所の「アドレス」になります。
コレがポインタであり、「メモリ上のアドレスを格納する変数」です。
そしてさらに別の変数cがメモリ上のどこか(絵の中では0x00002774)に確保されています。
この変数cは、値「0x00002720」がセットされています。
これは変数bのアドレスであり、即ち変数cが「ポインタへのポインタ」です。
簡単だが、この関係を確認するためのサンプルプログラムが下記です。

実行すると、次のような結果が得られます。

絵の中に書かれたアドレスは、上記プログラムの実行結果とは一致しませんが、意味しているものは同じです。

3.引数がダブルポインタの場合

では、関数の引数をダブルポインタにする場合は、どのような場合か?
(基本的には)何某かの値/領域のアドレスを関数から取得したい場合に、引数にダブルポインタが使用されます。
例えば、以下のようなコードになります。

上記コードをビルド、実行すると下記の結果が得られました。

4.引数がダブルポインタの場合のスタブ

前項まで、引数をダブルポインタにするのはどのような場合か、またどのような動作をするかがこれでわかりました。
それではやっと本題である、「スタブでのダブルポインタの引数への処理、実装」について考えます。

ここまで書いてきた内容から、ダブルポインタの変数が使用される場面は分かってきました。
そこから考えられる、ダブルポインタの変数に対してスタブが行うべき処理は、以下のことが考えられます。

  • ダブルポインタに格納された値の保持
  • ダブルポインタに別のポインタの値(アドレス)を設定する

具体的なスタブの実装、処理は下記のようになるかと思います。

この例では、ダブルポインタに設定されるアドレスのために、予め2次元配列を用意しています。
そして、スタブが実行される度に2次元配列の別の領域のアドレスがダブルポインタにセットされます。

関数の呼び出し元で返された領域の値を参照している場合には、事前にバッファ(上記の例では、「DoublePointer_arg_value」)に予め値をセットしておけば、対応ができます。

5.まとめ

今回のエントリでは、関数の引数にダブルポインタを持つ場合、その関数のスタブでのダブルポインタに対する処理を考えてみました。
結論ですが、

  • ダブルポインタに格納された値を保持する
  • ダブルポインタには、予め用意しておいたバッファへのアドレスを設定する。
  • ダブルポインタに設定する値は、スタブが複数回呼ばれた場合に備えて2次元配列にする。

です。

さて。
これまで4回にわたって

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

について考えてきました。
この4回のエントリの中で、「スタブで行うべき処理」については分かってきました。
そこで、次回からは(やっと?とうとう?)スタブの自動生成に入ります。

ではっ!

続きはコチラ

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

関連記事

no image

C言語でEV3開発(8)-opOUTPUT_POWERコマンド

どもです。 今回のエントリーでは、EV3でモーターを動かします。 なお、今回のエントリーでも

記事を読む

GitHub

C/C++のスタブを自動生成するツールを公開しました

どもです。 突然ですが、C/C++の単体テストで使用する「スタブ」を自動で生成するツールを公開

記事を読む

MY_MFC_LOGO

MFCプログラミング(2):コピー機能の実装

どもです。 前回に引き続き、今回もMFCネタです。 内容は、MFCでの「クリップボードへのデータ

記事を読む

raspberry-pi

ライブラリでRasPiのピンにアクセス(2)-SPIのインターフェース追加

どもです。 前回のエントリでは、RaspberryPiのピンをより簡便に使用できるようにするた

記事を読む

eclipse_4.3_kepler

elicpse/CDTでのgdbでのソースを追従したデバッグができない問題

どもです。 今回のエントリーは、Eclipse上でgdbを利用したデバッグ中に発生する問題について

記事を読む

GitHub

GitHubのFreeプランでのPrivate Repository数が無制限になったので試してみた

どもです。 年明けに、「おっ♪」と思うようなニュースがありました。 それが 「GitHubのF

記事を読む

Splash

EV3開発サポートツール(3)-Ev3Controller

どもです。 今回は、以前ちらりと紹介した、Ev3のモーターの出力を調整するアプリケーションについて

記事を読む

iot_at_home_eye_catch

IoT開発(3)-ESP-WROOM-02でデータを送信

どもです。 この記事は、IoT開発(1)-ESP-WROOM-02のセットアップ、IoT開発(

記事を読む

RasPi_Qt

QtでRaspberryPi/GUI開発(8):pigpioを使用したチャタリング対策の問題の対策

どもです。 だいぶ、間が空いてしまいました。 久しぶりの更新です。 前回のエントリーで、「

記事を読む

cygwin_my_image

cygwinでstartコマンド

どもです。 このエントリでは、cygwinでWindows/コマンドプロンプトの「start」

記事を読む

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 ↑