Me topé con la charla de Greg Young 7 razones por las cuales fallan los proyectos DDD, donde menciona algo que llama DDD-Lite a las 7:20.
Resumiendo, básicamente dice que algunos usan DDD como lenguajes de patrones (entidades, repositorios, objetos de valor, servicios, etc.) sin hacer nada más relacionado con DDD. Postula que el 60% o más de los modelos de dominio en .Net son DDD-Lite. Él piensa que DDD-Lite básicamente está construyendo un lenguaje en torno a la inyección de dependencia, algo que realmente no necesita hacer. Él dice o hacer DDD por completo o hacer algo más simple. De lo contrario, afirma que una persona está haciendo todo este trabajo para construir buenas abstracciones, pero sin ningún beneficio real.
Debo admitir que no sé tanto sobre DDD como me gustaría, y aún no he tratado de usarlo. Tampoco he leído el libro de Eric Evan tampoco. Estoy mucho más interesado en la inyección de dependencia y muchos, muchos libros y blogs sobre este tema usan términos y conceptos de referencia del libro DDD de Eric Evans. Aquí es donde he estado expuesto a los conceptos DDD. Los libros que he estado leyendo que hacen esto incluyen:
- Inyección de dependencias en .NET
- Microsoft .Net: Arquitectura de aplicaciones para la empresa
- Desarrollo de aplicaciones Brownfield en .NET
Si uno quiere hacer una inyección de dependencia, ¿cuáles son las alternativas más simples en lugar de hacer "DDD-Lite"? Me parece que construir buenas abstracciones es bastante útil, independientemente de si uno está usando conceptos de DDD de una manera "DDD-Lite". (vea las publicaciones de blog de Mark Seemann: Las interfaces no son abstracciones y Hacia mejores abstracciones ). Me cuesta creer que todos los que hacen la inyección de dependencia también estén haciendo (o necesiten hacer) DDD completo. ¿De alguna manera entendí mal el argumento de Greg Young sobre DDD-Lite?