Skip to Content
Author's profile photo Former Member

How to debug the Fiori Back-End ABAP codes


Sometimes it may be helpful for us to find the root cause of the unexpected Fiori application behavior if we can debug the Fiori’s back-end ABAP code.

Before we start, there are some basic information we need to know:

The browser’s “Developer tools”: This is the tool we can use to debug the JavaScript code, get all the necessary information of the HTTP requests in the browser.

We can press F12 to open this tool in Firefox, Chrome or IE.

XMLHTTP request: When the browser is running some JavaScript codes, the JavaScript codes will trigger some XMLHTTP request to get or post some data from/to the server.

JavaScript code: In Fiori application, HTML codes, JavaScript codes are transferred from the front-end server to the browser.

Browser displays the Fiori application by the HTML codes, do the dynamic operations (such as display dynamic data) by the JavaScript codes.

Package name: We need the package name to get the data provider class when debug the ABAP method  (the t-code is SE80) in the back-end system.

Data Provider Class: This class (ABAP code) locates in the back-end system, and is used to provide the data. So if we find no data or incorrect data in the Fiori application, we can debug the data provider class in the back-end system.

I got very helpful information for writing this document from the following SCN link:

SAP Fiori LL11 – Consultants should know about OData troubleshooting–consultants-should-know-about-odata-troubleshooting

Lessons Learned:

You will know how to debug the Fiori back-end ABAP code.

Example Issue Description:

Enter the Fiori application My Timesheet   version 2.

Click the rectangle of “Time Assignment->Receiver Order”, there is no data displayed in the popped up window.


Image [1].png

Steps of debugging:

1. Before clicking the rectangle of “Time Assignment->Receiver Order”, press F12 to open the browser’s Developer  Tools.

Image [2].png

2. Click the rectangle to pop up the “Receiver Order” window. This will trigger an XMLHTTP request for getting the data of “Receiver Order”.

We can get the information of this XMLHTTP request in the Network tab (sometimes there can be multiple lines in the Network tab, we only care about the OData URL which is beginning with  /sap/opu/odata/sap/):

Image [3].png

Image [4].png

3. Double click this line to get more details:

Image [5].png

Key Value
Request GET /sap/opu/odata/sap/HCM_TIMESHEET_MAN_SRV/ValueHelpList?$filter=…sap-client=500 HTTP/1.1

The OData service is: HCM_TIMESHEET_MAN_SRV, through the OData service name we can get the package name and the data provider class which will be needed to debug the ABAP code of getting data.

The  method of the data provide class invoked in the back-end system looks like: ValueHelpList

4. Go to “front-end system -> open t-code /n/IWFND/MAINT_SERVICE,  find the OData Service HCM_TIMESHEET_MAN_SRV:

Image [6].png

Click “Service Implementation” to get the necessary information for debugging:

Image [7].png



The method looks like ValueHelpList (as we find in the URL above). Actually, the method should look like ValueHelpList_GET_ENTITYSET.

5. Debug the ABAP code in the back-end system (t-code: SE80) :

Image [8].png

Now if we reproduce the issue in the browser (Click the rectangle of “Time Assignment->Receiver Order” as mentioned above), the breakpoint will be triggered( the program will stop at the breakpoint).

6. Finally we get the root cause.

Image [9].png

Image [10].png

Image [11].png

Assigned Tags

      You must be Logged on to comment or reply to a post.
      Author's profile photo Masayuki Sekihara
      Masayuki Sekihara

      It is a real example for debugging. I like it.

      Author's profile photo Lech Dzierzawski
      Lech Dzierzawski

      also, try t-code SRDEBUG

      Author's profile photo Y. Mauricio Pacheco Pedraza
      Y. Mauricio Pacheco Pedraza

      Really? its a t-code ?

      Author's profile photo Bruno Lucattelli
      Bruno Lucattelli

      This is very similar to any external break point in ABAP. So, to someone who's already an ABAP developer, this should be old news. But there's value to those who came to SAP platform because of Fiori (a.k.a.: web developers and front-end developers). I would definitely send this link to someone in that position. Thanks for sharing!

      Author's profile photo Custodio de Oliveira
      Custodio de Oliveira

      It's not "very similar", it IS external break point. The tricky part is to know which Gateway service is yours. From there, nothing new. Nevertheless, it's a good blog post.

      Author's profile photo Bruno Lucattelli
      Bruno Lucattelli

      That's what I meant! 🙂

      Author's profile photo Michael Albrecht
      Michael Albrecht

      Great blog Moon!

      Author's profile photo Erica Miyamoto
      Erica Miyamoto

      If you don't have authorization to use transaction /IWFND/MAINT_SERVICE (my case), the table that has the data provider class is: /IWBEP/I_SBD_SV.
      EXTERNAL_NAME is the service name and DPC is the Data Provider Class

      Author's profile photo Martin Schlegel
      Martin Schlegel

      Hello Moon, thank you for sharing! Martin 

      Author's profile photo Former Member
      Former Member



      The external debugging is not getting triggered anyway.


      I have tried all the suggestion given on blog and internet elsewhere.


      Is there anything that I am missing?


      Please help.



      Author's profile photo Lindolfo Martins dos Santos
      Lindolfo Martins dos Santos

      Thank you very much Moon, it is very helpful !


      Author's profile photo Joy Dey
      Joy Dey

      The content is really good. It's really useful.

      Author's profile photo Shuxin Li
      Shuxin Li

      It's very helpful. I was wondering how to find out the back end program for a Fiori app and this is exactly what I need. Thank you for sharing!

      Author's profile photo Helmut Berger
      Helmut Berger

      Thank you for sharing this information. This is very helpful for me.