abapgit-agent 1.2.0 → 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -6,6 +6,7 @@ CLASS zcl_abgagt_command_inspect DEFINITION PUBLIC FINAL CREATE PUBLIC.
6
6
  PUBLIC SECTION.
7
7
  INTERFACES zif_abgagt_command.
8
8
 
9
+ " Error structure for syntax check results
9
10
  TYPES: BEGIN OF ty_error,
10
11
  line TYPE string,
11
12
  column TYPE string,
@@ -15,21 +16,49 @@ CLASS zcl_abgagt_command_inspect DEFINITION PUBLIC FINAL CREATE PUBLIC.
15
16
 
16
17
  TYPES ty_errors TYPE STANDARD TABLE OF ty_error WITH NON-UNIQUE DEFAULT KEY.
17
18
 
19
+ " Generic warning structure (for DDLS and other objects)
20
+ TYPES: BEGIN OF ty_warning,
21
+ type TYPE string,
22
+ line TYPE string,
23
+ column TYPE string,
24
+ severity TYPE string,
25
+ message TYPE string,
26
+ object_type TYPE string,
27
+ object_name TYPE string,
28
+ END OF ty_warning.
29
+
30
+ TYPES ty_warnings TYPE STANDARD TABLE OF ty_warning WITH NON-UNIQUE DEFAULT KEY.
31
+
32
+ " Result for each individual object
18
33
  TYPES: BEGIN OF ty_inspect_result,
34
+ object_type TYPE string,
35
+ object_name TYPE string,
19
36
  success TYPE abap_bool,
20
37
  error_count TYPE i,
21
38
  errors TYPE ty_errors,
39
+ warnings TYPE ty_warnings,
22
40
  END OF ty_inspect_result.
23
41
 
42
+ " Table to hold results for multiple objects
43
+ TYPES ty_inspect_results TYPE STANDARD TABLE OF ty_inspect_result WITH NON-UNIQUE DEFAULT KEY.
44
+
24
45
  TYPES: BEGIN OF ty_inspect_params,
25
46
  files TYPE string_table,
26
47
  END OF ty_inspect_params.
27
48
 
28
49
  TYPES ty_object_keys TYPE TABLE OF scir_objs WITH NON-UNIQUE DEFAULT KEY.
29
50
 
51
+ " Type for DDLS object names
52
+ TYPES ty_ddls_names TYPE STANDARD TABLE OF tadir-obj_name WITH NON-UNIQUE DEFAULT KEY.
53
+
30
54
  METHODS run_syntax_check
31
55
  IMPORTING it_objects TYPE ty_object_keys
32
- RETURNING VALUE(rs_result) TYPE ty_inspect_result.
56
+ RETURNING VALUE(rt_results) TYPE ty_inspect_results.
57
+
58
+ " Validate DDLS (CDS views)
59
+ METHODS validate_ddls
60
+ IMPORTING it_ddls_names TYPE ty_ddls_names
61
+ RETURNING VALUE(rt_results) TYPE ty_inspect_results.
33
62
 
34
63
  ENDCLASS.
35
64
 
@@ -45,9 +74,11 @@ CLASS zcl_abgagt_command_inspect IMPLEMENTATION.
45
74
  lv_obj_type TYPE string,
46
75
  lv_obj_name TYPE string,
47
76
  lo_util TYPE REF TO zcl_abgagt_util,
48
- ls_result TYPE ty_inspect_result,
77
+ lt_results TYPE ty_inspect_results,
49
78
  lt_objects TYPE ty_object_keys,
50
- ls_obj TYPE scir_objs.
79
+ lt_ddls_names TYPE ty_ddls_names,
80
+ ls_obj TYPE scir_objs,
81
+ ls_result TYPE ty_inspect_result.
51
82
 
52
83
  " Parse parameters from is_param
53
84
  IF is_param IS SUPPLIED.
@@ -57,7 +88,10 @@ CLASS zcl_abgagt_command_inspect IMPLEMENTATION.
57
88
  IF ls_params-files IS INITIAL.
58
89
  ls_result-success = abap_false.
59
90
  ls_result-error_count = 1.
60
- rv_result = /ui2/cl_json=>serialize( data = ls_result ).
91
+ ls_result-object_name = 'N/A'.
92
+ ls_result-object_type = 'N/A'.
93
+ APPEND ls_result TO lt_results.
94
+ rv_result = /ui2/cl_json=>serialize( data = lt_results ).
61
95
  RETURN.
62
96
  ENDIF.
63
97
 
