Expedite Security Role Testing Assignments After a Code Move in Dynamics AX

By Andy Lawton-Thesing | May 24, 2017

It is common throughout an ERP migration for the need to perform many code promotions and environment refreshes to a TEST or UAT system for eventual installation to Production. Not only is testing being performed on code, data, and functionality, but security roles and settings may also require validation. This can introduce a level of complexity in your testing scenarios because the users testing the roles may not necessarily “live” them or be representative of what they have in Production.  Therefore, manual IT administration is needed after each data refresh to reassign users into their needed testing roles, as they will inherently match the system the data originated from. This can be especially problematic and time consuming if there are large numbers of people testing security roles.

There is a shortcut to addressing this however and it involves setting up your desired “testing” security role assignments in one environment, exporting them, and further importing them into the target environment. The following steps can be taken to accomplish this.

How to set up security role assignments, export, and import for testing in Dynamics AX:

In our scenario, April Meyer is an accounts payable manager at Contoso Ltd. She is working on testing the security roles for her employees, one of which includes the accounts payable clerk role.  In Production, the source of the data refresh, her security role assignments are as follows:

Security assignments in Dynamics AX

In TEST, where the security role testing will occur, she needs to have the following security role assignments in order to test and validate functionality:

Validate functionality of Security Roles in Dynamics AX

Set up security role assignment

The first step is to set up the desired security role assignment.  This should ideally be performed in an environment that closely resembles the target, such as a development system that was copied from production.  In our scenario, we are going to be performing the desired assignments in our TEST environment.

  1. Navigate to System Administration > Common > Users > Users
  2. Create your desired security role assignments for each user that will be affected.
  3. Navigate to System Administration > Common > Data export/import > Definition groups
  4. Click the New button to create a new definition group.
  5. Enter in the name “SecRoles” for the Definition group name, and a description of your liking.

Create table definition group for security roles in Dynamics AX

  1. Click the Clear button to remove any current saved parameters, and then click OK.
  2. The new definition group is now listed. Click the Select tables button.

Select tables for Security Role Definition groups

  1. In the Name of table column, find and add the SecurityUserRole Check the box marked Apply criteria and Specify related tables on the row.
  2. Click the Select related tables button:

Select related tables for security role definition groups

  1. The Select related tables form will appear. Uncheck the Select all tables in list checkbox and under the Select table relationship levels to include: section, click the < < (b) button until the level reaches 1:

Select table relationship levels for security roles

  1. You should now have a listing of three tables. Click the checkbox next to the UserInfo table and click Close.

SecurityRoleTesting6

  1. With the SecurityUserRole row selected, click the Export criteria button:

Security user role export criteria in Dynamics AX

  1. We are now going to create a query in which we select which users to export. This can be one user, or many users. In our scenario, we will click the Add button to create a new query, choose the Security user role table, with the field User ID, and the criteria of our AprilM user. If you have multiple users that you want to export, you can do so by comma-separating the users.  Click OK when done.

Create a query to select which users to import

  1. Click Close
  2. Now it is time to export our user role assignments. Click the Export to Select a save location, and change the File type to Comma, and click OK.

Export user role assignments

Export user role assignments

  1. Click OK if prompted to export or import-related tables.
  2. You’ll now find there is a .dat and a.def file created at the path you specified earlier. If you open the .dat file, you’ll find a listing of all users within AX and their associated security role mappings that we defined in our query.

Associated security role mappings

Moving into TEST

Next, we’re now assuming that our TEST environment has been refreshed from Production and we need to update the security assignments for our testing users.

  1. In the TEST Dynamics AX environment, navigate to System Administration > Common > Data export/import > Import
  2. Browse and find the .dat file we created earlier
  3. Click on the Advanced
  4. Check all three check boxes

Update security assignments for testing users

  1. Click OK. The import process will begin.
  2. When prompted with a dialog regarding selecting which tables to delete before import, check the box next to Security user role, and click OK.

Select tables to delete before import.

  1. Click Yes to continue.
  2. Click Yes when prompted to update existing data.
  3. Dynamics AX will now assign the security roles based on the file we created earlier and an Infolog will be presented when the import is complete. You can verify by opening the user options for the account to what the intended role is.

Verify security roles in the user options for the account


Under the terms of this license, you are authorized to share and redistribute the content across various mediums, subject to adherence to the specified conditions: you must provide proper attribution to Stoneridge as the original creator in a manner that does not imply their endorsement of your use, the material is to be utilized solely for non-commercial purposes, and alterations, modifications, or derivative works based on the original material are strictly prohibited.

Responsibility rests with the licensee to ensure that their use of the material does not violate any other rights.

Start the Conversation

It’s our mission to help clients win. We’d love to talk to you about the right business solutions to help you achieve your goals.

Subscribe To Our Blog

Sign up to get periodic updates on the latest posts.

Thank you for subscribing!