草庐IT

ruby-on-rails - rails : How do I write tests for a ruby module?

我想知道如何为混合到几个类中的模块编写单元测试,但不太知道如何去做:我是通过在其中一个测试文件中为包含它们的类编写测试来测试实例方法(似乎不正确),还是您能以某种方式将包含方法的测试保存在特定的单独文件中到模块?同样的问题也适用于类方法。我应该像普通Rails模型那样为模块中的每个类创建一个单独的测试文件,还是它们存在于通用模块测试文件中(如果存在)? 最佳答案 恕我直言,您应该进行涵盖模块所有用途的功能测试覆盖率,然后在单元测试中对其进行隔离测试:setupdo@object=Object.new@object.extend(Gr

ruby-on-rails - Ruby 模块中常量的作用域

我在mixin模块中遇到常量作用域的小问题。假设我有这样的东西moduleAuthUSER_KEY="user"unlessdefined?USER_KEYdefauthorizeuser_id=session[USER_KEY]defend除非已经定义,否则USER_KEY常量应默认为“user”。现在我可能会把它混合到几个地方,但在其中一个地方USER_KEY需要不同,所以我们可能有这样的东西classApplicationController我希望USER_KEY在授权中使用时会是“my_user”,因为它已经定义,但它仍然是“用户”,取自USER_KEY的模块定义。有人知道如何

ruby - 何时在 Ruby 中使用 `require` 、 `load` 或 `autoload` ?

我理解Ruby中require、load和autoload之间的细微差别,但我的问题是,你怎么知道要加载哪一个利用?除了能够在匿名模块中“包装”load之外,require似乎是首选。但是autoload允许您延迟加载文件——这听起来很棒,但我不确定您实际上比require获得了什么一种方法优于另一种方法吗?是否存在一种方法脱颖而出的情况? 最佳答案 通常,您应该使用require。load每次都会重新加载代码,因此如果您从多个模块执行此操作,将会做很多额外的工作。autoload的惰性在理论上听起来不错,但许多Ruby模块会做一些

ruby - 如何在 Ruby 中初始化模块的实例变量?

我有一些模块,我想在其中使用实例变量。我目前正在像这样初始化它们:moduleMyModuledefself.method_a(param)@var||=0#otherlogicgoeshereendend我也可以调用一个init方法来初始化它们:definit@var=0end但这意味着我必须记住始终调用它。有更好的方法吗? 最佳答案 在模块定义中初始化它们。moduleMyModule#selfhereisMyModule@species="frog"@color="redpolka-dotted"@log=[]defself.

ruby-on-rails - Rails/lib 模块和

我正在为open_flash_chart插件编写自定义包装器。它位于/lib中,并将其作为模块加载到ApplicationController中。但是,我遇到了类层次结构问题或其他问题。我可以从任何Controller访问open_flash_chart功能,如OpenFlashChart、Line等。但是,在/lib模块的类中,它不起作用!有什么想法吗? 最佳答案 在Rails中加载文件有两种方式:它在自动加载过程中注册,您引用一个与文件名对应的常量。例如,如果您有app/controllers/pages_controller.

ruby-on-rails - Rails 模块中的 mattr_accessor 是什么?

我真的无法在Rails文档中找到它,但似乎'mattr_accessor'是'attr_accessor'的模块推论(getter和setter)在普通的Ruby类中。例如。在类里面classUserattr_accessor:namedefset_fullname@name="#{self.first_name}#{self.last_name}"endend例如。在模块中moduleAuthenticationmattr_accessor:current_userdeflogin@current_user=session[:user_id]||nilendend此辅助方法由Acti

ruby - 在 Ruby 中创建模块变量

有没有什么方法可以在Ruby模块中创建一个行为类似于类变量的变量?我的意思是,无需初始化模块实例即可访问它,但它可以更改(与模块中的常量不同)。 最佳答案 Ruby原生支持模块中的类变量,因此您可以直接使用类变量,而不是一些代理或伪类变量:moduleSite@@name="StackOverflow"defself.setName(value)@@name=valueenddefself.name@@nameendendSite.name#=>"StackOverflow"Site.setName("Test")Site.name

ruby 继承 vs mixins

在Ruby中,由于您可以包含多个混入但只能扩展一个类,因此混入似乎优于继承。我的问题:如果您正在编写必须扩展/包含才能有用的代码,您为什么要把它变成一个类?或者换句话说,你为什么不总是把它做成一个模块?我只能想到您想要一个类的一个原因,那就是您是否需要实例化该类。然而,在ActiveRecord::Base的情况下,您永远不会直接实例化它。那么它不应该是一个模块吗? 最佳答案 我只是在TheWell-GroundedRubyist中阅读了有关此主题的信息(顺便说一句,好书)。作者比我解释得更好,所以我会引用他的话:没有任何单一的规则

ruby - 我可以在不包含 Ruby 模块的情况下调用实例方法吗?

背景:我有一个模块声明了一些实例方法moduleUsefulThingsdefget_file;...defdelete_file;...defformat_text(x);...end我想从一个类中调用其中一些方法。你通常如何在ruby​​中这样做:classUsefulWorkerincludeUsefulThingsdefdo_workformat_text("abc")...endend问题includeUsefulThings从UsefulThings引入所有方法。在这种情况下,我只需要format_text并且明确不需要get_file和delete_file。我可以看到几

ruby - Ruby 中的 include 和 extend 有什么区别?

刚开始了解Ruby元编程。mixin/modules总是让我困惑。include:在目标类中混入指定的模块方法作为实例方法extend:将指定的模块方法混入目标类中作为类方法那么主要的区别仅仅是这个还是潜伏着一条更大的龙?例如moduleReusableModuledefmodule_methodputs"ModuleMethod:Hithere!"endendclassClassThatIncludesincludeReusableModuleendclassClassThatExtendsextendReusableModuleendputs"Include"ClassThatIn