1. 程式人生 > >不喜歡SAP GUI?那試試用Eclipse進行ABAP開發吧

不喜歡SAP GUI?那試試用Eclipse進行ABAP開發吧

view 標簽 專業 重構 -a 格式 而是 事務 err

Jerry和SAP成都研究院一些新同事聊天時,談到ABAP和SAP GUI這個話題。很多新同事在加入SAP成都之前,是做Java和C++開發的,習慣了Eclipse/IntelliJ IDEA/Visual Studio這些現代IDE,對於SAP GUI這個比較”復古“的IDE不太適應。

其實還有一個選擇:ABAP Development Tools,最初在SAP內部稱為ABAP in Eclipse。這個工具SAP在很多場合簡稱為ADT,本文後續部分也使用這個簡稱。

簡單地說,SAP對Eclipse做了擴展,開發了一些插件,使得開發人員能使用Eclipse完成部分以前在SAP GUI裏進行的ABAP開發工作。

技術分享圖片

本文不去重復網上和SAP幫助文檔裏對ADT的介紹,而是介紹一些Jerry的原創內容。

Jerry曾經寫過一篇文章 那些年我用過的SAP IDE, 裏面也提到了ADT。本文對其做詳細介紹。

文章目錄

1. ADT的工作原理

2. SAP GUI和ADT的關系

3. ADT相比SAP GUI具有的一些獨到之處

4. ADT其他一些值得一提的小功能

下面是正文。


1. ADT的工作原理

很多從Eclipse做Java開發的朋友轉到ADT後,最大的不習慣就是ADT沒辦法離線使用。即使是用SAP雲平臺Neo編程環境裏的SDK,開發人員也可以在本地完成開發後,使用命令行或者Eclipse Run As菜單將其發布到SAP雲平臺上。然而這種用法對於ADT來說行不通,因為後者仍然是一個Client / Server

模式中的Client端。從本質上講,和SAP GUI的區別,僅僅體現在對Netweaver服務器上開發資源的展示和操作方式有所差異罷了。

正因為這種CS架構,每次我們在ADT裏操作Netweaver上的ABAP資源時,比如編輯一個ABAP類並保存,實際上都是通過消費ABAP後臺暴露出的Restful API來完成的。

這種Restful API的消費行為可以通過打開ADT裏的ABAP Communication Log視圖來觀察。點擊Start logging按鈕:

技術分享圖片

在源代碼裏隨便做一些改動,比如增加一個空行,能觀察到這個修改動作觸發了很多到ABAP後臺的HTTP請求:

技術分享圖片

如果想自己調試這些後臺操作的具體實現,用SAP GUI登錄ABAP後臺,使用事務碼SICF找到節點/sap/bc/adt

:

技術分享圖片

在節點處理類的方法HANDLE_REQUEST裏設置斷點即可調試:

技術分享圖片

HTTP請求發送到後臺之後,上述方法會調用一個統一的入口函數SADT_REST_RFC_ENDPOINT, 該函數和ADT後臺框架其他處理邏輯的交互如下圖所示:

技術分享圖片

關於這些HTTP的請求和響應明細,請參考Jerry的博客:

An example to help you understand how does ADT work

https://blogs.sap.com/2014/08/12/an-example-to-help-you-understand-how-does-adt-work/

比如在ADT裏對ABAP源代碼做語法檢查,實際上就是把整段代碼做一個Base64編碼,然後通過HTTP Post發送到後臺,由後臺執行對應的檢查函數,結果通過HTTP響應返回給ADT前端。

技術分享圖片

相應的,如果對ADT的前臺Java代碼感興趣,請移步ADT安裝目錄下的plugins文件夾,把裏面的jar包反編譯出來閱讀源代碼即可。

技術分享圖片

2. SAP GUI和ADT的關系

Jerry的個人觀點是:二者互為補充

一方面,對於S/4HANA很多新功能的開發,比如CDS view和AMDP(ABAP Managed Database Procedure), 開發人員沒有選擇的余地,必須使用ADT,因為SAP GUI不支持這些新功能的開發。

