A Hitchhiker’s Guide to Enterprise Mobile App DevelopmentJune 4, 2015
When most enterprise companies decide to “kick the tires” on developing a mobile app, they typically follow a similar process for finding developers, requesting quotes, and deciding on a development vendor based on a preset criteria.
In this article, we’ve decided to offer a few tips for successfully working with an app development company and open up the curtain to reveal a behind the scenes look at what it takes to successfully develop an enterprise-grade mobile app.
Let’s get started with five of the most common pre-development questions:
- What platform(s) will this app be on? E.g. – iOS, Android, Windows, etc.
- Will it be a static app or will new content be added to it frequently?
- What device features will the app use? E.g. – GPS, Accelerometer, Camera, Bluetooth, etc.
- Does the app require a backend database? E.g. – Connecting to a customer database, integrating with internal systems, reports, etc.
- Will the app require an Internet connection? E.g. – Posting to social media, saving data to the cloud, etc.
Once the organization has a good understanding for the questions above, a budget is generally discussed. Usually, the more complex the app, the greater the monetary investment it will require to build and maintain. At this time, enterprise organizations will often consider the potential returns on this investment such as increased revenue, greater market share, and improved customer satisfaction. During this stage, a ballpark budget range is discussed. This will likely be a wide range as the idea has yet to be discussed specifically. The goal of discussing a ballpark range is to make sure there is a fit between the client and the development company.
The next stage is signing a non-disclosure agreement or NDA. This provides the client and the developer with the ability to share information more openly since all conversations and information will remain confidential. From the client side, this often involves sharing documentation about the idea and how it may help the enterprise compete better in the marketplace. From the developer side, this may involve sharing specific pricing information, hourly rates, or development processes.
Once an NDA has been signed and specific details have been shared about the app, the development team will begin to gather requirements to provide a proposal. These requirements may involve a bit of discovery into the client’s business processes and experience with technology. At a minimum, a written description or one-pager is requested by the development team to better understand the desired features for the app. The development team will often use these requirements and features to write what is called “user stories”. User stories are part of an agile approach that helps shift the focus from writing about requirements to talking about them. All agile user stories include a written sentence or two and, more importantly, a series of conversations about the desired functionality. The most common way to write user stories is using the format below.
Format: As a , I want so that .
Example: As an app user, I want to login to the app using Facebook to save time.
Once the requirements have been gathered and user stories have been written, a proposal for services is provided by the development team to the client. This proposal will outline “our understanding” of the app, include the user stories, and pricing information. The pricing will often come in the form of dollar amount per device type. For example, $XX,XXX per device type (iPhone, Android, etc.). The proposal has an area for the client to sign to accept the agreement and move forward with the development project.
Once a project is signed for, there are several milestones for development:
- Kick-off – during the kick-off meeting, the team members will be introduced and roles will be assigned. This is often a good time to discuss project goals in terms of the timeline, app features, and milestones.
- Design – the app will be designed from start to finish based on the user stories and requirements document. This will involve collecting the brand guidelines from the organization or RGB color values and preferred font styles. The design process involves creating wireframes which are just sketches of the app. These wireframes are used to create the actual designs which can be exported into sliced individual assets. These designs are provided to the client for review, feedback, and ultimately approval.
- Development – Once designs are approved, the development phase will begin. MichiganLabs follows an Agile development approach where new functionality is rolled out to the app in two-week sprints. These sprints allow new value to be added and tested in smaller “bite sized” releases. So, rather than going away and building an entire app without checking in with the client, MichiganLabs will build and present the app more frequently once a new feature or requirement is finalized. Clients do not like surprises.
- Testing – the application features will be tested in detail. Each feature will be tested to meet the client requirements. This may involve testing on different software builds such as iOS or Android. The app may be tested in both landscape and portrait modes. For backend systems, each user story will be tested including testing on multiple browsers and in different hosting environments. Once testing is complete, the launch plan will begin.
- Launch – the application will be posted to the Apple App Store and Google PlayStore where appropriate. These postings will require screenshots, an app store description, and maybe even a promotional video. Apple generally takes 7-10 days to approve the app while Google will make the app available in the PlayStore within 24 hours. For backend system launches, the links and logins will be provided to the client and the databases moved into the production environment.
- Maintenance – each application has different needs for maintenance. This typically includes a monthly agreement with set aside hours for development and support. This maintenance agreement may also include support for new features and new software releases such as iOS, Android – and changes in hardware such as screen sizes or device types (E.g. Apple Watch).
In summary, each application is very different and may require very specific milestones to be successful. These milestones are just the most common milestones and could be changed based on recommendations or desires from the client. It is important to stay in close communication at each step of the process.
At MichiganLabs, our goal is to see your project through to completion and be your partner every step of the way. We hope the recommendations in this article have been helpful as you consider your next Enterprise application development project. If you have any questions, please contact us at email@example.com or 616-594-0269. Thank you.
Stay in the loop with our latest content!
Select the topics you’re interested to receive our new relevant content in your inbox. Don’t worry, we won’t spam you.
Bringing Agile HomeAugust 26, 2020
My life often resembles a game of Whack-A-Mole. The moment I complete one task two more pop up. To avoid getting behind, I jump on new tasks almost immediately. Then at some point along the way my wife will innocently ask if I’ve scheduled my appointment with the Secretary of State. Realizing that an up-to-date driver’s license takes priority over a squeaky hinge, I put down my tools and book my online appointment.Read more
Michigan Software Labs breaks ground on new officeJune 19, 2020
Michigan Software Labs recently broke ground on a new office building in its hometown of Ada. The 16,500-square-foot, three-story building will have office space for the growing software company and support up to 75 team members. The company currently is hiring for developers, UX designers and project managers.Read more
Download a collection of 3 key articles on the state of digital todayApril 14, 2020
As presented by Forbes. Download the top-3 most popular articles published by Michigan Software Labs.Read more