草庐IT

log_info_without_trace

全部标签

ruby - 如何使用 mkmf.log 提示找不到 libiconv 安装 Nokogiri Ruby gem?

我正在安装RubyNokogirigem并发现以下错误。如何诊断并解决?#geminstallnokogiriBuildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingnokogiri:ERROR:Failedtobuildgemnativeextension..../opt/ruby/1.9.3-p194/bin/rubyextconf.rbcheckingforlibxml/parser.h...***extconf.rbfailed***CouldnotcreateMakefileduetosomere

ruby - 导轨 4 : Append to a "has_many" relation without saving to DB

在Rails3中,可以做类似some_post.comments.append(some_comment)的事情其中一些帖子是“有很多”评论的模型实例。我在Rails4中面临的问题是append方法现在保存到数据库(如push和),我只需要“附加”而不将附加的对象保存到数据库。我们如何在Rails4中实现这一点?我不能使用some_post.comments.build(some_comment.attributes)因为我需要保留some_comment中已经存在的其他关系实例。 最佳答案 在Rails中优雅地做到这一点非常困难。

ruby-on-rails - rails : Logging for code in the lib directory?

为保存在lib目录中的代码配置日志记录的最佳/最简单方法是什么? 最佳答案 有两种方法:假设您的库是独立的并且有一个模块,您可以将logger属性添加到您的模块并在您的库代码中的任何地方使用它。moduleMyLibrarymattr_accessor:loggerend然后,您可以使用config/initializers/中的初始化程序,或使用config/environment.rb中的config.after_initializeblock来初始化你的记录器,像这样:require'mylibrary'MyLibrary.l

ruby-on-rails - Rails 路线 : GET without param :id

我正在开发基于Rails的RESTAPI。要使用此API,您必须登录。关于这一点,我想在我的用户Controller中创建一个方法me,它将返回已登录用户信息的JSON。因此,我不需要在URL中传递:id。我只想调用http://example.com/api/users/me所以我尝试了这个:namespace:api,defaults:{format:'json'}doscopemodule::v1,constraints:ApiConstraints.new(version:1,default:true)doresources:tokens,:only=>[:create,:de

ruby-on-rails - 测试 : how to focus on behavior instead of implementation without losing speed?

似乎有两种完全不同的测试方法,我想引用它们。问题是,这些意见是在5年前(2007年)提出的,我很感兴趣,从那以后发生了什么变化,我应该走哪条路。BrandonKeepers:Thetheoryisthattestsaresupposedtobeagnosticoftheimplementation.Thisleadstolessbrittletestsandactuallyteststheoutcome(orbehavior).WithRSpec,Ifeellikethecommonapproachofcompletelymockingyourmodelstotestyourcontr

ruby :console.log?

我最近将console.log语句放在JavaScript程序的每一行中,发现它现在更容易理解了。有没有办法用服务器端代码,特别是Ruby来做到这一点?我想没有办法在firebug中读取它,但它在irb中可见吗?我会在Ruby代码中放入哪些console.log等效语句? 最佳答案 puts在ruby​​中是等价的。例子puts'HelloWorld!' 关于ruby:console.log?,我们在StackOverflow上找到一个类似的问题: https

ruby-on-rails - rails : Update model attribute without invoking callbacks

我有一个具有:credits属性的用户模型。我想要一个简单的按钮,它将通过名为“add”的路由将5添加到用户的积分中,以便/users/3/add将5添加到用户id=3的积分中。defadd@user=User.find(params[:id])@user.credits+=5redirect_toroot_pathend那是我Controller的相关部分。问题是,我不想调用@user.save,因为我有一个before_save回调,它根据当前的UTC时间重新加密用户的密码。我只想简单的给属性加5,避免回调,没想到这么简单的事情这么难。编辑:我将回调更改为:before_creat

ruby Rspec : Testing instance variables without adding an accessor to source

我正在尝试测试以下方法:defunprocess_move(board,move)ifmove[0].instance_of?(Array)multi_move=@multi_move.pop(2).reversemulti_move.eachdo|single_move|unapply_move(board,single_move)endelseboard=unapply_move(board,move)endboardend我想为@multi_move设置状态,但我不想添加仅用于测试的访问器。有没有办法在没有访问器的情况下这样做?谢谢。 最佳答案

ruby strftime : Month without leading zero?

Ruby的strftime是否具有不带前导零的月份格式?我发现%e的日期没有前导零,但月份没有任何运气。最终想要一个格式如下的日期:9/1/2010 最佳答案 某些版本的strftime确实允许使用前缀minus来格式化前导零,例如:strftime"%-d/%-m/%y"然而,这将取决于您系统上的strftime。所以为了保持一致性,我会做这样的事情:dt=Time.local(2010,'Sep',1)printf"%d/%d/%d",dt.day,dt.month,dt.year

ruby-on-rails - rails : Logging the entire stack trace of an exception

我一直在尝试找出记录堆栈跟踪的正确方法。我遇到了this链接指出logger.error$!,$!.backtrace是要走的路,但这对我不起作用log_error。根据文档,我看不出将第二个参数传递给错误方法是如何工作的,因为rails使用的ruby​​记录器只接受一个参数。奇怪的是(或者可能不是)第二个论点被接受了,没有任何口译员的提示。但是,我传递给它的任何内容都将被忽略。谁能解释一下我错过了什么?对错误的第二个论点是什么以及是什么吞噬了它有什么见解吗? 最佳答案 如果您查看ActiveSupport中BufferedLogg