CDS测验框架介绍
分类:传统文化

动机

今后大家都晓得单元测量检验对大家代码的裨益。并且大家都认同它是开辟进度中至关重要的意气风发有个别。可是在把代码切换来数据库的情势下的时候,我们被强行地打回了软件测量试验的乌黑时期...大家前不久面对着逻辑下推到ABAP CDS entities后,代码要哪些测验的难题。

CDS Test Double Framework允许开荒者们通过鲜明的ABAP Unit Test Framework自动化地质度量试CDS entities。

正文链接:

韩语原稿:Introduction to CDS Test Double Framework – How to write unit tests for ABAP CDS Entities?

挑战

因为CDS entity中的逻辑运维在下层的数据库中(独立于abap runtime),使用古板的ABAP信任注入施工方案以落到实处地度量试成为了不也许的事体。entity的依赖于组件急需在数据库中丰富测验替身,而且大家必需保障CDS entity测量试验的时候数据库引擎调用/实施那么些测量检验替身(double)。

为了能够在CDS entity under test (CUT)中可控地质衡量试逻辑,我们须求经过测量检验替身注射测量试验专项使用数据。那意味着必得将测验数据插入到测量试验替身中,那样数据足以在CUT推行时被测验替身们回去。对于在ABAP CDS上下文中颇有固有的只读属性的依附组件(比方数据库视图和数据库函数),这是风姿潇洒项特地的挑战。

正文中举足轻重的缩写:

CUT = CDS entity Under Test

DOC = Depended-On Component

CDS Test Double Framework

CDS Test Double Framework管理了以上的挑战,而且能够兑现CDS entities测验的自动化:

  1. 在一直以来的Database Schema中为种种正视新组合件创造不经常的可更新测量检验替身
    1. 复制依赖新组合件表,但不复制任何数据。不复制注重数据库表的主键限定。这允许你轻便地插入测验数据,而不用顾虑数据的完整性。相同的,数据库索引也不会被复制。
    2. 为依靠数据库视图创立数量库表。那一个表有着和正视数据库视图相符的布局。
    3. 依赖数据库functions(由带有参数的注重CDS视图和重视表function发生)会被复制,並且function的测量检验替身达成会被涂改为允许插入必要的测量试验数据。
  2. 在长久以来的Database Schema创制三个CDS entity under test(CUT)的临时别本。从各种意义上来看,这么些别本是为CUT服务的。在原来的CDS entity中贯彻的逻辑在别本中相符存在,不过借助组件被替换为了呼应的测量检验替身。测量检验替身是由大家的CDS Test Double Framework所开创的。

图片 1

测量试验什么?

单元测量试验应当注意于由一个给定视图完成的有价值的效果与利益定义。不是装有的CDS视图都亟需一个单元测量试验。在落到实处单元测量试验早前,提议辨别出entity中与测量试验有关的地点。

常备,供给为有个别含有了代码下推的章程的entity实行单元测验。潜在的测量检验候选者包蕴:

Calculations and/or filters, conversions, conditional expressions 比如 CASE…THEN…ELSE or COALESCE, type changing CAST operations, cardinality changes or checks against NULL values,  JOIN behavior, complex where conditions 等.

单元测量检验不接纳于测量检验那贰个更适用于静态检查、集成测量检验等本领的CDS entities属性。借使不可能从单元测量检验中拿走别的价值的话,也不应举行它,比方对于那三个不难的CDS投影视图。

怎么着使用CDS Test Double Framework写单元测验?

在下一些,大家会由此被布满应用的ABAP Unit Test Framework为以下的CDS视图创建单元测量检验。

@AbapCatalog.sqlViewName: 'zSo_Items_By_1'
@EndUserText.label: 'Aggregations/functions in SELECT list'
@AbapCatalog.compiler.compareFilter: true
define view Salesorder_Items_By_TaxRate
as select from CdsFrwk_Sales_Order_Item
association [1] to snwd_so as _sales_order on so_guid = _sales_order.node_key
{
so_guid,
coalesce ( _sales_order.so_id, '9999999999' ) as so_id,
currency_code,
sum( gross_amount ) as sum_gross_amount,
tax_rate,
_sales_order
}
group by
so_guid,
_sales_order.so_id,
currency_code,
tax_rate

创建ABAP测试类

始建贰个ABAP测量试验类以对CDS视图进行单元测验。有四个好的举办措施:为测量试验类起二个和CUT相仿/雷同的名字,何况拉长TEST的后缀。比方,对于CDS视图Salesorder_Items_By_TaxRate,测验类的名字能够是:Salesorder_Items_By_TaxRate_Test.

因为单元测验和CDS是不一样的东西,雷同/雷同的名字能够支持大家轻易的检索相关的测验。

