Customizations Part 2: Requirements, Design, and Testing
Customizations run the range from simple to very complex. For this reason, accurate requirements gathering, and design documentation are critical to the customization’s success.
Customizations run the range from simple to very complex. For this reason, accurate requirements gathering, and design documentation are critical to the customization’s success.
Table of Content
In part 1 of our customizations post, Customizations: Why, When and What to Look For we discussed how to research customization alternatives, secure and manage executive project support and stay within your company’s capabilities.
Sometimes, after researching all customization alternatives, you might find that none are sufficient to meet your needs. At this point, a customization may be needed.
Customizations run the range from simple to very complex. For this reason, accurate requirements gathering, and design documentation are critical to the customization’s success. After completion, the customization needs to be carefully tested from both a user acceptance testing (UAT) and data reconciliation perspective.
ERP implementations are controlled using a specific methodology. Customization needs are usually identified in the pre-sale discovery phase and documented in the requirements gathering phase. The actual customization is coded in the configure and data load phase, and tested in the training and testing phase.
This post discusses some best practices that help ensure a successful customization. It also identifies some “pitfalls” which often result in a less than optimal outcome.
Over the course of many projects, four top best practices have emerged that can positively impact a customization:
In the ERP world, “customization” is a blanket term attached to many different initiatives.
Be sure to keep customization requirements consistent with their value. For example, some companies make extensive modifications just to keep legacy processes in place before really understanding how the new system works. Unless the issue is critical, out of the box functionality should be used for at least 6 months before considering major customizations. Once system users become familiar with the ERP, many modifications are rarely requested.
Customization and integrations are the most complex initiatives of the customization types described above. Due to their complexity, they need to be supported with a set of requirements and a detailed design document.
These initiatives can become quite expensive. Controlling the process is key to keeping the everything on track. Be sure the initiative is supported with a detailed budget, including testing and bug fix costs. If you can, try to negotiate a fixed price.
In addition to direct costs, be sure you understand any associated on-going costs. For example, custom code development may require a re-do of the coding each time the system is upgraded. These costs can be significant. Essentially, you’re paying multiple times for the same effort. Also, include ongoing soft costs such as reconciliation and error handling.
Be sure you know who’s doing the actual development. Many VAR’s are not large enough to have full time developers on staff, and they regularly outsource this work. While not necessarily an issue, just be sure that you complete an adequate level of due diligence. Meet with the developer, interview them and ask for references on prior development projects. At a minimum, get a signed non-disclosure agreement and review the developer’s experience and certifications.
Be sure to get the VAR to agree to stand behind the work and assume liability for any issues such as processing errors and data irregularities. Also address the completed customization’s ownership. You paid for it, so you own the rights to it. Ensure that these issues are addressed in the SOW.
Interfaces are much less difficult to control. In most cases they really don’t need a requirements or design document. Usually, a simple mapping document is sufficient. The mapping document should detail where the data is coming from (source system) and where the data is going to (destination system). The mapping document example below, reflects a positive pay file interface from AP to the processing bank.
Interface danger points, are error handling and the reconciliation between the source and destination systems. Prompt, efficient error handling and reconciliation are an important part of maintaining interface accuracy.
System tools use the ERP’s “out of the box” tools such as user fields and field label customization. This is the easiest customization to control. Usually, the need is identified, in the ERP requirements meetings. Many times, simple tasks using the tools can be priced or “thrown in” as a part of the ERP implementation. If needed post implementation, the VAR will write up a simple SOW (Statement of Work) and complete.
Building a functional design for customizations and integrations, is a task usually completed by an IT or SME (Subject Matter Expert) resource. This can be an internal employee, an outside contractor or a VAR team member.
Since the functional design is used by the developer to write the technical design and actual code, it’s important that the design’s author is reasonably familiar with both the functionality desired, technical terms and can build the design document in a manner easily understood by the developer. These tasks require a resource with a lot of prior experience, and the ability to write in a clear and precise manner.
Be sure that you complete an adequate level of due diligence before deciding on an author. Meet with the authors, interview them and ask for references. Have them show you some prior designs they’ve completed, even if you have to sign a non-disclosure agreement.
Don’t shortcut this, its very important to a successful project. Finally, don’t forget to get a signed non-disclosure agreement from the author, even if it’s a company employee.
In addition to creating the document, the author usually acts as the developer’s liaison during the development, testing and training phases. Additionally, assign an employee from your company to act as the “project lead” (from the user side) to work with the author to ensure that all requirements are included and functioning properly after completion.
In terms of the document itself, start with a general outline and have the author review it with the project lead. Be sure that the outline includes all requirements, and that it’s well written, organized and understandable. Once the general outline is finalized, continue by drilling down and building out the detail until you’re satisfied with the end product.
I personally like to use Word documents for this. If you prefer a spreadsheet, that’s ok too. Schedule regular meetings between the author and the project lead to keep thinks on track.
Testing and reconciliation are absolutely critical to success. Short cutting or using a haphazard testing approach without pre-defined testing scripts and expected results is risky. Not reconciling test results, is an accident waiting to happen.
Customization testing should be based on two testing types:
A lot of time and effort goes into identifying requirements and building the customization design. Use the requirement and design documents to build your test scripts. Prepare a set of test transactions including the expected outcomes to be sure your test efforts are systematic and can effectively identify issues. If you can, use similar transactions from your current system as a base. Using current system transactions provide the ability to know what the expected results should be. Use the test scripts as the basis of any training documentation.
A sample of a test script is displayed below:
Run your testing and reconciliation plans past your auditors to be sure that they are satisfied, and will accept the work papers and testing process. You don’t want to complete the implementation, then get to year end and have to incur additional audit labor to get a set of audited financials.
Remember, there are few things that erode an accountant’s credibility and career faster than providing inaccurate information, especially if it builds over time and becomes a material issue, so be very careful here.
Customizations are an expensive proposition, and they can quickly spiral out of control. Plan carefully about testing and reconciliation, as these tasks can take a very long time to complete. Be sure your company can handle what you’re going to be getting into.
In my mind’s eye, a customization should be used as a last resort, and the customization should be only as complex as needed to achieve its intended goal.
Talk to us about how Velosio can help you realize business value faster with end-to-end solutions and cloud services.
"*" indicates required fields