我正在尝试找出一种在这里测试find_communities
的最佳方法,而不必在这里使用多态性来击败盯着我的if
语句。
class CommunityFinder
def initialize(filters={})
@filters = filters
end
def find_communities
return my_communities if @filters[:my_communities]
visible_communities
end
def my_communities
# [...]
end
def visibile_communities
# [...]
end
end
我对my_communities
和visible_communities
都进行了良好的测试,但是我对测试find_communities
感到担忧。
my_communities
和visible_communities
的测试设置,因为可能会重复find_communities
的条件永远不会改变。我应该:
find_communities
驻留在呼叫者中find_communities
设为自己的策略find_communities
答案 0 :(得分:2)
在此示例中,您确实应该有两个子类,每个子类实现自己的communities
方法:
class CommunityFinder::Base
def initialize(**options)
@options = options
end
end
class CommunityFinder::Mine < CommunityFinder::Base
def communities
end
end
class CommunityFinder::Visible < CommunityFinder::Base
def communities
end
end
您可以使用工厂方法来实例化正确的子类:
module CommunityFinder
def self.filter(**options)
if (options[:my_communities])
CommunityFinder::Mine.new(options)
else
CommunityFinder::Visible.new(options)
end
end
end