首页 > 代码库 > AX7: Quick and easy debugging

AX7: Quick and easy debugging

This purpose of this blog is to show how you can get quickly get started with debuggingin AX7, specifically by showing how you can debug an error message issued from AX.

So, let’s begin !

Imagine you are posting a Bank journal and you get the following error message upon posting ‘Currency EUR not allowed for account USMF OPER’

You would like to know the logic behind this error message, but need to trace in the code where it was issued from

技术分享

We will use a classic debugging technique known from AX 2012 to demonstrate how this can be done quickly and easily, by inserting a breakpoint on the Info class to enable the debugger to track down in the code where the error is generated from.

These are the steps 1.Start Visual Studio as ‘Administrator’

技术分享

2.  Go to the Application explorer, go to the ‘Code’ node, select ‘Classes’ and locate the ‘Info’ class

技术分享

On the ‘Info’ class rightclick and select ‘View code’

技术分享

In the window that opens up, select the ‘Add’ method

技术分享

3. Insert your breakpoint on the ‘Add’ method by pressing ‘F9’

技术分享

 

4. Press ‘Debug’ from the toolbar and select ‘Attach to process’

技术分享

 

In the ‘Attach to process’ screen mark ‘Show processes from all users’ and then browse to  the process ‘w3wp.exe’

技术分享

Wait for the Symbols to load

技术分享

 

5. Once the symbols have loaded repeat the application procedure, eg. in this case we will post the journal again to generate the error message

技术分享

 

And note that almost immediately the debugger starts executing in Visual Studio

技术分享

I copy the call stack into Notepad and here I note especially the highlighted line as this is the line that is triggered just before the call to the Infolog code

技术分享

I can see that the error is triggered on the BankAccountTable, checkCurrency method on line 225 and I stop debugging

技术分享

I go to this code to study the method

 I open up the BankAccountTable and similar to as on the ‘Info’ class I select ‘View Code’ and open the method I am interested in

技术分享

Here naturally ‘checkCurrency’

技术分享

 

And  we can study the code that generated the error message

Naturally, you can use the same technique to insert breakpoints in other places of the code such as on ‘init’, ‘update’ and ‘insert’ methods etc

Happy debugging !

AX7: Quick and easy debugging