我有一个小型框架,它使用内置于ruby中的Logger对象记录一些信息和调试消息。在运行时,这很好用。在单元测试时(使用rspec如果重要的话......)我想将记录的消息转储到内存字符串变量中。执行此操作最简单的方法是什么?我正在考虑一个猴子补丁来替换信息和调试方法,如下所示:classLoggerdefinfomsg$logs=msgsupermsgendend有没有更好的方法将我的日志消息发送到字符串变量? 最佳答案 使用StringIOrequire'stringio'require'logger'strio=Strin
Net::HTTP库中有一个非常有用的方法可以调试HTTP请求。这是文档对此的描述:set_debug_output(output)WARNINGThismethodcausesserioussecurityhole.Neverusethismethodinproductioncode.Setanoutputstreamfordebugging.http://ruby-doc.org/stdlib/libdoc/net/http/rdoc/classes/Net/HTTP.html#M001371这里提到的安全漏洞是什么? 最佳答案
我在开发中通过ActionMailer发送时遇到问题,在我的本地主机上,使用Rails2.3.2和Ruby1.8.6.development.log显示它已经“发送”了没有错误的电子邮件,但是没有收到电子邮件。我尝试了多个用于发送和接收的电子邮件地址,并尝试了多个配置和插件,但无法发送电子邮件。任何帮助将不胜感激-我觉得我正在围绕不同版本的rails和ruby的一堆解决方案版本跳舞并且无法确定它。如有任何意见,我将不胜感激。谢谢!插件:Action邮件程序可选tlssmtp_tls不同的电子邮件配置:ActionMailer::Base.smtp_settings={:enable
我正尝试在我的Rails日志中获取更多信息,特别是请求的URI或当前参数(如果可用)(我很感激它们不会总是如此)。但是我似乎做不到。这是我到目前为止所做的:#config/environments/production.rbconfig.logger=Logger.new(config.log_path)config.log_level=:errorconfig.logger.level=Logger::ERROR#config/environment.rbclassLoggerdefformat_message(level,time,progname,msg)"***********
在与不同数据库有多个连接的ActiveRecord应用程序中,日志中没有任何内容表明哪个查询去了哪个数据库。这些查询分离数据库:Base1.connection.select_value("select*fromfoo")Base2.connection.select_value("select*fromfoo")发出这些日志条目:D,[2017-03-13T09:27:11.844395#22112]DEBUG--:(0.6ms)select*fromfooD,[2017-03-13T09:27:11.844539#22112]DEBUG--:(0.1ms)select*fromfo
我很惊讶我已经无法在SO上找到它了。我希望能够为输出到控制台的日志输出中的特定字符串段着色。所以像这样:"ThispartofthemessageinGreen:ThispartinBlue"可能是这样写的:Rails.logger.debug("ThispartofthemessageinGreen:".green+"ThispartinBlue".blue) 最佳答案 基本上,您要做的是将颜色的ANSI转义序列嵌入到调试字符串中,就像您在常规Ruby程序中所做的那样。有几种方法可以解决这个问题:使用rainbowgem,它允许你
我有一个包含ActiveRecord和ActiveResource模型的大型项目。我需要使用这些模型实现用户事件的日志记录,还需要记录模型属性的更改(保存对象状态或类似的东西)。用户或cronrake任务可以进行更改。我还必须能够按日期、任何字段等搜索任何数据例如,生成带有上次事件的可读消息也很好UserBobchangehispasswordto*andemailto**at2011-08-1208:12StaffJeffaddednewpartner:Companynameat2011-08-1208:13AdminJackdeletedproduct:Productnameat2
今天疯狂的想法。有没有办法获取代码执行的行号?Logger.info"Iwasrunonline#{get_line_number}" 最佳答案 您可以使用__LINE__变量。看这个https://stackoverflow.com/a/2496240/100466也回答一下。 关于ruby-在Ruby中获取当前代码行,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/121757
我为我的应用程序创建了一个自定义记录器,称为CRON_LOG,只需将这段代码添加到config/environment.rbCRON_LOG=Logger.new("#{Rails.root}/log/cron.log")CRON_LOG.level=Logger::INFO然后,当我想记录一些东西时,就这样做:CRON_LOG.info"something"它工作正常,但我想在每条日志消息之前添加当前时间戳。当然,我可以将Time.now添加到我的日志消息中,但我想知道是否有一种方法可以将它作为默认值添加到每条日志消息中。我该怎么做?谢谢。 最佳答案
在rails3.2中是否有一种方法(一个gem、一个插件或其他东西)来知道哪一行代码触发了一个数据库查询?例如在我的日志中我有:UserLoad(0.4ms)SELECT`users`.*FROM`users`WHERE`users`.`id`=5LIMIT1如何知道触发查询的代码行?谢谢... 最佳答案 我找到了这个解决方案:moduleQueryTracedefself.enable!::ActiveRecord::LogSubscriber.send(:include,self)enddefself.append_featur