CLASS Salesorder_Items_By_TaxRate_Test DEFINITION FINAL FOR TESTING
DURATION SHORT
RISK LEVEL HARMLESS.
PRIVATE SECTION.
...
...
ENDCLASS.

CLASS SO_ITEMS_BY_TAXRATE_TEST IMPLEMENTATION.
...
...
ENDCLASS.

概念固定格局

概念以下的装置拆卸方法。

运营情势cl_cds_test_environment=>create( i_for_entity = ‘<CDS under test>’ ),隐式地在数据库中创立全部依赖新组合件测量试验替身。那么些法子在测量试验类中只应被调用贰次。

"Fixture method class_setup is executed only once in the beginning of the execution of test class
METHOD class_setup.
"For parameter i_for_entity, specify the CDS view to be unit tested. This will create all the depended-on component Test doubles in the database.
environment = cl_cds_test_environment=>create( i_for_entity = 'Salesorder_Items_By_TaxRate' ).
ENDMETHOD.

METHOD class_teardown.
environment->destroy( ).
ENDMETHOD.

"Fixture method setup is executed once before each test method execution
<cod
METHOD setup.
environment->clear_doubles( ).
ENDMETHOD.

概念单元测量检验方法

METHOD cuco_1_taxrate_1_item_1_ok.

ENDMETHOD.

预备输入——在测量试验替身中插入测量检验数据

METHOD cuco_1_taxrate_1_item_1_ok.

"Step 1 : Insert testdata into the doubles
"Step 1.1 : create an instance of type snwd_so. Note : CDS view Salesorder_Items_By_TaxRate depends on snwd_so.
sales_orders = VALUE #( ( client = sy-mandt node_key = '01' so_id = 'ID' ) ).

"Step 1.2 : Use the framework method CL_CDS_TEST_DATA=>create(..) to create the test_data object
test_data = cl_cds_test_data=>create( i_data = sales_orders ).

"Step 1.3 : Use the framework method environment->get_double(..) to create the instance of the double 'SNWD_SO'
DATA(sales_orders_double) = environment->get_double( i_name = 'SNWD_SO' ).

"Step 1.4 : Insert the testdata into the double depended-on component object
sales_orders_double->insert( test_data ).

"Repeat Step 1 for all the depended-on component doubles
sales_order_items = VALUE #( ( mandt = sy-mandt so_guid = '01' currency_code = 'EUR' gross_amount = '1' tax_rate = '19.00' ) ).
test_data = cl_cds_test_data=>create( i_data = sales_order_items ).
DATA(sales_order_items_double) = environment->get_double( i_name = 'CdsFrwk_DEMO_1' ).
sales_order_items_double->insert( test_data ).

...

ENDMETHOD.

执行CDS

SELECT * FROM cdsfrwk_so_items_by_taxrate INTO TABLE @act_results.

证实输出——使用ABAP单元测验的预见

exp_results = VALUE #( ( so_id = 'ID' currency_code = 'EUR' sum_gross_amount = '1' tax_rate = '19.00' ) ).
cl_abap_unit_assert=>assert_equals(
act = lines( act_results )
exp = lines( exp_results ) ).

"The method looks as follows:

METHOD cuco_1_taxrate_1_item_1_ok.

"Step 1 : Insert testdata into the doubles
"Step 1.1 : create an instance of type snwd_so
sales_orders = VALUE #( ( client = sy-mandt node_key = '01' so_id = 'ID' ) ).

"Step 1.2 : Use the framework method CL_CDS_TEST_DATA=>create to create the test_data object
test_data = cl_cds_test_data=>create( i_data = sales_orders ).

"Step 1.3 : Use the framework method environment->get_double to the instance of the DOC double 'SNWD_SO'
DATA(sales_orders_double) = environment->get_double( i_name = 'SNWD_SO' ).

"Step 1.4 : Insert the testdata into the DOC double object
sales_orders_double->insert( test_data ).

"Repeat Step 1 for all the DOC doubles
sales_order_items = VALUE #( ( mandt = sy-mandt so_guid = '01' currency_code = 'EUR' gross_amount = '1' tax_rate = '19.00' ) ).
test_data = cl_cds_test_data=>create( i_data = sales_order_items ).
DATA(sales_order_items_double) = environment->get_double( i_name = 'CdsFrwk_DEMO_1' ).
sales_order_items_double->insert( test_data ).

"Step 2 : Execute the CDS
SELECT * FROM cdsfrwk_so_items_by_taxrate INTO TABLE @act_results.

"Step 3 : Verify Expected Output
exp_results = VALUE #( ( so_id = 'ID' currency_code = 'EUR' sum_gross_amount = '1' tax_rate = '19.00' ) ).
assert_so_items_by_taxrate( exp_results = exp_results ).

ENDMETHOD.

运营CDS的单元测量试验