@@ -72,24 +106,191 @@ CLASS zcl_abgagt_command_inspect IMPLEMENTATION.
72
106
  ev_obj_name = lv_obj_name ).
73
107
 
74
108
  IF lv_obj_type IS NOT INITIAL AND lv_obj_name IS NOT INITIAL.
75
- CLEAR ls_obj.
76
- ls_obj-objtype = lv_obj_type.
77
- ls_obj-objname = lv_obj_name.
78
- APPEND ls_obj TO lt_objects.
109
+ " Separate DDLS from other objects
110
+ IF lv_obj_type = 'DDLS'.
111
+ APPEND lv_obj_name TO lt_ddls_names.
112
+ ELSE.
113
+ CLEAR ls_obj.
114
+ ls_obj-objtype = lv_obj_type.
115
+ ls_obj-objname = lv_obj_name.
116
+ APPEND ls_obj TO lt_objects.
117
+ ENDIF.
79
118
  ENDIF.
80
119
  ENDLOOP.
81
120
 
82
- IF lt_objects IS INITIAL.
121
+ " Run syntax check for non-DDLS objects
122
+ IF lt_objects IS NOT INITIAL.
123
+ DATA(lt_sci_results) = run_syntax_check( lt_objects ).
124
+ INSERT LINES OF lt_sci_results INTO TABLE lt_results.
125
+ ENDIF.
126
+
127
+ " Run DDLS validation
128
+ IF lt_ddls_names IS NOT INITIAL.
129
+ DATA(lt_ddls_results) = validate_ddls( lt_ddls_names ).
130
+ INSERT LINES OF lt_ddls_results INTO TABLE lt_results.
131
+ ENDIF.
132
+
133
+ " If no valid objects found
134
+ IF lt_objects IS INITIAL AND lt_ddls_names IS INITIAL.
83
135
  ls_result-success = abap_false.
84
136
  ls_result-error_count = 1.
85
- rv_result = /ui2/cl_json=>serialize( data = ls_result ).
86
- RETURN.
137
+ ls_result-object_name = 'N/A'.
138
+ ls_result-object_type = 'N/A'.
139
+ APPEND ls_result TO lt_results.
87
140
  ENDIF.
88
141
 
89
- " Run syntax check for all objects together
90
- ls_result = run_syntax_check( lt_objects ).
142
+ rv_result = /ui2/cl_json=>serialize( data = lt_results ).
143
+ ENDMETHOD.
91
144
 
