使用SAP CRM mock框架进行单元测试的设计
There is an interface IF_CRM_PRODUCT_PROXY in CRM which declares almost all function modules from function group COM_PRODUCT_API for product master access.
data:image/s3,"s3://crabby-images/5f6f7/5f6f70d20ca718ffd99d6486b9641131bcd9644a" alt=""
This interface is implemented by three classes below.
data:image/s3,"s3://crabby-images/5cd0d/5cd0de9c9f0bb6a81275320e258d396e601c1324" alt=""
CL_CRM_PRODUCT_PROXY will delegate the call to MOCK_PROXY( for unit test ) or REAL_PROXY( for productive use ) according to different mode in which the code is running. As an application developer, we do not directly call CL_CRM_PRODUCT_PROXY in our application code, but use another wrapper class CL_CRM_PRODUCT_API instead.
For example, I would like to get the product guid for product with id “I042416”, I use the following source code:
data:image/s3,"s3://crabby-images/5c8d4/5c8d406ea8f8b5ba2cad8d4a06aafd5a155b0711" alt=""
In productive use scenario, the callstack could be found below:
our test report calls CL_CRM_PRODUCT_API, which calls CL_CRM_PRODUCT_PROXY, which then calls the productive implementation – CL_CRM_PRODUCT_REAL_PROXY. Inside the real proxy, function module COM_PRODUCT_GUID_GET is called.
data:image/s3,"s3://crabby-images/99517/9951706054715e51b9b8e0785de7294027ce1fd6" alt=""
How to use CRM mock framework to make fake product guid is returned
Suppose in my unit test code, I would like a fake guid “AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA” is returned by the same source code.
- Just add the following source code to let CL_CRM_PRODUCT_PROXY know that currently the code is running under mock mode.
cl_factory_proxy=>set_source( iv_source = 'MOCK'
iv_xml_master_data_file = '\\TSHomeServer\TSHome$\i042416\Desktop\test.xml'
iv_read_from_mime = abap_false ).
This code would probably be inserted into the class_setup of your unit test code.
data:image/s3,"s3://crabby-images/4e496/4e496111c20e1eeadd4b52833e1258b9c0adcbf3" alt=""
- paste the following source code into your test.xml:
<Mock XMLCompressVersion="2">
<XMLRC_Object ObjectName="CL_CRM_PRODUCT_API" Component="COM_PRODUCT_GUID_GET" input="8B70F13430313231340300">
<EV_PRODUCT_GUID>qqqqqqqqqqqqqqqqqqqqqg==</EV_PRODUCT_GUID></XMLRC_Object></Mock>
data:image/s3,"s3://crabby-images/d86e2/d86e2689471f0de64da7eadb636e0fbdb2ff87ce" alt=""
- Where does input 8B70F13430313231340300 in xml come from?
Set a breakpoint on function module PROXY_CONVERT_TO_STRING,
data:image/s3,"s3://crabby-images/a0206/a0206f957d09ea29fbe5fc67d90eff9908976631" alt=""
data:image/s3,"s3://crabby-images/5eefd/5eefd1480f59f6f2560599ee3affcde1011a6357" alt=""
and you can know this value is calculated based on the zip operation of the concatenated value based on all input parameter values ( in my example, it is CDI042416 )
- Where does qqqqqqqqqqqqqqqqqqqqqg== for IV_PRODUCT_GUID in xml come from?
Execute function module SSFC_BASE64_ENCODE in test mode, paste the fake guid AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA and execute it, then you get base64 encoded value. Paste the value into xml file.
data:image/s3,"s3://crabby-images/7b0ed/7b0ed37c502b4af577bd9531c0c4d800eb8f83cb" alt=""
- Now execute the test report once again. From callstack you can see that the MOCK_PROXY is called, the faked guid is fetched from XML and returned:
data:image/s3,"s3://crabby-images/ff46a/ff46ad7bd5a3f7ac48050a4c4f59414b661dfbd9" alt=""
data:image/s3,"s3://crabby-images/acd86/acd86442f50b137b0f77d0b58df734b15eed3178" alt=""
要获取更多Jerry的原创文章,请关注公众号"汪子熙":
data:image/s3,"s3://crabby-images/dbdb5/dbdb58b6e07a167b4c721ac53e4d5857cad20da6" alt=""