1

我的雷模块:

define(['Util', 'Vector3f'], function (Util, Vector3f) {
  var Ray = {}
  Ray.o = null;
  Ray.d = null;
  Ray.depth = 0;
  Ray.mint = 0.03;
  Ray.maxt = null;
  return Ray;
});

我的单元测试:

describe(".moveAlong(Number t)", function(){
  it("returns a point at distance t in the direction of the ray", 
  function(){
    expect(4).toBe(null); //unimplemented unit test always fails
  });
});

Ray.o 是射线的起源。Ray.d 是射线的方向。我希望 Ray.moveAlong(t) 返回一个点 q,使得 q = o + d*t。

我对单元测试的理解是,如果我真的在单元测试中包含了我的 Vector3f 模块,这样我就可以给 Ray 一个起点和一个方向,我实际上在做的就是集成测试。但是我需要 Vector3f 模块中的 add() 和 mulScalar() 方法才能在 moveAlong(t) 中计算 ray.d + ray.d*t。

在这里处理我的 Vector3f 依赖项有哪些选择?我不知道如何合理地排除它,但排除依赖关系并一次只测试一种方法是单元测试的重点。

4

1 回答 1

1

单元测试选项:

第一个选项:
只需为 Ray.o、Ray.d 传入 Vector3f 对象

优点:
- 容易。

缺点:
- 保留测试中的依赖性。
- 更新不在此测试 (Vector3f) 下的组件可能需要更新此测试。

第二个选项:
创建存根 Vector3fs,每个只实现 Vector3f 模块的 add(Vector3f v)、mulScalar(Number t) 方法。这在 Javascript 中非常简单,因为引用是无类型的,任何具有正确方法的对象都可以替代“正确”的对象。这让我认为尝试将 OOP 硬塞到这个项目中是一个坏主意,但我不确定如何处理这个问题,这是另一个问题的主题。

优点:
- 在测试代码中打破 Ray 和 Vector3f 之间的依赖关系,因此对 Vector3f 的进一步更改不会导致 Ray 单元测试失败,这减少了在 Vector3f 发生故障时要检查的失败测试的数量。

缺点:
- 测试中有更多代码。
- 如果 Vector3f 以使其通过所有单元测试的方式进行更改,但破坏了 Ray 的功能,那么我们也不会在 Ray 单元测试中看到它,因为对 Vector3f 的依赖已被破坏。

我不确定最后一个 con 是否有问题 - 如果 Vector3f 正在通过其所有单元测试,那么它正在遵守与系统其他组件的合同,所以我们不应该看到 Vector3f 的测试全部通过但它会导致其他组件损坏。此外,这是一个集成级别的问题,而不是单元级别的问题。

我认为第二种选择是要走的路。

于 2012-09-15T19:23:54.733 回答