On Wednesday, 5 June 2013 at 13:19:33 UTC, Peter Lundgren wrote:
On Wednesday, 5 June 2013 at 07:17:50 UTC, Jacob Carlborg wrote:
I would suggestion using some kind of wrapper instead of doing true monkey patching. Example:

class Wrapper
{
   private Object o;
   this (Object o) { this.o = o; }

   auto opDispatch (string name, Args ...) (Args args)
   {
// Use this function to "catch" all calls and forward as necessary to "o"
   }
}

http://dlang.org/operatoroverloading.html#Dispatch

That's a reasonable option too. I think I'd rather use deject.

The problem I'm trying to solve (and maybe this isn't as important as I think) is that DMocks or deject + DMocks only works on a subset of the language. I can't mock out free function calls, private or final methods, or functions on structs or unions (can I inject mocked structs using deject?).

What do I do when I want to mock out std.stdio or std.random?

Making mocks work with statical world of D could definitely be done - the language has many useful tools like alias or mixins to do that. I think that substitution here may be a problem. It'd probably be required to use aliases instead of bare types in user code, so types could be fully substituted. Mocking statically linked methods is a similar problem - consider:
MyType a = new Mocker().mock!(MyType );
a.finalMethod()
will call MyType.finalMethod, not Mock!MyType.finalMethod. Using aliases for defining types is a sollution but it requires changes to user code. Maybe deject has a sollution to this problem.

Reply via email to