92
- rv_result = /ui2/cl_json=>serialize( data = ls_result ).
145
+ METHOD validate_ddls.
146
+ " Validate DDLS (CDS views) using CL_DD_DDL_HANDLER_FACTORY
147
+ " First checks inactive version ('M'), falls back to active ('A')
148
+ DATA: lv_ddls_name TYPE ddlname,
149
+ lo_handler TYPE REF TO if_dd_ddl_handler,
150
+ ls_ddlsrcv TYPE ddddlsrcv,
151
+ ls_error TYPE ty_error,
152
+ ls_warning TYPE ty_warning,
153
+ lt_warnings TYPE ddl2ddicwarnings,
154
+ lx_error TYPE REF TO cx_dd_ddl_check,
155
+ lv_found TYPE abap_bool,
156
+ ls_result TYPE ty_inspect_result,
157
+ lv_err_msg TYPE string,
158
+ lv_warn_msg TYPE string.
159
+
160
+ rt_results = VALUE #( ).
161
+
162
+ " Create DDL handler
163
+ lo_handler = cl_dd_ddl_handler_factory=>create( ).
164
+
165
+ " Check each DDLS object
166
+ LOOP AT it_ddls_names INTO lv_ddls_name.
167
+ CLEAR: ls_ddlsrcv, lt_warnings, lv_found, ls_result.
168
+
169
+ ls_result-object_type = 'DDLS'.
170
+ ls_result-object_name = lv_ddls_name.
171
+ ls_result-success = abap_true.
172
+
173
+ " First try to read inactive version (get_state = 'M')
174
+ TRY.
175
+ lo_handler->read(
176
+ EXPORTING
177
+ name = lv_ddls_name
178
+ get_state = 'M'
179
+ IMPORTING
180
+ ddddlsrcv_wa = ls_ddlsrcv ).
181
+
182
+ IF ls_ddlsrcv-source IS NOT INITIAL.
183
+ lv_found = abap_true.
184
+ ENDIF.
185
+
186
+ CATCH cx_dd_ddl_check.
187
+ " Ignore - will try active version
188
+ ENDTRY.
189
+
190
+ " If no inactive version, try active version
191
+ IF lv_found = abap_false.
192
+ TRY.
193
+ lo_handler->read(
194
+ EXPORTING
195
+ name = lv_ddls_name
196
+ get_state = 'A'
197
+ IMPORTING
198
+ ddddlsrcv_wa = ls_ddlsrcv ).
199
+
200
+ IF ls_ddlsrcv-source IS NOT INITIAL.
201
+ lv_found = abap_true.
202
+ ENDIF.
203
+ CATCH cx_dd_ddl_check.
204
+ " Ignore
205
+ ENDTRY.
206
+ ENDIF.
207
+
208
+ " If still not found, report error
209
+ IF lv_found = abap_false.
210
+ ls_error-line = '1'.
211
+ ls_error-column = '1'.
212
+ ls_error-text = |DDLS { lv_ddls_name } not found in repository|.
213
+ APPEND ls_error TO ls_result-errors.
214
+ ls_result-success = abap_false.
215
+ ls_result-error_count = lines( ls_result-errors ).
216
+ APPEND ls_result TO rt_results.
217
+ CONTINUE.
218
+ ENDIF.
219
+
220
+ " Run validation check
221
+ TRY.
222
+ " Get warnings from check method
223
+ lo_handler->check(
224
+ EXPORTING
225
+ name = lv_ddls_name
226
+ IMPORTING
227
+ warnings = lt_warnings
228
+ CHANGING
229
+ ddlsrcv_wa = ls_ddlsrcv ).
230
+
231
+ " Parse warnings from check method
232
+ LOOP AT lt_warnings INTO DATA(ls_warn_from_check).
233
+ CLEAR ls_warning.
234
+ ls_warning-type = ls_warn_from_check-type.
235
+ ls_warning-line = ls_warn_from_check-line.
236
+ ls_warning-column = ls_warn_from_check-column.
237
+ ls_warning-severity = ls_warn_from_check-severity.
238
+ ls_warning-object_type = 'DDLS'.
239
+ ls_warning-object_name = lv_ddls_name.
240
+ " Use MESSAGE statement to get real warning message
241
+ MESSAGE ID ls_warn_from_check-arbgb TYPE 'E' NUMBER ls_warn_from_check-msgnr
242
+ WITH ls_warn_from_check-var1 ls_warn_from_check-var2 ls_warn_from_check-var3 ls_warn_from_check-var4
243
+ INTO lv_warn_msg.
244
+ ls_warning-message = lv_warn_msg.
245
+ APPEND ls_warning TO ls_result-warnings.
246
+ ENDLOOP.
247
+
248
+ " If no errors and no warnings, validation passed
249
+ IF ls_result-warnings IS INITIAL.
250
+ ls_result-success = abap_true.
251
+ ELSE.
252
+ ls_result-success = abap_false.
253
+ ENDIF.
254
+
255
+ CATCH cx_dd_ddl_check INTO lx_error.
256
+ " Validation failed - get error details using get_errors method
257
+ DATA(lt_errors) = lx_error->get_errors( ).
258
+ LOOP AT lt_errors INTO DATA(ls_err).
259
+ CLEAR ls_error.
260
+ ls_error-line = ls_err-line.
261
+ ls_error-column = ls_err-column.
262
+ " Use MESSAGE statement to get real error message
263
+ MESSAGE ID ls_err-arbgb TYPE 'E' NUMBER ls_err-msgnr
264
+ WITH ls_err-var1 ls_err-var2 ls_err-var3 ls_err-var4
265
+ INTO lv_err_msg.
266
+ ls_error-text = lv_err_msg.
267
+ APPEND ls_error TO ls_result-errors.
268
+ ENDLOOP.
269
+
270
+ " Also get warnings if any
271
+ DATA(lt_warn) = lx_error->get_warnings( ).
272
+ LOOP AT lt_warn INTO DATA(ls_warn2).
273
+ CLEAR ls_warning.
274
+ ls_warning-type = ls_warn2-type.
275
+ ls_warning-line = ls_warn2-line.
276
+ ls_warning-column = ls_warn2-column.
277
+ ls_warning-severity = ls_warn2-severity.
278
+ ls_warning-object_type = 'DDLS'.
279
+ ls_warning-object_name = lv_ddls_name.
280
+ " Use MESSAGE statement to get real warning message
281
+ MESSAGE ID ls_warn2-arbgb TYPE 'E' NUMBER ls_warn2-msgnr
282
+ WITH ls_warn2-var1 ls_warn2-var2 ls_warn2-var3 ls_warn2-var4
283
+ INTO lv_warn_msg.
284
+ ls_warning-message = lv_warn_msg.
285
+ APPEND ls_warning TO ls_result-warnings.
286
+ ENDLOOP.
287
+
288
+ ls_result-success = abap_false.
289
+ ENDTRY.
290
+
291
+ ls_result-error_count = lines( ls_result-errors ).
292
+ APPEND ls_result TO rt_results.
293
+ ENDLOOP.
93
294
  ENDMETHOD.
