3

我正在对我们的 SSAS 表格项目的自动化测试工具进行一些研究。我找到了 NBI,觉得它真的很酷。我尝试设置它并成功运行了一些基本测试。但是,当我尝试测试 dax 计算时,它显示“未找到函数”(见屏幕截图)。听起来它不支持 SUM,但鉴于 SUM 是一个基本功能,我想它应该可以工作。因为我是这个工具的新手,所以我想仔细检查我是否做错了什么,或者这只是错误的意思......(不支持的功能)。

我回去查看了 NBI 文档,它提到要检查他们的 NCAL.dll 以获取所有可用的表达式。不幸的是,我无法打开该 dll 文件的可读版本。任何帮助表示赞赏。

这是我要测试的公式:

=SUMX(FILTER(MyTable, AND(MyTable[Date] = EARLIER(MyTable[Date]), MyTable[Account] = EARLIER(MyTable[Account]))), MyTable[Amount])

在此处输入图像描述

XML 代码 (nbits) 文件

 <test name="My second test: Calculated column compared to DAX formula">
  <system-under-test>
   <execution>
    <query connectionString="Provider=MSOLAP.7;Data Source...">
     <![CDATA[    
    EVALUATE
    SUMMARIZE (MyTable, MyTable[Date], MyTable[Account], MyTable[Amount], MyTable[CalculatedAmount])
     ]]>
    </query>
   </execution>
  </system-under-test>
  <assert>
    <evaluate-rows>
      <variable column-index="0">Date</variable>
      <variable column-index="1">Account</variable>
      <variable column-index="2">Amount</variable>
      <variable column-index="3">CalculatedAmount</variable>
      <expression column-index="3" type="numeric" tolerance="0.01"> = SUMX(FILTER(MyTable, AND(MyTable[Date] = EARLIER(MyTable[Date]), MyTable[Account] = EARLIER(MyTable[Account]))), MyTable[Amount])</expression>
    </evaluate-rows>
  </assert>
 </test>
4

1 回答 1

3

NBI 支持在查询标签中而不是在表达式标签中评估 DAX 查询。表达式和评估行标签并非旨在比较两个查询。为此,请更改您的测试以在两个查询之间使用断言 equalTo。它会更容易并且会起作用。

我想一个更好的问题是如何测试度量和计算列,以确保另一个开发人员不会意外更改我在设计表格模型时输入的计算/表达式?

我将从三个层面回答:概念、逻辑和技术。

在概念层面上,您的测试是错误的:您永远不应该在断言和被测系统中使用相同的实现。这不是特定于 NBI 或任何框架,而是特定于所有自动化测试。测试的作用不是确保某人不会改变某事,而是确保某事给出正确的结果。即使您的实现是错误的,将工件与其自身进行比较总是会导致绿色测试。在这种情况下,您必须使用具体的静态结果更改您的断言,或者您需要创建一个 sql 语句来导致对数据库进行相同的计算,或者在 MDX 中找到另一个查询,从而得到相同的结果。

在逻辑层面,以下句子是不正确的

这是我要测试的公式:

您已经在您的assert而不是在您的system-under-test. 这意味着这不是您要测试的内容,而是您的参考资料(您 100% 确定它是正确的)。您正在测试的是 query EVALUATE SUMMARIZE (MyTable, MyTable[Date], MyTable[Account], MyTable[Amount], MyTable[CalculatedAmount])

在技​​术层面上,使用评估行不是正确的选择。这个断言不需要函数或查询,而是基于行变量的表达式(没有 DAX,没有 SQL,...)。的使用EARLIER是一个明确的信号,表明它是不可能的。在您的情况下,您必须比较两个查询,可能是:

<assert>
  <equalTo>
    <column index="0" role="key" type="dateTime"/>
    <column index="1" role="key" type="numeric"/>
    <column index="2" role="value" type="numeric"/>
    <column index="3" role="value" type="numeric" tolerance="0.01"/>
    <query>
      EVALUATE SUMMARIZE (MyTable, MyTable[Date], MyTable[Account], MyTable[Amount], SUMX(FILTER(MyTable, AND(MyTable[Date] = EARLIER(MyTable[Date]), MyTable[Account] = EARLIER(MyTable[Account]))), MyTable[Amount])
    </query>
  </equalTo>
</assert>

PS:我显然不是 DAX 专家,从语法的角度来看,我不确定上面的查询是否有效。

于 2016-07-06T22:22:52.573 回答