草庐IT

save_path

全部标签

ruby-on-rails - 防止实例上的 ActiveRecord save()

我有一个ActiveRecord模型对象Foo;它代表一个标准的数据库行。我希望能够显示该对象实例的修改版本。我想重用类本身,因为它已经具有我需要的所有Hook和方面。(例如:我已经有一个显示适当属性的View)。基本上我想克隆模型实例,修改它的一些属性,并将它反馈给调用者(View、测试等)。我不希望这些属性修改返回到数据库中。但是,我确实希望在克隆版本中包含id属性,因为它可以更轻松地处理路由助手。因此,我计划调用ActiveRecord::Base.clone(),手动设置克隆实例的ID,然后对新实例进行适当的属性更改。不过这让我很担心;修改后的实例上的一个save()和我的原始

ruby-on-rails - before_save 在验证后运行吗?

我的自定义验证似乎在我的before_saveblock之前运行,这对我来说很奇怪。我知道before_validation,但我正在尝试测试我的自定义验证器,所以before_validationHook不允许我这样做。我还读到测试私有(private)方法(我的验证器)是不好的做法。我该怎么办?更多信息:我们希望用户能够上传带有URL或文件的文档,但不能同时上传或不上传(xor)。我的验证器检查这些的异或。如果用户编辑文档,before_saveHook会删除当前的URL或文件。理论上,流程应该是:上传文件验证并保存上传网址before_save、验证、保存但在我的测试中,我收到验

ruby - 如何在 Rails 4 中访问 *_path 和 *_url 助手

我正在阅读Rails:Checkoutputofpathhelperfromconsole并且没有一个解决方案对我有用,大概是因为它们都适用于Rails2/3。在Rails4/5中,如何从Rails控制台访问*_path和*_url助手? 最佳答案 运行Rails4,我得到它们:app.root_path=>"/"app.users_url=>"http://www.example.com/users" 关于ruby-如何在Rails4中访问*_path和*_url助手,我们在Stack

ruby - `save` 和 `save!` 是唯一持久化 ActiveRecord 对象的方法吗?

我正在尝试调试一些代码。一个奇怪的部分是before_save回调被调用了两次,尽管我只打算保存对象一次。为了追踪这是如何发生的,我在类中定义了这些方法:%w[savesave!].eachdo|method_name|define_method(method_name)do|*args|puts"whocalled'#{method_name}'?#{caller.first}"super(*args)endend从这个输出中,我只看到一个持久化调用。我相信save和save!是导致ActiveRecord持久化对象的唯一方法。据我所知,其他持久化方法依赖于这两者之一;例如,upda

ruby-on-rails - Rails Brakeman 警告 : Dynamic Render Path false alarm?

我刚刚开始使用Rails,所以我使用Brakeman了解我的新手代码中的潜在漏洞。它在我的show.js.erb文件中抛出关于以下代码的高置信度“动态渲染路径”警告:$('#media-fragment').html('');我实际上预料到这是一个问题,所以不足为奇。所以我将其更改为以下内容:#controller:defshowiflegal_partial?@allowed_partial=params[:partial]elseraiseStandardError,"unexpectedpartialrequest:#{params[:partial]}"endendprivat

Ruby - 打开 ("file_path") - Errno::ENOENT: 没有那个文件或目录

尝试打开文件时,我不断收到此Nosuchfileordirectory错误。我在做:file=open("http://farm7.static.flickr.com/6064/6090089285_242ca0e342_m.jpg")根据ruby-doc并不断收到这样的错误。我做错了什么? 最佳答案 你必须require'open-uri'不需要'open-uri',我在我的irb中得到了这个确切的错误消息:Errno::ENOENT:Nosuchfileordirectory 关于R

ruby-on-rails - "save(false)"是做什么的?

在下面的代码中,save(false)做了什么?defcreate_reset_code!@reset=trueself.attributes={:reset_code=>Digest::SHA1.hexdigest(Time.now.to_s.split(//).sort_by{rand}.join)}save(false)end如果是为了更新凭据,那为什么要包含false? 最佳答案 save(false)绕过对正在保存的模型对象的验证。 关于ruby-on-rails-"save(

ruby - $:<< "." do to Ruby's require path? 是什么意思

我不明白$:的意思在Ruby中。我将Ruby升级到1.9.1,但程序无法运行。我的同学告诉我,我应该添加$:什么是$:做? 最佳答案 $:是包含构成Ruby加载路径的路径数组的变量将一个项目追加到数组的末尾.引用当前目录123|||VVV$:所以你正在将当前目录添加到Ruby的加载路径引用资料:可以在ExecutionEnvironmentVariables中找到此页面的一部分来自ThePragmaticProgrammersGuideAnarrayofstrings,whereeachstringspecifiesadirecto

ruby-on-rails - "require File.expand_path(' ../../config/environment', __FILE__)"到底做什么?

我一直在尝试更深入地了解Ruby,解构样板式rails应用程序似乎是了解编写跨不同文件和目录的Ruby应用程序的一些细节和优雅的好方法。在我当前的应用程序中,文件之间对“requires”的依赖变得有点问题(我发现我需要做一些事情,比如requires'../../../lib/helper'它变得有点丑陋。我注意到Rails应用程序似乎不受此影响。我确实注意到了这条线:requireFile.expand_path('../../config/environment',__FILE__)当我用谷歌搜索时,我发现很多关于Rails启动例程等的解释,但没有关于该行到底做什么的明确描述。在

ruby - capybara -webkit : automatically save a screenshot on an RSpec test failure

当使用带有Rspec的capybara-webkit测试失败时,如何自动保存html和屏幕截图?如何在RSpec测试失败时执行回调。奖励积分:如何避免出现以下错误:Capybara::Driver::Webkit::WebkitInvalidResponseError执行这段代码时:require'capybara/util/save_and_open_page'path="/#{Time.now.strftime('%Y-%m-%d-%H-%M-%S')}"png=Capybara.save_and_open_page_path+"#{path}.png"page.driver.re