4

我正在尝试针对单个模块功能编写单元测试。该模块与其他一些模块协作,因此我想模拟这些模块以隔离我的测试系统。这是一些简化的伪代码:

local moduleFoo={}
local moduleBaz=  require("moduleBaz") 

moduleFoo.doSomething = function (arg) 

  if moduleBaz.bar.neatMethod(arg) then
     --does something interesting  
  end

end

return moduleFoo

这是moduleBaz的代码

local moduleBaz={}
moduleBaz.bar= {}

moduleBaz.bar.neatMethod=function(arg)
   --does something neat
end
return moduleBaz

我正在尝试使用 package.preload 函数在测试运行之前注入 moduleBaz 的模拟实例,但它似乎不起作用(即在测试中使用了 moduleBaz 的真实实例,而不是我的模拟)

这是一些伪测试代码:

    package.loaded.moduleBaz= nil
    local moduleBaz = {}
    moduleBaz.bar = {}
    moduleBaz.bar.neatMethod= function(guid) return true end

    package.preload['moduleBaz'] = function ()
        return moduleBaz
    end

   local foo= require("moduleFoo")
   foo.doSomething('asdasdasda')--real moduleBaz is called, not my mock!

任何想法我做错了什么?我对 Lua 很陌生,对语言中如何处理范围完全不满意!

4

1 回答 1

8

您的 moduleBaz 代码中似乎缺少 return 语句

return moduleBaz

为什么不使用package.loaded它,因为它为您提供了更简单的界面?package.loaded.moduleBaz只需要包含您想从moduleBaz代码中返回的任何内容。像这样的东西应该可以工作或给你一个想法:

package.loaded.moduleBaz = {
  bar = {
    neatmethod = function(arg)
      -- your mock code here
    end,
  }
}

然后require('moduleBaz')将简单地返回您刚刚创建的那个对象。

我也无法重现您的设置问题。我使用的文件如下;请注意,我添加return moduleBaz了如上所述的内容,但这是我所做的唯一更改:

文件moduleBaz.lua

local moduleBaz={}
moduleBaz.bar= {}
moduleBaz.bar.neatMethod=function(arg)
  print "baz"
  return true
end
return moduleBaz

文件moduleFoo.lua

local moduleFoo={}
local moduleBaz=  require("moduleBaz") 
  moduleFoo.doSomething = function (arg) 
  if moduleBaz.bar.neatMethod(arg) then
    print "foo"
  end
end
return moduleFoo

文件testFoo.lua

package.loaded.moduleBaz= nil
local moduleBaz = {}
moduleBaz.bar = {}
moduleBaz.bar.neatMethod= function(guid) print "mock" return true end

package.preload['moduleBaz'] = function ()
    return moduleBaz
end

local foo= require("moduleFoo")
foo.doSomething('asdasdasda')--real moduleBaz is called, not my mock!

当我运行它时,我会mock\nfoo\n按预期打印。

于 2012-10-01T22:29:47.860 回答