草庐IT

php - 按升序编写查询正值和负值

全部标签

ruby - 在 Ruby 中为 REST API 编写单元测试

我已经使用sinatra编写了一个基本的RESTAPI。有谁知道为它编写测试的最佳方法吗?我想使用Ruby来做到这一点。我已经使用curl完成了初步测试。但我想做一些更强大的事情。这是我的第一个API-有什么我应该测试的具体内容吗? 最佳答案 最好的方式见仁见智:)就我个人而言,我喜欢简单干净。使用像minitest这样的工具,Watir和rest-client,您可以对REST界面进行非常简单的测试,并通过实际浏览器(支持所有主要浏览器)测试您的Web服务。#!/usr/bin/ruby##Requiresthatyouhavei

ruby-on-rails - 编写 gem 时如何测试虚拟 Rails 应用程序?

我正在编写一个与Rails集成的gem,我希望能够在我的gem的测试套件中使用rspec测试一个虚拟应用程序。当我测试我的虚拟rails应用程序是否通过加载/几个模块时,问题出现了rspec规范/integration/rails/load_path_spec.rb到目前为止,这是我所拥有的:#spec/support/rails_app/config/environment.rb#LoadtheRailsapplication.requireFile.expand_path('../application',__FILE__)#Loadthegemrequire'skinny_con

ruby-on-rails - var_dump 并像 php 一样死去,在 ruby​​ on rails 中(在 ruby​​ on rails 中调试)

这可能是重复的问题。但是我无法显示对象。我是ruby​​的新手,尝试过像var_dump和print_r这样的调试,然后在php中die/p>这是我的代码。@brand_id=Brand.maximum("brand_id")我试过下面的方法1putsYAML::dump(@brand_id)2logger.debug{@brand_id.inspect}请问谁能帮我解决一下吗? 最佳答案 Rails只会将View输出到浏览器。任何其他输出都发送到服务器上的STD_OUT。从View中调试很简单:但是从Controller或模型内部

sql - 将每个 SQL 查询记录到 Rails 中的数据库

我想将某些SQL查询rails执行(即CREATE、UPDATE和DELETE)保存到日志文件中因此我需要拦截所有查询,然后可能使用一些正则表达式过滤它们并根据需要记录它们。我应该把这样的东西放在Rails代码的什么地方? 最佳答案 这里是c0r0ner链接的简化版本,以更好地展示它:connection=ActiveRecord::Base.connectionclasse;end#executeoriginalstatementoriginal_exec(sql,*name)endend

ruby-on-rails - 查询多条记录时如何避免ActiveRecord::RecordNotFound异常

我有这个代码:Article.find([1,2,3])但数据库中只有记录1和2。我得到这个异常(exception):"ActiveRecord::RecordNotFound(Couldn'tfindallOfferswithIDs(1,2,3)(found2results,butwaslookingfor3))"有没有办法只获取现有记录而不获取异常? 最佳答案 Article.find_all_by_id([1,2,3])是要走的路! 关于ruby-on-rails-查询多条记录时

ruby - 编写 gem 时设置配置设置

我正在编写一个gem,我想在有和没有Rails环境的情况下工作。我有一个Configuration类来允许配置gem:moduleNameCheckerclassConfigurationattr_accessor:api_key,:log_leveldefinitializeself.api_key=nilself.log_level='info'endendclass现在可以这样使用了:NameChecker.configuredo|config|config.api_key='dfskljkf'end但是,我似乎无法通过gem中的其他类访问我的配置变量。例如,当我像这样在spec

ruby - 具有可选查询参数的 Sinatra

我想创建一个带有可选查询参数的SinatraAPI路由。我可以按如下方式添加查询参数%r{^/mysql/data/(?)/start_time=(?\w*)/?}但是上面route对应的route是像"/mysql/data/:name/start_time=:start_time"我需要查询参数作为可选参数并以URL格式声明。例如:/mysql/data/:name?start_time=:start_time&end_time=:end_time在Sinatra中有什么方法可以做到这一点吗? 最佳答案 引自Sinatra文档:

ruby - RSpec:如何编写一个期望特定输出但不关心方法的测试?

我正在努力了解测试驱动设计,特别是RSpec。但是我在使用TheRSpecBook中的一些示例时遇到了问题。在本书中,我们像这样测试$STDOUT上的输出:output=double('output')game=Game.newoutput.should_receive(:puts).with('WelcometoCodebreaker!')game.start()好吧,这在时尚之后起作用。但是我到底为什么要关心Game对象是否使用puts()方法呢?如果我把它改成print(),它真的会破坏测试吗?而且,更重要的是,这是否违背了TDD的一项原则——我应该测试方法的作用(设计)而不是它

sql - 如何使用 Sequel 运行原始 SQL 查询

我还不清楚使用Sequel运行原始SQL查询的正确方法。目前我正在尝试这个:DB.fetch("SELECT*FROMzoneWHEREdialcode='#{@dialcode}'LIMIT1")do|row|@zonename=rowend我怎样才能将查询作为原始SQL运行,然后像平常一样访问结果?if@zonename.name="UK" 最佳答案 请注意,而不是:DB.fetch("SELECT*FROMzoneWHEREdialcode='#{@dialcode}'LIMIT1")你应该这样做:DB.fetch("SELE

ruby-on-rails - Rails 在 ActiveRecord::Relation 对象中查找记录而无需再次查询数据库

我想在ActiveRecord::Relation对象中找到一个特定的记录,这样我就可以获取该记录的属性。下面的代码有效,但问题是它再次使用find_by语句访问数据库。它不应该。Rails应该有一种方法可以在ActiveRecord::Relation对象中找到该对象,而不必再次查询数据库。#returnsanActiveRecord::Relationobject@blogs=Blog.all#SearchfortheblogwithinthatActiveRecord::Relationobject,NOTthedatabase@blogs.find_by(id:1).title