94
295
 
95
296
  METHOD run_syntax_check.
@@ -99,9 +300,11 @@ CLASS zcl_abgagt_command_inspect IMPLEMENTATION.
99
300
  lo_inspection TYPE REF TO cl_ci_inspection,
100
301
  lt_list TYPE scit_alvlist,
101
302
  ls_error TYPE ty_error,
102
- lx_error TYPE REF TO cx_root.
303
+ ls_list TYPE scir_alvlist,
304
+ lx_error TYPE REF TO cx_root,
305
+ ls_result TYPE ty_inspect_result.
103
306
 
104
- rs_result-success = abap_true.
307
+ rt_results = VALUE #( ).
105
308
 
106
309
  TRY.
107
310
  " Create unique name for inspection
@@ -145,14 +348,29 @@ CLASS zcl_abgagt_command_inspect IMPLEMENTATION.
145
348
  " Get results
146
349
  lo_inspection->plain_list( IMPORTING p_list = lt_list ).
147
350
 
148
- " Parse results - aggregate all errors
149
- LOOP AT lt_list INTO DATA(ls_list).
150
- CLEAR ls_error.
151
- ls_error-line = ls_list-line.
152
- ls_error-column = ls_list-col.
153
- ls_error-text = ls_list-text.
154
- ls_error-word = ls_list-code.
155
- APPEND ls_error TO rs_result-errors.
351
+ " Build result for each object
352
+ LOOP AT it_objects INTO DATA(ls_obj).
353
+ CLEAR ls_result.
354
+ ls_result-object_type = ls_obj-objtype.
355
+ ls_result-object_name = ls_obj-objname.
356
+ ls_result-success = abap_true.
357
+
358
+ " Get errors for this object
359
+ LOOP AT lt_list INTO ls_list WHERE objname = ls_obj-objname.
360
+ CLEAR ls_error.
361
+ ls_error-line = ls_list-line.
362
+ ls_error-column = ls_list-col.
363
+ ls_error-text = ls_list-text.
364
+ ls_error-word = ls_list-code.
365
+ APPEND ls_error TO ls_result-errors.
366
+ ENDLOOP.
367
+
368
+ ls_result-error_count = lines( ls_result-errors ).
369
+ IF ls_result-error_count > 0.
370
+ ls_result-success = abap_false.
371
+ ENDIF.
372
+
373
+ APPEND ls_result TO rt_results.
156
374
  ENDLOOP.
157
375
 
158
376
  " Cleanup
@@ -173,19 +391,20 @@ CLASS zcl_abgagt_command_inspect IMPLEMENTATION.
173
391
  exists_in_objs = 5
174
392
  OTHERS = 6 ).
175
393
 
176
- rs_result-error_count = lines( rs_result-errors ).
177
- IF rs_result-error_count > 0.
178
- rs_result-success = abap_false.
179
- ENDIF.
180
-
181
394
  CATCH cx_root INTO lx_error.
182
- rs_result-success = abap_false.
183
- rs_result-error_count = 1.
184
- ls_error-line = '1'.
185
- ls_error-column = '1'.
186
- ls_error-text = lx_error->get_text( ).
187
- ls_error-word = ''.
188
- APPEND ls_error TO rs_result-errors.
395
+ " Return error for all objects
396
+ LOOP AT it_objects INTO ls_obj.
397
+ CLEAR ls_result.
398
+ ls_result-object_type = ls_obj-objtype.
399
+ ls_result-object_name = ls_obj-objname.
400
+ ls_result-success = abap_false.
401
+ ls_error-line = '1'.
402
+ ls_error-column = '1'.
403
+ ls_error-text = lx_error->get_text( ).
404
+ APPEND ls_error TO ls_result-errors.
405
+ ls_result-error_count = 1.
406
+ APPEND ls_result TO rt_results.
407
+ ENDLOOP.
189
408
  ENDTRY.
190
409
  ENDMETHOD.
191
410