我正在尝试在IRB工作,以便了解我在网上找到的一些代码。
我能够要求最终导入此文件的文件:
module LinkedIn
module Api
logger.debug "....7"
module QueryMethods
logger.debug "....6"
def profile(options={})
logger.debug "....1"
path = person_path(options)
simple_query(path, options)
end
def connections(options={})
path = "#{person_path(options)}/connections"
simple_query(path, options)
end
def network_updates(options={})
path = "#{person_path(options)}/network/updates"
simple_query(path, options)
end
def company(options = {})
path = company_path(options)
simple_query(path, options)
end
def test(options = {})
logger.debug "helllllooooo"
end
private
logger.debug "....2"
def simple_query(path, options={})
logger.debug "....3"
fields = options.delete(:fields) || LinkedIn.default_profile_fields
if options.delete(:public)
path +=":public"
elsif fields
path +=":(#{fields.map{ |f| f.to_s.gsub("_","-") }.join(',')})"
end
headers = options.delete(:headers) || {}
params = options.map { |k,v| "#{k}=#{v}" }.join("&")
path += "?#{params}" if not params.empty?
Mash.from_json(get(path, headers))
end
def person_path(options)
logger.debug "....4"
path = "/people/"
if id = options.delete(:id)
path += "id=#{id}"
elsif url = options.delete(:url)
path += "url=#{CGI.escape(url)}"
else
path += "~"
end
end
def company_path(options)
path = "/companies/"
if id = options.delete(:id)
path += "id=#{id}"
elsif url = options.delete(:url)
path += "url=#{CGI.escape(url)}"
elsif name = options.delete(:name)
path += "universal-name=#{CGI.escape(name)}"
elsif domain = options.delete(:domain)
path += "email-domain=#{CGI.escape(domain)}"
else
path += "~"
end
end
end
end
end
此代码是LinkedIn的包装,我在此处找到它:https://github.com/pengwynn/linkedin/blob/master/lib/linked_in/api/query_methods.rb
它主要是现成的,但这个测试位是我的:
def test(options = {})
logger.debug "helllllooooo"
end
我在本地复制了这些文件,在IRB中我可以执行一些命令,但由于某种原因,我不能做client.test
这样的事情,而我可以做client.profile
之类的事情。
同样没有调试语句出现在IRB中。我是否必须使用某种标志启动IRB以查看调试?
答案 0 :(得分:3)
logger是rails的一部分
irb只是一个ruby命令行解释器
使用'rails console'获取运行rails基础设施的命令行界面。
在使用irb时使用puts作为记录器的替代
修改
你永远不会试图在irb中运行该代码,而是将文件复制到yourapp / lib,然后执行
rails console
现在启动RAILS,但是使用命令行界面,然后尝试
包括LinkedIn :: Api :: QueryMethods
测试
现在你也可以使用logger.debug
答案 1 :(得分:0)
在寻找同一个问题的答案时,我尝试了这个,我在网上找到了它并且有效:
2.0.0-p353 :020 > ActiveRecord::Base.logger.debug "your whatever text"