草庐IT

运行时数据区

全部标签

ruby-on-rails - 条款和条件的复选框,数据库中没有列

我需要一个页面上的“我接受服务条款”复选框,必须选中它才能继续执行订单。因此,在数据库中有一列来匹配它(无论用户是接受还是拒绝条款)似乎是不合逻辑的。在我看来,我正在使用这样的表单助手:在我的模型中:validates_acceptance_of:terms目前它根本不工作。这似乎是一段非常常见的代码,但如果没有模型中的术语,我找不到它在任何地方使用。否则我可以使用javascript来验证它,但我更愿意将它全部保留在模型中。 最佳答案 这应该可以正常工作,没有数据库列或attr_accessor:http://guides.rub

ruby - 如何告诉 rspec 在没有未决测试输出的情况下运行?

有没有办法(也许是一些关键)告诉rspec跳过挂起的测试并且不打印有关它们的信息?我有一些自动生成的测试,比如pending"addsomeexamplesto(ordelete)#{__FILE__}"我运行“bundleexecrspecspec/models--formatdocumentation”并得到如下信息:RatingallowstoratefirsttimedisallowtoratebooktwiceCustomeraddsomeexamplesto(ordelete)/home/richelieu/Code/first_model/spec/models/cust

ruby - 为什么我可以引用从未运行过的 if/unless/case 语句之外的变量?

为什么下面的代码不会报错?iffalsex=0endx#=>nil而以下确实会引发错误:y#NameError:undefinedlocalvariableormethod`y'formain:Objectunless和case语句也会发生同样的事情。 最佳答案 这是因为Ruby解析器的工作方式。变量由解析器定义,解析器逐行遍历代码,而不管它是否会实际执行。一旦解析器看到x=,它就会在当前范围内定义局部变量x(值为nil)。因为if/unless/case/for/while不创建新的作用域,x被定义并且在代码块之外可用。由于条件为

ruby - 为什么 gems 安装在与我运行的 Ruby 版本不同的目录中?

当我安装gem时,它会安装在名为1.9.1的目录中,尽管这不是我安装的Ruby版本:$ruby-vruby1.9.3p327(2012-11-10revision37606)[x86_64-darwin12.2.0]$gemwhichrails.../ruby/gems/1.9.1/gems/railties-3.2.9/lib/rails.rb为什么会这样?我没有安装其他Ruby版本(当然也没有安装v1.9.1)。 最佳答案 请注意,以下内容也适用于撰写本文时所有后来的Ruby版本,而不仅仅是1.9.2。根据1.9.2releas

ruby - 如何以较低的速度运行 Selenium(通过 Capybara 使用)?

默认情况下,Selenium在我使用Cucumber定义的场景中尽可能快地运行。我想将它设置为以较低的速度运行,这样我就可以拍摄该过程的视频。我发现Selenium::Client::Driver的一个实例有一个set_speed方法。对应于JavaAPI.如何获取Selenium::Client::Driver类的实例?我可以得到page.driver,但它返回Capybara::Driver::Selenium的实例。 最佳答案 感谢http://groups.google.com/group/ruby-capybara/msg

ruby - 在端口 80 上运行 Sinatra

我安装了Sinatra,它可以正常工作,但它默认使用端口4567。我希望它在端口80上运行。为了让它在80端口上工作,我尝试了这个:require'rubygems'require'rack/handler/webrick'require'sinatra'Sinatra::Application.default_options.merge!(:run=>false,:env=>:production,:port=>80)get'/'do"HelloWorld"end但是我得到这个错误:$ruby-rubygemsindex.rbindex.rb:5:in`':undefinedmeth

ruby-on-rails - 在 Ruby 中,如何从 CSV 文件中按列读取数据?

我知道它是如何逐行完成的CSV.foreach(filename.csv)do|row|puts"#{row}"end但我完全迷失了专栏? 最佳答案 测试.csv:name,surname,no1,no2,no3,dateRaja,Palit,77489,24,84,12/12/2011Mathew,bargur,77559,25,88,01/12/2011harin,Roy,77787,24,80,12/12/2012Soumi,paul,77251,24,88,11/11/2012按列访问:require'csv'csv=CSV

ruby-on-rails - 从 Rails 控制台修改数据库 ID?

我有一个小型数据库,一直在通过Rails页面添加条目。我“销毁”了其中一个条目,现在我的ID序列跳过了一个。例如,我现在有42然后是44,而不是显而易见的:42、43、44。我想知道是否有办法通过控制台编辑新对象的ID号。我试过:record.id=43record.save和record=record.newrecord.attributes={:id=>43}但两者均无效。我相当确定必须有一个控制台方法,但我似乎无法在谷歌上找到更多具体信息,而且我可能错误地阅读了RailsAPI......我是否可能必须通过sqlite中的直接SQL来执行此操作?谢谢

ruby-on-rails - 在 Heroku 上运行 Phantomjs

关闭。这个问题是off-topic.它目前不接受答案。想改进这个问题吗?Updatethequestion所以它是on-topic用于堆栈溢出。关闭10年前。Improvethisquestion有没有办法运行phantomjs,一个命令行工具,在Heroku上?

ruby - 使用 Ruby 和 Minitest,如何运行具有不同数据的相同测试用例,仅由列表控制

我有对电话号码进行操作的Ruby2.0代码,我想使用MiniTest对其进行测试。我有一个函数,它接受一个电话号码参数并对其进行测试(包括断言)。每次调用该函数时,我都希望它成为一个新的测试用例。像这样:listOfPhoneNumbersForTesting.each{|phone|testphonephone}我不想要的是:classtest2125551212...重复10、20或100次以测试每个电话号码...显然,我可以将循环代码放在MiniTest::Unit::TestCase中,但无论我测试多少个电话号码,这都会导致只有一个测试用例,我不喜欢这样。(此外,如果其中一个断