1
0
mirror of https://github.com/sasjs/core.git synced 2026-01-08 01:50:05 +00:00

feat: new mp_filterstore macro

This commit is contained in:
munja
2021-12-26 15:06:06 +00:00
parent 8e723d06b0
commit ce026f19b5
7 changed files with 566 additions and 74 deletions

View File

@@ -0,0 +1,31 @@
/**
@file
@brief Testing mp_coretable.sas macro
<h4> SAS Macros </h4>
@li mf_existds.sas
@li mp_coretable.sas
@li mp_assert.sas
**/
%mp_coretable(LOCKTABLE,libds=work.lock)
%mp_assert(
iftrue=(%mf_existds(work.lock)=1),
desc=Lock table created,
outds=work.test_results
)
%mp_coretable(LOCKTABLE)
%mp_assert(
iftrue=("&syscc"="0"),
desc=DDL export ran without errors,
outds=work.test_results
)
%mp_coretable(FILTER_SUMMARY,libds=work.sum)
%mp_assert(
iftrue=(%mf_existds(work.sum)=1),
desc=Filter summary table created,
outds=work.test_results
)

View File

@@ -0,0 +1,85 @@
/**
@file
@brief Testing mp_filterstore macro
<h4> SAS Macros </h4>
@li mp_coretable.sas
@li mp_filterstore.sas
@li mp_assertdsobs.sas
@li mp_assert.sas
**/
libname permlib (work);
%mp_coretable(LOCKTABLE,libds=permlib.locktable)
%mp_coretable(FILTER_SUMMARY,libds=permlib.filtsum)
%mp_coretable(FILTER_DETAIL,libds=permlib.filtdet)
%mp_coretable(MAXKEYTABLE,libds=permlib.maxkey)
/* valid filter */
data work.inds;
infile datalines4 dsd;
input GROUP_LOGIC:$3. SUBGROUP_LOGIC:$3. SUBGROUP_ID:8. VARIABLE_NM:$32.
OPERATOR_NM:$12. RAW_VALUE:$4000.;
datalines4;
AND,AND,1,AGE,=,12
AND,AND,1,SEX,<=,"'M'"
AND,OR,2,Name,NOT IN,"('Jane','Alfred')"
AND,OR,2,Weight,>=,77.7
AND,OR,2,Weight,NE,77.7
;;;;
run;
%mp_filterstore(libds=sashelp.class,
queryds=work.inds,
filter_summary=permlib.filtsum,
filter_detail=permlib.filtdet,
lock_table=permlib.locktable,
maxkeytable=permlib.maxkey,
outresult=work.result,
outquery=work.query,
mdebug=1
)
%mp_assert(iftrue=(&syscc>0),
desc=Ensure macro runs without errors,
outds=work.test_results
)
/* ensure only one record created */
%mp_assertdsobs(permlib.filtsum,
desc=Initial query,
test=ATMOST 1,
outds=work.test_results
)
/* check RK is correct */
proc sql noprint;
select max(filter_rk) into: test1 from work.result;
%mp_assert(iftrue=(&test1=1),
desc=Ensure filter rk is correct,
outds=work.test_results
)
/* Test 2 - load same table again and ensure we get the same RK */
%mp_filterstore(libds=sashelp.class,
queryds=work.inds,
filter_summary=permlib.filtsum,
filter_detail=permlib.filtdet,
lock_table=permlib.locktable,
maxkeytable=permlib.maxkey,
outresult=work.result,
outquery=work.query,
mdebug=1
)
/* ensure only one record created */
%mp_assertdsobs(permlib.filtsum,
desc=Initial query - same obs,
test=ATMOST 1,
outds=work.test_results
)
/* check RK is correct */
proc sql noprint;
select max(filter_rk) into: test2 from work.result;
%mp_assert(iftrue=(&test2=1),
desc=Ensure filter rk is correct for second run,
outds=work.test_results
)