Mohitt Chopra’s Post

Day 17. I stopped using @Autowired. Not because it doesn’t work. Because it hides problems. I used to write this: @Autowired private UserService userService; Every tutorial does it. It works. Until you try to test it. Then you realize: → You can’t see dependencies clearly → You need Spring context just to run tests → Your class is tightly coupled That’s when it clicked. The issue isn’t @Autowired. The issue is hidden dependencies. So I switched to this: (see implementation below 👇) Constructor injection. Dependencies are explicit. Your class is honest. Testing becomes simple. The hard truth: → @Autowired works — that’s why everyone uses it → Constructor injection scales — that’s why senior devs prefer it → The difference shows up when your code grows Writing code that runs is easy. Writing code that is testable and maintainable is what makes you a backend developer. Are you still using @Autowired? 👇 Drop it below #SpringBoot #Java #BackendDevelopment #CleanCode #JavaDeveloper

  • No alternative text description for this image

Hot take: If your class needs Spring to be tested, your design is already wrong. Constructor injection forces clarity. Field injection hides it. Are you writing unit tests without Spring context? 👇

To view or add a comment, sign in

Explore content categories