Nowadays, having a mobile application seems like a must in many industries. It allows for much more closer contact with clients, engaging them on many levels and responding to their needs almost as soon as they occur.
However, many companies that plan to build an application do not sufficiently know and understand what building an app actually entails. But more importantly, they don’t realize how far has technology in that matter has come in recent years.
Since cross-platform development came into existence, it made building mobile applications easier, faster, and more accessible in almost every domain.
Because almost everyone uses at least a few applications to handle daily business, acquire information, do shopping, communication, etc., technology must continuously look for (and find) increasingly easy ways of building these applications to answer the ever-changing trends.
One of these technologies is React Native, with the growing popularity and many possibilities.
React Native means:
- Faster mobile development
- Building applications on Android and iOS with one codebase
- Vast possibilities of implementing ready-to-use solutions
- Quality for much less money
- On-demand support from massive community
- And much more
The questions remain:
- How to start?
- What do I need?
- Where to start to plan the development process?
- How long will it take?
- How much will it cost?
- And more
So now, let’s say you do like React Native, and you decided to hire React Native agency for your next mobile project. You are looking for an experienced agency that will help you with the development process from top to bottom, 360, and help you understand what’s important on each stage and step you will make.
What we recommend you to do is to have face-to-face interviews with them.
Let’s go over a few points that will help you to better prepare for such an interview.
How to run an interview with React Native agency?
An interview is an essential part while hiring the agency. It will help you fill in the blanks and decide whether they are trustworthy and knowledgeable or not. However, you will get much more out of such an interview if you will get yourself prepared. Otherwise, such a meeting could become a huge waste of time for both sides.
You can follow our five-step list to prepare for such an interview.
Step 1: Specify needs and budget.
What features and functionalities do you want your application to have? It might be a great idea to note down all of them in order of importance. This way, you will make sure that you won’t miss anything crucial in turning your idea into a working product.
It will also help you with staying on budget while building at least the MVP of your application. And specifying a budget is the next thing for you to do after identifying the needs. Be aware that you might have to spend more money than you predicted or wanted to if the project is complex or due to users’ feedback or ideas that emerged during the ideation phase.
However, a good agency will give you at least a ballpark estimate (or, in some cases, even a fixed price) during an interview. If the project is complex, be prepared for other options like time-and-material. It will give you many flexible possibilities.
Be aware that your budget may not cover implementing all the features and functionalities you wanted in the first place. To deal with this situation, you can either create a prototype (or MVP) or rethink the to-do list and remove some points for now.
Step 2: Check the React Native agency’s website.
Treat the agency’s website like their bigger business card with all crucial information instead of just contact details. While browsing through such a website, focus on:
- Agency’s specialisation – the best-case scenario is that it’s React Native agency. It might indicate they know what they are doing. However, don’t let it be a deciding factor – even if it’s not written with big letters on a home page, it doesn’t mean the agency doesn’t know how to work with React Native.
- Size of dev team – you don’t want to be dependent on one or two developers – even if your project is relatively small.
- Localisation – find out where the agency is based and if it matches your time zone. If not, make sure that it won’t be a problem for you.
Step 3: Check the agency’s portfolio.
Look for projects involving React Native and check if there are similar projects to yours. What’s also important is if the agency did projects in the same niche because it will help them understand you better.
Step 4: Read reviews and testimonials.
Don’t believe everything the agency will say just because they say it. Verify their words by reading reviews and testimonials on a website or, even better, on portals like Clutch. You can go even further and contact clients directly to ask for an honest opinion.
Reviews and testimonials posted on independent portals like Clutch are even more trustworthy than those on the agency’s website. It’s because the agency isn’t collecting them.
Step 5: Prepare a list of questions.
If you are satisfied with what you have learned about agency or agencies, now it’s time to prepare a list of general and technical questions. Such a list will help you decide whether you are talking with a competent agency or an agency that just pretends to be competent.
Extra: Step 6: Observe how fast do they reply
How fast a salesperson will contact you after you leave your message? Is a salesperson clear about the next step you need to take? How often is she following you up and how she is leading the conversation further?
It’s another sign of having a process worked out. In other words, experience and professionalism.
Questions to ask a React Native Agency
To make sure your agency is the right fit, we definitely recommend asking them both general questions, as well as the ones closer to their technical process and approach.
Here’s a helpful list of questions, and a small explanation of what you should expect.
General and light questions
The list of general questions will help you define the general abilities and accessibility of React Native agency during qualification meetings or a call.
1. How long did you work on your longest project?
It doesn’t matter if your project is small or complex – you should look for an agency that can build lasting business relationships. It’s a sign that such a company can manage projects (even demanding ones) well and will manage your project, too.
The reason behind this is that the agency, during various projects, established a set of best practices that work. Also, they experienced many problems, so they won’t be surprised if anything comes out during the project. Experience also taught them to make no promise they can’t keep just to make a deal.
2. Can I ask you for a code review?
Code reviews are usually things done by senior developers, so such a question is a great way to check if the agency has senior developers on board. If they can’t do it, there is a chance that they don’t have seniors and junior developers who will work on your project.
It’s also a better way to check their technical skills than doing a long technical interview.
3. Do you engage in any open-source and community activities?
Developers passionate about technologies of their choice will try to contribute to the community as much as they can. It’s not only about helping others, but it’s also the highest form of learning.
You can ask about:
- Open-source projects they are engaged in
- Conferences and events they are attending
- Sharing knowledge via blogging, social media or in any other form
4. Do you use Continuous Integration?
Experienced teams use Continuous Integration (CI) to check whether the application works well after new commits are integrated into the main branch.
Automated testing is one of the best practices in quality assurance, and a great React Native agency should be familiar with that concept.
5. Can you send me profiles of developers?
To check the skills and experience of developers, ask an agency for their profiles or CVs. It’s a great way to learn more about developers and their technical qualifications, portfolio, and other helpful information.
6. Can I call some of your previous clients?
Reading reviews and testimonials may not be enough to understand how the agency works and if it’s a great fit for your project. Contacting previous clients directly, on the other hand, will help you get some crucial information.
For example, you could ask the following questions:
- Why did you choose this agency?
- What can you tell about code quality and documentation?
- Are you satisfied with project management and execution?
- What’s their English level?
- What were the weaker points of this cooperation?
- How do they deal with working under pressure?
7. What did you use before React Native?
An even more important question should follow this question – why did you make a switch? In both cases, look for reasonable answers, not trend-based ones. You should choose an agency that sees the real value in React Native development.
Without any React Native development experience, asking technical questions may be challenging. However, in this case, if you want the Agency to be a trustworthy partner, you may want to learn how do they explain technical stuff to others.
To help you with that part, we prepared some questions that could uncover possible threats.
1. Does your agency have a standard code development process? How would you integrate that with our processes?
For example, at Pagepro, we do have our own code standards, but we are very agile and adaptive if it’s required.
We work with many companies, and we are used to adapting to the client’s standards.
2. What automation testing strategies have you utilized and would recommend?
At Pagepro, we usually do have a separate team that writes the automation tests (E2E).
If the project is logic heavy, we can provide the unit tests with a continuous integration solution to make sure we don’t have any regression.
3. How do you approach assuring a product and the code quality? What do you do to ensure the code written by you is future-proof?
At Pagepro, for example, we make sure everything is named correctly and readable (variables, functions etc) so the code is self-descriptive.
We use TypeScript which is somehow making sure we won’t accidentally break the app when we change 1 thing in the code (compilation errors). If the code is not declaring its intention, we add extra comments about it so if we come back to that code in a few months we will understand that.
We do code reviews with some requirements, so you can’t merge the code that is not approved by others.
We are also making a pull requests, but before merging it into a master branch, another developer has to review it.
On top of that, we use Expo SDK so the packages we are using to develop our project are well tested and stable. This is how we minimize the possibility of using an invalid package and the problem with developing/update application in future.
And finally, we use linters, so each and every developer working on the project, writes the code in the same way
4. How do you ensure documentation is adequately updated and revised during technology changes and iterations?
We update the documents each time we change something important that includes extra work or required making the project work correctly, including:
- adding environment variables
- creating extra account to make something work
- situations that need to do extra setup manually
- situations when we’ve changed our standards
Extra: Partnership, collaboration, and quality assurance
How to make sure you will get what you want?
Good partnerships are not afraid of difficult questions.
These questions will help you understand what can you expect from the agency while working together and how they approach quality and delivery assurance.
- How will the communication between us look like? What’s your preferred way of communication?
- How would you structure the cooperation (considering we are working on multiple projects)?
- How do you approach the option of occasionally visiting us in our office for consultation sessions? (Assuming the Covid situation allows for this).
Understanding your business:
- How will you ensure you understand our business requirements?
- What do you do to make sure you meet the business requirements when developing features?
- If we would switch places, and you would be in our place, what measures would you put in place to make sure that services are delivered in the best quality possible and that the outcome meets the requirements?
- How do you shape teams? How are skills distributed across the team?
- What about choosing people for the project considering roles and responsibilities?
- How long can we expect to work with specific team members? How do you approach turnover?
- What do you do when we are not satisfied with the work of one of your team members?
- How do you make sure that work performed by each team member is of the same high quality?
Talk with at least a few agencies – don’t choose the first one you talk with, even if everything seems great. Such an approach has a few benefits:
- A more in-depth insight into the average rates
- Information about what can you expect of cooperation with an agency
- Overview of standards and best practices of good agencies
Check average rates – it helps you with two things. Firstly, you will know if your budget allows for it and what can you expect for the money you can spend. Secondly, you won’t overpay for a project.
Verify provided information – bear in mind that it has never been easier for agencies to look more skilled and experienced than they are. For example, you can check LinkedIn profiles of developers working for the agency or talk directly with previous clients to double-check some obtained information.
Double-check technical skills – don’t be afraid to ask for a trial project or some code samples. The other option is a technical interview or conversation with at least one developer on their side.
Have more and better questions to ask? We are ready to answer!