- 28 Jul 2022
- 6 Minutes to read
- Print
- DarkLight
Unit Testing (Advanced)
- Updated on 28 Jul 2022
- 6 Minutes to read
- Print
- DarkLight
Overview
Unit Tests can be used using various techniques within Decisions Designer Studio. Unit Tests can be created using a Flow and a Rule to test data as it passes through. Advanced Unit Tests have additional advantages that help to quickly and accurately check the data being passed through and provide a clear picture of what a user may be looking to test. The following document demonstrates advanced techniques of using the Unit Test utility in Decisions.
This document demonstrates the advantages of using Unit Tests on Composite Data Types, Step Simulation Options, and Running Unit Test Rules before any step in the Flow.
Composite Data Types
Building the Flow
- CREATE a new Flow in a Designer Folder.
- From the Flow Designer, click the SETUP INPUT DATA button under the top Action bar, then click DEFINE.
- In the Input Data dialog, create a Name the Input and define the Type. For this example search for Accounts in the search bar and select Account [DecisonsFramework].
- Save the Input Data, then close with X.
- Connect the Start step to the End step in the Flow. Save the Flow, then close if desired.
Debug
- Select the Debug link from the top Action bar.
- In the Debugger, add a New Unit Test by selecting Add New next to Unit Tests.
- Give the Unit Test a Test Name (CheckAccountField).
- Select the Edit Settings button (which appears as a pencil) on the right under Input Data.
- Pick or Define an existing Account(admin@decisoins.com).
- Click Save to save the Unit Test.
- Add a second Unit Test and choose different INPUT DATA. This Unit Test is named CheckEmailTest and uses an account for a different email address.
Rule
Edit each Unit Test and create a Rule that checks for Account EmailAddress Contains Admin. The example sets up a Rule that checks for admin in the Account Email Address.
- In the Rule Designer write a Rule that can evaluate any desirable field of the Composite Data Type. This Rule will use the pick Email Address field from the Account Input as an example.
The Rule states: If the Account.EmailAddress Contains admin (if the Unit test passes, the Rule will evaluate True if the Unit Test fails, the Rule will evaluate False). - Save and close the Rule.
- Save the Unit Test rule and close the Debugger and navigate back to the Flow Designer.
- Select the End step, and under Data and Output, select Show Editor.
- Create a new data definition called Account and choose String as the Type. Under Inputs next to Account, choose Select From Flow and then pick Account.
- Select Close to save the configuration.
- In the Flow Designer, select Debug.
- Next, to Unit Tests, select Run All to run all Unit Tests. The results of the Unit Tests will display under Under Unit Tests, displaying which test was evaluated as True or False.
Flow As Data Source
As of Decisions Installations v.7.7+, users are provided the ability to dynamically map in Flow Input Data as a Data Source for Unit Testing.
- From the Debugger, under UNIT TESTS, click Add New.
- Under [UNIT TEST DATA], provide a Test Name.
- Click the Edit UNIT TEST RULE button and edit the Rule as usual, then Save and close the Rule.
- Back in the Debugger, under UNIT TESTS > DATA SOURCE FOR UNIT TEST RULE, select From Flow.
- Under FLOW AS DATA SOURCE, click EDIT FLOW AS INPUTS.
- From the resulting Flow Designer, attach a Create Data step to the Start step. Note on Flow ConfigurationThe Create Data step is not required as it is only used for example purposes. Any Flow logic that Outputs Data may be implemented to create dynamic Source Data for a Unit Test.
- From the Create Data step's Properties, under DATA > Data to Create, select SHOW EDITOR.
- Define the Data to Create according to desired/expected Input Data for the Unit Test (in this case, an Account TYPE).
- Save the Data, then close via X.
- Back in the Flow Designer, connect the Done path to the End step.
- Select the End step to navigate to the End step's Properties, then Select From Flow map the Output of the Create Data step to the End step's INPUT DATA.
- Save and close the Flow.
- Save the Unit Test, then Run it via the Run button (Play icon) or Run All.
Step Simulation Options
Building the Flow
Running a Unit Test on a specified step is called Step Simulation. Step Simulation can be specified on a step or on a specific direction in a Flow.
- From the Flow, add a Placeholder Step from the Annotations Folder in the Toolbox tab.
- Select the step to navigate to the Properties.
- Under Outcomes select ADD NEW.
- Define the Outcome definitions in the Editor.
Name the Path "Test Simulation" then click OK. - Connect the Done path to the End Step.
- Search for and add an End step.
- Under NAME > Data, name the step.
- Connect the Test Simulation path to the newly added End step.
- Next, select the Placeholder Step, and navigate to TESTING AND SIMULATION under the Properties tab,
- Denote the Use Simulation Behavior setting as InUnitTests to run the Simulation Behavior in the Debugger.
Doing so will display a yellow S icon on the step to mark that it is using a Simulation Behavior.Each option that is checked under Use Simulation Behavior will run the Flow with that behavior and on the selected pathway.
- InDebugger: Run the test in the Debugger on the selected pathway.
- InProduction: Run the test at Production on the selected pathway.
- InUnitTests: Run the Unit Tests in the Flow on the selected pathway.
- Under Simulation Selected Path, expand the dropdown and select the Test Simulation to run the Simulation behavior on that specific path.
- Toggle the Run Unit Test Rule box, then select EDIT PLACEHOLDER STEP 1 UNIT TEST RULE to define the Unit Test Rule that will be run on the selected path.
- Define the Rule as If Account.EmailAddress Contains admin, Then Result { Return True.
- Save the Rule and close with X.
Debug
- From the Flow Designer, select the Debug link.
- Under UNIT TESTS select CheckAccountField and Run the Unit Test via the play button.
If the Unit Test evaluates False the Flow will stop in the Debugger. If the Unit test evaluates True the Flow will continue to deploy in the Debugger. - Select either Rule on the left to check the results of the Unit Tests.
Creating a Unit Test Completion Notification Flow
The Flow to Run After Unit Tests Execution setting allows Designers to assign a specific Unit Test Completion Notification Flow to start either daily at a set time, after saving the project associated Flow or Rule, or after importing the Flow or Rule into an environment. When initialized, this Flow sends an email notification to the specified account detailing unit test failures and successes. When testing specific scenarios, the Unit Completion Notification Flow helps pinpoint errors soon after it initially occurs.
- In the Decisions Studio, select CREATE FLOW. Select the Advanced tab and then select the Unit Test Completion Notification Flow.
- Search for the Send Email step in the Toolbox and connect it to the Start and End steps
- Configure the Send Email step to connect to desired email server's specifications. Test the Flow and, upon successfully receiving the email, close out of the Flow Designer.Need help sending emails?Please refer to our Send Email and Modifying an Application Servers SMTP Settings articles for further information relating to email server SMTP configurations.
- In the Studio, navigate to Settings > Designer Settings > Run Unit Tests to view the Flow To Run After Unit Tests Execution setting. Select PICK and choose the Flow made prior.
- Select the interval when to run the Notification Flow. For this example, the After Save option is selected.
- Open a Flow with Unit Tests that belong to the same project as the Unit Test Completion Notification Flow. Save the Flow and exit the Flow Designer.
- Check the inbox of the specified receiving email account. An email reporting all project-associated Unit Tests along with individual success and failure information will appear.