在ADT中间,张开包涵全数CDS单元测试的ABAP测量试验类。右键接收Run As->ABAP Unit Test,大概接纳ctrl+shift+f10组合键来运营单元测量试验。结果会在eclipse中的ABAP Unit Runner视图中显得。

专一:于今结束,还不可能在DDL源代码编辑器中平素运转单元测量试验。

受帮助的测量试验场景

CDS Test Double framework支持为给定的CUT的以下DOC成立测量检验替身:

  • DDIC tables
  • DDIC views
  • CDS views
  • CDS views with Parameters
  • External Views
  • Table Functions
  • CDS special functions. CURRENCY_CONVERSION and UNIT_CONVERSION

你能够展开/关闭给定CDS的DCL,更加多细节会在本文的末尾提供。

依赖组件是Table Function

Tables Function的测验替身的支配方式和别的的CDS视Toure同。

依靠于组件是含有参数的CDS视图

CDS Test Double Framework提供了

cl_cds_test_data=>create( .. )->for_parameters( .. )

来为带有参数的类其余测验替身插入数据。

METHOD eur_tax_rate_19_found.

"Step 1 : Insert testdata into the doubles
open_items = VALUE #( ( mandt = sy-mandt so_guid = '0F' tax_rate = '19.00' so_id = '1' ) ).
i_param_vals = VALUE #( ( parm_name = `pCuCo` parm_value = `EUR` ) ).

"CdsFrwk_demo_3 is a CDS view with parameters. Use framework method ->for_parameters( ) to insert test data
test_data = cl_cds_test_data=>create( i_data = open_items )->for_parameters( i_param_vals ).

DATA(open_items_double) = environment->get_double( 'CdsFrwk_demo_3' ).
open_items_double->insert( test_data ).

...
...
ENDMETHOD.

DCL对CUT的影响

你也得以张开/关闭给定的CDS的DCL。可是,在现阶段,假设你的CDS DDL在测量检验时碰着DCL影响的话,大家提议在运转测量检验时总是关闭DCL。在今后,使用DCL时会有为数不菲抉择可以玩,而且能够运用剧中人物权限测量检验替身等。可是在时下的本子中,你必要当心在测量试验CDS DDL时完全关闭DCL(假如局地话)。在开采DCL时些测验可能招致测验间断性战败,因为实际访谈调控剧中人物权限会被使用。由此,提出在你的坐蓐测验中总是有一个:

DISABLE_DCL=ABAP_TRUE in the cl_cds_test_environment=>create(…)

对特殊function的支持:CURRENCY_CONVERSION和UNIT_CONVERSION

CDS Test Double framework中可以为多个特其他CDS function提供支持:

"Step 1 : Create testdata using the special framework method create_currency_conv_data
test_data = cl_cds_test_data=>create_currency_conv_data( output = '399.21' )->for_parameters(
amount = '558.14'
source_currency = 'USD'
target_currency = 'EUR'
exchange_rate_date = '20150218'
).

"Step 2 : Get the double instance using the framework method get_double
DATA(curr_conv_data_double) = environment->get_double( cl_cds_test_environment=>currency_conversion ).

"Step 3 : Insert test_data into the double
curr_conv_data_double->insert( test_data ).

含蓄NULL值的测验

为了在测验替身中插入null值,CDS Test Double Framework提供了点子:

cl_cds_test_data=>create( .. )->set_null_values( .. )

该方法能够显式地设定null值。

partners = VALUE #( ( client = sy-mandt bp_id = '1' ) ).

"Step 1 : define the list of columns into which NULL is inserted
i_null_vals = VALUE #( ( `address_guid` ) ).

"Step 2 : Create testdata and set the NULL value object
test_data = cl_cds_test_data=>create( i_data = partners )->set_null_values( i_null_vals ).

"Step 3 : Get test Double instance
DATA(partners_double) = environment->get_double( i_name = 'SNWD_BPA' ).

"Step 4 : Insert test data into test double
partners_double->insert( test_data ).

Demo examples

您能够在这里个包里找到好些个单元测验的事例:

SABP_UNIT_DOUBLE_CDS_DEMO

可用性

CDS Test Double Framework从NetWeaver AS ABAP 7.51 release初始可用。

更加多新闻

报告bug的话,请为CSS组件BC-DWB-TOO-UT-CDS创建tickets。

小结:通过本文,你未来能够运用CDS Test Double Framework高效地为你在CDS中实现的代码下推来写自动化的测量检验!

 

触类旁通阅读:深深探討 Test Double、Dummy、Fake、Stub 、Mock 與 Spy

 

本文由第一星座网发布于传统文化,转载请注明出处:CDS测验框架介绍

上一篇:丹东凤台农商家招徕约请考试专项论题 下一篇:没有了
猜你喜欢
热门排行
精彩图文