比如在SAP GUI裏即使想瀏覽CDS view的內容也不行,會收到提示:

Please use the ADT Tools in Eclipse to process DDL sources.

技術分享圖片

而AMDP,就是一個特殊的ABAP類,能夠在ABAP方法裏執行HANA的SQLScript或者存儲過程。

技術分享圖片

SAP GUI裏可以查看AMDP的源代碼,但是沒法做開發。試圖在SAP GUI裏進行編輯時,會遇到上面的提示信息:

Class XX contains stored procedures which cannot be changed in SAP GUI

反之,SAP GUI裏一些比較傳統的開發,ADT也是不支持的。舉一些例子。

傳統Dynpro程序的Screen開發,雙擊Screen number,就可以通過點擊Layout按鈕打開Screen Painter,然後進行所見即所得的Screen布局開發:

技術分享圖片

然而如果在ADT裏試圖編輯這個Screen會發生什麽事?

技術分享圖片

ADT會打開一個新的標簽頁,裏面顯示一個嵌入的SAP GUI窗口,像Screen Painter和其他一些傳統的ABAP開發,均在這個嵌入的SAP GUI裏進行。

技術分享圖片

這就是Jerry在這一小節標題裏提到SAP GUI和ADT互為補充的含義:即便使用了ADT,也不意味著能和SAP GUI說再見——很多傳統的ABAP開發仍然需要在SAP GUI裏進行,哪怕是作為一個窗口嵌入在ADT裏。

技術分享圖片

使用SAP GUI做開發的ABAP顧問,應該明白這三個session的區別:

  • User Session

  • ABAP Session

  • Internal Session

技術分享圖片

我們每次用SAP GUI登錄一個系統,都會產生一個新的User Session,每個User Session裏用/o打開一個新的事務碼,則是在該User Session裏開啟了一個新的ABAP Session。一個User Session默認能打開最多6個ABAP Session,可以通過修改系統參數把最大數目擴充為16個。

技術分享圖片

那麽ADT裏打開的嵌有SAP GUI窗口的標簽頁,背後啟動的Session類型是什麽?經過Jerry測試,答案是User Session

下圖是ADT裏打開的兩個標簽和其對應的兩個User Session,用不同顏色來區分。

技術分享圖片

3. ADT和SAP GUI相比一些獨到之處

既然是一個基於Eclipse的IDE,ADT和SAP GUI相比還是存在一些獨到之處。

(1) 由於ADT是基於Eclipse這個較之SAP GUI來說更加現代的IDE,從使用習慣上來說更貼近Java/C++程序員。

以ABAP類為例,各個維度的信息在ADT裏能在一個屏幕裏同時顯示,在SAP GUI裏一個屏幕顯示的信息維度很單一,如果想看其他維度信息,只有通過雙擊的方式跳轉,查看完畢後通過回退鍵回到正在工作的界面。

技術分享圖片

又比如所有添加了關註的系統的ST22信息能在一個地方統一監控了,Jerry再也不需要自己開發工具實現了:

技術分享圖片

(2) ADT提供了很多代碼重構的向導(Assistant), Java和C++的開發人員對這些類的重構功能一定不會陌生。

技術分享圖片

Delete unused variables:

快速刪除一個方法裏所有定義了但未使用的局部變量,這個功能很實用,SAP GUI不支持。

技術分享圖片

Extract Methods: 如果一段代碼反復出現,可以考慮用重構技術裏的方法提取,將其封裝成一個方法。

當然還在使用SAP GUI的開發人員要使用ABAP重構向導也是可以的, 根據SAP GUI版本的不同, 入口也稍有差異。

在Jerry的SAP GUI 740版本裏,重構向導通過Utilities菜單進入。

技術分享圖片

740之前的版本,重構向導的打開方式大同小異:

技術分享圖片

(3) 對SAP GUI一些常用功能的原生支持

所謂原生支持,指用Eclipse原生的頁面來提供以前在SAP GUI裏實現的功能。

對ABAP開發顧問來說,幾乎每天都要在SAP GUI進行的操作就是ABAP類和報表的調試。

