草庐IT

ios - NSOperationQueue 和传递数据

全部标签

ruby - ActiveRecord 3.1.0 多数据库

我正在尝试将ActiveRecordgem升级到最新的3.1.0版本并看到出现了很多异常,我认为这是由于我们处理多个数据库的方式所致。对于我们的每个数据库,我们指定一个单独的基类,它继承自ActiveRecord::Base,并在其中调用establish_connection。没有跨数据库关系。到目前为止,这对我们来说效果很好。升级到ActiveRecord3.1.0后,我看到它在遍历关系时失败并出现ActiveRecord::ConnectionNotEstablished异常(即,它将成功地从数据库,但在导航到相关类时失败)。回溯的第一行是C:/Ruby/lib/ruby/gem

ruby-on-rails - 数据库锁在 Rails 和 Postgres 中无法正常工作

我在Rails模型中有以下代码:foo=Food.find(...)foo.with_lockdoifbar=foo.bars.find_by_stuff(stuff)#dosomethingwithbarelsebar=foo.bars.create!#dosomethingwithbarendend目标是确保正在创建的类型的Bar不会被创建两次。在控制台测试with_lock的效果证实了我的预期。然而,在生产中,似乎在某些或所有情况下锁都没有按预期工作,并且正在尝试冗余Bar——因此,with_lock不会(总是?)导致代码等待轮到它.这里会发生什么?更新对所有说“锁定foo不会帮

ruby - 如何获取使用 IO.popen 调用的命令的退出状态?

我正在使用IO.popen执行命令并像这样捕获输出:process=IO.popen("sudo-uservice_user-istart_service.sh")do|io|whileline=io.getsline.chomp!process_log_line(line)endend如何捕获*start_service.sh*的退出状态? 最佳答案 您可以通过引用$?捕获通过IO.open()调用的命令的退出状态,只要您关闭了block末尾的管道即可。在上面的例子中,你会这样做:process=IO.popen("sudo-us

ruby-on-rails - 我如何序列化 - 反序列化哈希以将其保存在数据库中?

我有一个散列:h={"revision"=>7,"rev"=>"708a4bd5b","thumb_exists"=>false,"bytes"=>246000,"modified"=>"Sun,01Jul201217:09:15+0000","client_mtime"=>"Sun,01Jul201217:09:15+0000","path"=>"/GettingStarted.pdf","is_dir"=>false,"icon"=>"page_white_acrobat","root"=>"dropbox","mime_type"=>"application/pdf","size

ruby - 如何使用续集创建数据库

我已阅读所有sequel的文档,但我找不到创建数据库的方法,假设我可以做到这一点。我正在运行这样的rake任务:require'rubygems'require'bundler/setup'require'pg'require'sequel'require'yaml'require'erb'namespace:dbdotask:connectdoendtask:create=>:connectdoputsdb_configSequel.connect(db_config['production']){|db|db.create_table:userdoprimary_key:idStr

ruby - 在命令行上将参数传递给 Rspec 测试

我正在尝试使用RSpec对我的RESTapi进行功能测试。我希望它的工作方式是使用CI构建来构建我的应用程序并将其部署到云中某处的测试服务器,然后让它启动自动化功能测试。但是为了正确地做到这一点,我需要能够传递应用程序部署位置的基本url/域。它不会是一样的。到目前为止,我发现的所有内容都表明RSpec似乎无法做到这一点。如果我不能在命令行上传递参数,还有另一种方法吗?或者RSpec不是正确的选择吗? 最佳答案 一种方法是使用接受命令行参数的东西绕过对rspec的调用,然后在代码中启动rspec。如果您不想为此编写自己的二进制文件,

ruby-on-rails - 如何编写 Rake 任务将数据导入 Rails 应用程序?

目标:使用CRON任务(或其他预定事件)更新数据库,每晚从现有系统导出数据。所有数据都是在现有系统中创建/更新/删除的。该网站不直接与该系统集成,因此Rails应用程序只需要反射(reflect)数据导出中出现的更新。我有一个包含约5,000种产品的.txt文件,如下所示:"1234":"productname":"attr1":"attr2":"ABCManufacturing":"2222""A134":"anotherproduct":"attr1":"attr2":"FoobarWorld":"2447"...所有值都是用双引号(")括起来的字符串,用冒号(:)分隔字段是:id

通过传递构造函数的 Ruby YAML 解析器

我正在开发一个应用程序,该应用程序从YAML文件获取输入,将它们解析为对象,然后让它们执行它们的操作。我现在遇到的唯一问题是YAML解析器似乎忽略了对象“初始化”方法。我指望构造函数用默认值填充YAML文件缺少的任何实例变量,并将一些东西存储在类变量中。这是一个例子:classTest@@counter=0definitialize(a,b)@a=a@b=b@a=29if@b==3@@counter+=1enddefself.how_manyp@@counterendattr_accessor:a,:bendrequire'YAML'a=Test.new(2,3)s=a.to_yaml

ruby - 如何将变量传递给 capybara 中的 page.executescript()

我需要在javascript中传递要通过capybara中的excute_script方法执行的变量。我无法将变量传递给它。请任何人帮助我。例子:@idd="sample"txt=page.execute_script('varuser_id=${@idd};returnuser_id;')putstxt我希望打印文本示例,但我遇到了Java脚本错误。 最佳答案 我认为问题出在${};你必须使用#{};尝试:page.execute_script("varuser_id='#{@idd}';returnuser_id;")

ruby - 你如何将 shell 输出通过管道传递给 ruby​​ -e?

假设我在我的终端中输入了一些东西,比如:ls|grepphrase这样做之后我意识到我想删除所有这些文件。我想使用Ruby来这样做,但不太清楚要将什么传递给它。ls|grepphrase|ruby-e"whatdoIputinheretogothrougheachlinebyline?" 最佳答案 以此为起点:ls~|ruby-ne'print$_if$_[/^D/]'哪个返回:DesktopDocumentsDownloadsDropbox-n标志表示“遍历所有传入行”并将它们存储在“默认”变量$_中。我们没有看到该变量使用太多,