Book Image

Automated Testing in Microsoft Dynamics 365 Business Central - Second Edition

Book Image

Automated Testing in Microsoft Dynamics 365 Business Central - Second Edition

Overview of this book

Dynamics 365 Business Central is a cloud-based SaaS ERP proposition from Microsoft. With development practices becoming more formal, implementing changes or new features is not as simple as it used to be back when Dynamics 365 Business Central was called Navigator, Navision Financials, or Microsoft Business Solutions-Navision, and the call for test automation is increasing. This book will show you how to leverage the testing tools available in Dynamics 365 Business Central to perform automated testing. Starting with a quick introduction to automated testing and test-driven development (TDD), you'll get an overview of test automation in Dynamics 365 Business Central. You'll then learn how to design and build automated tests and explore methods to progress from requirements to application and testing code. Next, you'll find out how you can incorporate your own as well as Microsoft tests into your development practice. With the addition of three new chapters, this second edition covers in detail how to construct complex scenarios, write testable code, and test processes with incoming and outgoing calls. By the end of this book, you'll be able to write your own automated tests for Microsoft Business Central.
Table of Contents (22 chapters)
1
Section 1: Automated Testing – A General Overview
4
Section 2:Automated Testing in Microsoft Dynamics 365 Business Central
7
Section 3:Designing and Building Automated Tests for Microsoft Dynamics 365 Business Central
12
Section 4:Integrating Automated Tests in Your Daily Development Practice
15
Section 5:Advanced Topics
19
Section 6:Appendix

How to make your code testable?

Having full control of the code under test, in essence, means that this code has no direct dependency on other pieces of code in your application and outside it. In other words: your code is broken up into loosely coupled units. Either they are fully independent or, if a dependency applies, your code allows you to control the dependency. Microsoft has been highly investing, and still is, in getting the application loosely coupled and better testable, like they have done when splitting the system and base application. They also continue doing this with the base application itself where there is still a vast number of battles to be won like in the case of the sales posting routine. Although it has been refactored significantly, there is a still massive blob of code that executes 1,000 tasks in the process of posting a sales order. We can hardly access just parts of the code, it is only possible to execute the whole thing. Imagine if the code is executed...