有的以前從事Java開發的朋友們轉到SAP GUI後,剛上手時使用SAP GUI的調試器總覺得很別扭。一旦使用ADT的調試器,熟悉的味道又回來了。在ADT裏調試ABAP和Eclipse裏調試Java程序的方式完全一致。

技術分享圖片

SAP GUI裏的單元測試和分支/語句執行覆蓋率:

技術分享圖片

技術分享圖片

ADT裏也提供了單元測試和各種覆蓋率審查的原生支持:

技術分享圖片

SAP GUI裏的事務碼SAT在ADT裏的原生支持:

技術分享圖片

使用方式和SAP GUI裏的沒有差別。

技術分享圖片

(4) 方便的SQL console功能。

以前在SAP GUI裏時,有時出於測試目的想寫些簡單的SQL語言做些驗證,還得創建一個報表然後在報表裏書寫。在ADT裏,直接使用SQL console就可省去不必要的報表創建:

技術分享圖片

技術分享圖片

(5) 改進的代碼版本比較功能

Jerry之前的公眾號文章 我用ABAP做過的那些無聊的事情 提到,有的朋友覺得SAP GUI裏自帶的代碼比較工具不是很好用:

技術分享圖片

如今在ADT裏,ABAP開發人員終於可以像Java程序員一樣,享受Eclipse提供的便利的代碼版本比較功能了:

技術分享圖片

4. ADT其他一些值得一提的小功能

(1) ADT Link

比如任何一個在ADT裏能夠查看的資源,都有一個所謂的ADT Link,通過菜單Share Link查看:

技術分享圖片

這種Link格式如下:

adt://AG3/sap/bc/adt/vit/wb/object_type/tabldt/object_name/ZORDER

通過Open ADT Link菜單,輸入上述ADT Link,能直接打開對應的資源,而不需要像SAP GUI那樣,需要先運行正確的事務碼,進入事務碼之後再打開資源。

技術分享圖片

(2) 自定義編輯器顏色

Jerry和很多程序猿一樣,兩件T恤衫就能穿一個夏天:

技術分享圖片

技術分享圖片

然而對於自己每天都要使用八到十個小時的IDE,其個性化裝扮是一點都不能含糊。

如何才能讓您的IDE和其他程序猿相比顯得與眾不同呢?一個辦法是個性化字體和背景色。比如Jerry的SAP GUI的個性化設置是這樣的,字體必須用程序猿專用的等寬開源字體Inconsolata,這樣顯得比較專業。

技術分享圖片

SAP GUI的顏色個性化設置稍顯麻煩,需要一項項手動設置。而ADT因為是基於Eclipse,所以主題的個性化就容易多了。如果覺得下面的dark主題還不夠酷,

技術分享圖片

安裝一個名叫Eclipse Color Theme的插件,就可以使用這個插件預置好的幾十套主題,真正做到一年54周每周換一套了。程序猿衣著可以隨便,但IDE或者代碼編輯器決不能隨便

技術分享圖片

總結

說了這麽多,Jerry並不是在推銷ADT,在我心中SAP GUI和ADT都是優秀的IDE,各有優缺點。我覺得網上流傳的程序猿IDE和工具的鄙視鏈很無聊,與其有時間去鄙視別人,不如把這時間用來深入研究自己每天用的IDE,進一步提高自己單位時間內的工作效率。

技術分享圖片

祝大家都能愉快地使用SAP GUI和ADT,做到得心應手。感謝閱讀。

更多閱讀

  • 動手使用ABAP Channel開發一些小工具,提升日常工作效率

  • 聊聊C語言和ABAP

  • ABAP vs Java, 蛙泳 vs 自由泳

  • 300行ABAP代碼實現一個最簡單的區塊鏈原型

  • Jerry的ABAP原創技術文章合集

  • ABAP開發人員未來應該學些什麽

  • Jerry的ABAP, Java和JavaScript亂燉

  • 我用ABAP做過的那些無聊的事情

技術分享圖片

要獲取更多Jerry的原創文章,請關註公眾號"汪子熙":

技術分享圖片

不喜歡SAP GUI?那試試用Eclipse進行ABAP開發吧