Надев защитный шлем, продолжаем разговор без предисловий.
Про дилетантов
Не так давно на Хабре пробежала статья, в которой некий дилетант кидал камни в огород SAP.
Один из камней:
Почему люди переводившие продукт не понимали русский язык? Потому что даже при перепечатывании русскоговорящий человек должен был усомниться, увидев фразу «Пушномолочная свинья-несушка» — так до определенного времени называлась программа RAIMEWMS (сейчас название уже исправили). В оригинале она называется «Eierlegende Wollmilchsau», что переводится как «Мастер на все руки», но умный Magic Gooddy посчитал, что Wollmilchsau – это 3 отдельных слова (Woll, milch, sau) и перевел фразу «Eierlegende Woll milch sau» как «Яйцо укладки шерсти молока свиноматки». Остается только гадать, как это потом превратилось в «Пушномолочная свинья-несушка».
Вот вопрос: кто больший дилетант? Тот, кто сделал такой перевод, или тот, кто кинул камень?
По пунктам:
Куда пристроить модульные тесты в ABAP. Часть вторая. Первые грабли.
Первый шаг сделан. Теперь нужно расширить и углубить наше наступление. Глобальная цель – максимально полное покрытие тестами, в рамках целесообразности происходящего.
Грабля первая. Обработка ошибок.
Допустим, наш ФМ делает не замещение значений, а проверку:
function zfi_bte_00001120.
if ls_bseg-zuonr eq space.
message ‘Поле Присвоение обязательно для заполнения’ type ‘E’.
endif.endfunction.
Тут есть две проблемы.
Куда пристроить модульные тесты в ABAP. Часть первая. Первый тест.
В умных книгах и статьях много про это написано в целом. Но вопрос по части специфики в ABAP-программировании раскрыт мало.
ABAP-программирование может быть совсем разным. Но почти в любом большом проекте его можно разложить на следующие кучи:
- Экзиты (user-exits). Сюда относятся: проверки, замещения, BTE, BAdI, CMOD и подобные способы расширения стандартной функциональности.
- Собственное приложение. Вполне вероятно, что это будет вариация на тему CRUD.
- Отчеты. Можно сказать, что отчёт – это такое собственное приложение, но у программ такого рода есть свои нюансы.
- Входящая интеграция, исходящая интеграция. Мы вызываем, нас вызывают, как это часто не совпадает.
- Вспомогательные библиотеки. Полуфабрикаты, необходимые для построения готового продукта.
А теперь отдельно про экзиты.