私はあなたが実際にこれをしたくないのではないかと思います(PHPUnitのモックビルダーでコンストラクターなどを無効にすることができるので、ドキュメントを参照してください)が、あなたが望むか必要であると仮定すると、これはトリックを行うはずです:
$foo = $this->getMockBuilder('nonexistant')
->setMockClassName('foo')
->setMethods(array('bar'))
->getMock();
var_dump(class_exists('foo', false));
var_dump(method_exists('foo', 'bar'));
var_dump(method_exists($foo, 'bar'));
$cls = new ReflectionClass('foo');
var_dump($cls->hasMethod('bar'));
上記で異なる名前(存在しない名前とfoo)を指定する必要がある理由の詳細については正直にわかりませんが、モックされているクラスがまだ存在しない場合のPHPUnitの動作に関係しているようで、setMockClassNameにそのクラスを拡張するクラス。か何か。おそらくバグ/エッジケースを効果的に回避しています-これはライブラリの奇妙な使用法です。あなたは関数だけで同じことをすることができるはずですgetMock
、それはただ醜いです。
余談ですが、おそらくphpのリフレクション機能に精通している必要があるようです。これは、世の中で最も強力なリフレクションライブラリではありませんが、かなり優れています。これを使用して、コンストラクター引数と「モデル」ライブラリのプロパティに基づいてクラスの必須フィールドとオプションフィールドに関するメタ情報を生成しました。このメタ情報は、正しいタイプの値を受け入れるフォームを生成するために使用されます。つまり、フォームの対象となるクラスのインスタンスを使用せずに、ばかげた量のコードを手書きせずに型付きフォームを生成します。これは、機能全体で合計約100行です。明らかに、あなたが何をしようとしているのかわかりませんが、あなたの投稿の少量の情報から、それはそうでないよりもそのタイプのメタに近いと思います。