Once you’ve sourced a pool of candidates, thoroughly vet their qualifications before moving forward.
Start by asking for code samples of previous Solidity projects they have worked on. 
GitHub repos or snippets from current work can give you a good sense of their grasp over syntax, structure, security practices, design patterns, and more. If the candidate has limited public samples due to NDA restrictions, consider providing a small paid test assignment for them to complete.
Additionally, technical screening calls and interviews should include Solidity coding challenges relevant to what your dApp requires. Test their skills in areas like:
- smart contract functions and state variables;
- interacting with contracts via Web3;
- understanding gas optimization;
- access control with function modifiers;
- handling transactions and events;
- inheritance and interfaces;
- cryptographic best practices;
- unit testing contracts.
Be wary of developers who can talk the blockchain talk but struggle with actual Solidity coding challenges. Finally, do conduct thorough background checks and contact references to confirm claimed experience levels align with demonstrated skills.