草庐IT

几英里之外没有更新重新加载

全部标签

ruby - 有没有一种干净的方法来测试 Rspec 中的 ActiveRecord 回调?

假设我有以下ActiveRecord类:classToastMitten是否有一种干净的方法来测试:brush_off_crumbs是否已设置为before_save回调?我所说的“干净”是指:“没有实际保存”,因为它很慢我不需要测试ActiveRecord是否正确处理before_save指令;我需要测试我是否正确地告诉它在保存之前要做什么。“没有通过未记录的方法进行黑客攻击”我找到了满足标准#1但不满足标准#2的方法:it"shouldcallhavebrush_off_crumbsasabefore_savecallback"do#undocumentedvoodoobefore

ruby - 手动更新 Carrierwave Uploader 安装的属性

我无法对由载波uploader装载的属性使用model.update_attribute。SQL语句不会接受该值并将NULL添加到占位符。如果我从模型类中删除mount_uploader语句,它会正常工作。我正在从控制台进行故障排除并尝试在为数据库播种时添加一些属性,这阻碍了我的努力。想法?谢谢。更新:相关代码:classProfile我只是想从数据库种子文件重写:avatar字符串,同时从Rails控制台进行测试,如下所示:Profile.first.update_attribute(:avatar,'foo')当我注释掉mount_uploader行时,两者都有效。添加mount_

ruby - 在没有猴子修补的情况下禁用 Rack::CommonLogger

所以,我想为我的sinatra应用程序完全自定义日志记录,但我似乎无法禁用Rack::CommonLogger。根据sinatradocs我需要做的就是添加以下行(也尝试将其设置为false):set:logging,nil我的配置。但是,这不起作用,我仍然在我的终端中收到类似Apache的日志消息。所以到目前为止我找到的唯一解决方案就是猴子修补这该死的东西。moduleRackclassCommonLoggerdefcall(env)#donothing@app.call(env)endendend如果可以在不恢复此类问题的情况下禁用它,有人有任何想法吗?

ruby-on-rails - 我可以在没有 Controller 的情况下直接从 routes.rb 渲染布局吗?

我想为网站的管理和公共(public)部分设置一对样式指南。每个都需要自己的布局,其中包含静态html和调用erbpartials的混合(因此静态页面不会削减它)。我不需要Controller来为这些页面提供服务,而且我不希望有效的仅开发内容使其余代码困惑。这让我想知道是否有一种方法可以直接呈现布局。免责声明:我明白这不是我应该经常/永远做的事情,而且我知道有很多争论可以解释为什么这是一个坏主意。我对这是否可能感兴趣。有没有办法让我直接从routes.rb渲染布局而不通过Controller? 最佳答案 出于某种奇怪的原因,我想暂时

ruby-on-rails - 我如何在邮件程序之外使用 Devise 的 `confirmation_url`?

我在Rails项目中使用Devise。我想将确认网址传递给第三方。该url由以下DeviseMailerView中的表达式confirmation_url(@resource,confirmation_token:@token)生成:https://github.com/plataformatec/devise/blob/master/app/views/devise/mailer/confirmation_instructions.html.erb我已经grep了Devise的整个源代码,试图找出confirmation_url定义的人或位置,但我找不到任何东西;它只出现在View中

ruby-on-rails - 了解 Rails 中的简单 ActiveRecord 更新

我刚刚深入研究ActiveRecord,但未能找到我的问题的答案。如果我正在更新对象的属性然后调用save()...ActiveRecord是否仅在新值与旧值不同时才保存到数据库?假设我做了这样的事情:thing_to_update=Thing.find_or_create_by_code(some_code)ifthing_to_update.name!=some_namething_to_update.update_attribute(:name,some_name)end如果不需要的话,我不想对数据库进行额外的调用,因为我可能不得不更新很多对象。我试图通读文档,但它没有提及任何关

ruby-on-rails - 成功发送延迟作业电子邮件后更新用户表

我是一个尝试使用delayed_job的NOOB。我想在使用延迟作业成功发送邮件后更新用户模型。发送邮件:UserMailer.delay.welcome_email(user)如果邮件发送成功,请执行以下操作:User.update_attributes(:emailed=>true)邮件发送成功后如何回调或触发? 最佳答案 您需要创建一个Job对象而不是调用#delay帮助程序。您可以使用successHook来执行回调。classWelcomeEmailJob 关于ruby-on-

ruby - RVM:在系统范围安装中从 .rvmrc 文件加载 gemset 时权限被拒绝

我创建了一个包含自定义gemset的项目特定.rvmrc文件(使用命令rvm--rvmrc--create1.9.2@registration):#excerptof.rvmrc...environment_id="ruby-1.9.2@registration"if[[-d"${rvm_path:-$HOME/.rvm}/environments"\&&-s"${rvm_path:-$HOME/.rvm}/environments/$environment_id"]]then\."${rvm_path:-$HOME/.rvm}/environments/$environment_id

ruby - 父类(super class)不匹配、结构、重新加载和 Spork

假设有下面这个类#derp.rbclassDerp当我加载“./derp.rb”两次时,程序因TypeError:superclassmismatchforclassDerp而失败。好的,这可以通过require来管理。但是我如何为每次使用Spork的测试运行重新加载这些类?require显然不会工作,因为它会缓存加载的文件。 最佳答案 Struct.new正在为您的每次加载创建新类。irb(main):001:0>classTest1classTest1'您可以将返回的Struct.newclass保存到一个变量中,然后您可以使用

ruby - 使用 open-uri 和 nokogiri 在完全加载之前读取 HTML

我正在使用open-uri和nokogiri以及ruby​​来进行一些简单的网络爬虫。有一个问题,有时html在完全加载之前就被读取了。在这种情况下,我无法获取加载图标和导航栏以外的任何内容。告诉open-uri或nokogiri等待页面完全加载的最佳方法是什么?目前我的脚本是这样的:require'nokogiri'require'open-uri'url="https://www.the-page-i-wanna-crawl.com"doc=Nokogiri::HTML(open(url,ssl_verify_mode:OpenSSL::SSL::VERIFY_NONE))puts