草庐IT

mysql - 验证 MySql 查询

全部标签

ruby - 如何让 rspec 不显示数据库查询而只显示带有 rails_12factor 的点?

ruby:2.0rails:3.2.17rspec:2.14.8Database:mysqlrspecspec用于仅输出点。当我推送到Heroku并且最近添加了rails_12factorgem来绕过它时,我收到了弃用警告。但是,现在在本地运行规范时,我会得到每个事务的详细数据库输出。当我需要它时这是一个很好的选择,否则它会产生很多不需要和分散注意力的输出。所以我想要一个将它用于Heroku而不是本地的选项。请注意,这不会通过使用格式化程序来解决,例如rspecspec-fd此外,如果出现错误,在这种冗长程度下,错误几乎总是滚出当前页面...09:50:39durrantmCastle

ruby-on-rails - Rails 查询执行导致数据库峰值

我的Rails应用程序出现问题,一些随机查询需要大约5秒或更长时间才能完成。大多数时候,查询非常简单(select*fromxwhereid=?),而且字段甚至也被编入索引。这里有一些关于设置的更多信息:反向nginx代理背后的Puma3.5.04个worker,每个worker最少4个,最多8个线程。Rubyv2.2.3,Railsv4.2.4PostgreSQL9.4数据库线程池设置为最多60个连接监控应用8GBRAM、4个CPU、SSD。我在查看Appsignal中的查询性能时发现了这一点。我注意到大多数查询在几毫秒内完成,然后时不时地,仍然在同一个请求中,有多个查询需要5秒以上

ruby-on-rails - 在 Rspec 中用项目符号标记 N+1 查询

我正在尝试使用bulletgem标记N+1并在代码中添加计数器缓存的位置.但是手动执行所有检查N+1查询的操作似乎非常痛苦,所以我尝试使用Bullet和Rspec,使用他们推荐的设置步骤:#config/environments/test.rbconfig.after_initializedoBullet.enable=trueBullet.bullet_logger=trueBullet.raise=true#raiseanerrorifn+1queryoccursend#spec/spec_helper.rbifBullet.enable?config.before(:each)d

ruby-on-rails - 请求规范中的 stub 身份验证

我正在寻找做this的方法但在要求规范。我需要登录和注销double或instance_double来设计而不是实际的ActiveModel/ActiveRecord。通过使用wiki页面中的代码:moduleRequestSpecHelpersdefsign_in(user=double('user'))ifuser.nil?allow(request.env['warden']).toreceive(:authenticate!).and_throw(:warden,{:scope=>:user})allow(controller).toreceive(:current_user)

ruby-on-rails - Restful 身份验证的无意 session 劫持问题

我正在使用在github上找到的当前版本的restful_authentication,我遇到了一堆奇怪的session问题。服务器似乎以某种方式将session分配给不应该的用户。只有在越过注销/登录障碍时才会发生这种情况。这是一个例子。在服务器上没有事件session的情况下,我使用用户A登录帐户。在另一台计算机上,我使用用户B登录。然后当注销用户B时,在注销重定向发生后的某个时间,我将登录为用户A。从这一点开始,我可以继续浏览该站点,就像我以该用户身份登录一样!我通过日志观察到的是,当发生这种劫持时,sessionID是不一样的。用户A在两个session中均已登录,但sessi

ruby-on-rails - ActiveRecord:查询未对 STI 子类使用正确的类型条件

我有一组STI子类继承自User基类。我发现在子类定义中的某些条件下,对子类的查询没有正确使用type条件。classUser在开发中加载Rails控制台时,它会按照我的预期进行:Admin:SELECT`users`.*FROM`users`WHERE`users`.`type`IN('Admin')但是当点击应用程序(localhost/pow)时,它缺少type条件,我明白了:Admin:SELECT`users`.*FROM`users`但在部署到暂存服务器时不是来自应用程序:Admin:SELECT`users`.*FROM`users`WHERE`users`.`type`

ruby-on-rails - 使用具有两个 Devise 用户模型和不同身份验证方法的登录表单

我正在构建一个站点,该站点必须支持通过LDAP进行的身份验证,以及仅在站点中管理的“本地”用户。目前我有以下Devise模型:classUserDevise正在为其中的每一个生成独立的路由,即/local_users/sign_in和/ldap_users/sign_in。这并不理想,用户不需要知道他们是哪种类型的用户,所以我想将它们统一为一种形式,使用一组登录/注销URL。我已经查看了一些关于如何执行此操作的解决方案,但它们似乎依赖于模型具有相同的Devise配置或相同的身份验证方法这一事实。我发现的此类问题的唯一其他在线示例是此Google网上论坛帖子:https://groups

iphone - 设计和 Rails 3 中的 http 身份验证

我有一个使用deviseonrails3的应用程序。我想启用http身份验证,以便我可以从iPhone应用程序向我的网络应用程序进行身份验证。如何从我的iPhone应用程序进行身份验证以进行设计?这安全吗?还是我应该进行不同的身份验证? 最佳答案 从设计的角度来看,您有3个选择:1)使用基本的http身份验证:您的iPhone应用程序有一个secretkey-这是在您的iPhone应用程序代码中烘焙的-用于对网络应用程序的每个请求进行身份验证。Google搜索:“设计基本的http身份验证”2)您可以通过在您的iPhone应用程序中

ruby - 从 Ruby 内部使用 bundler 验证 gem 的版本

有没有办法从Ruby程序中验证我是否拥有最新版本的gem?也就是说,有没有办法以编程方式执行bundleoutdated#{gemname}?我尝试查看bundler的源代码,但找不到直接的方法。目前我正在做这个,它很脆弱,很慢而且很不优雅:IO.popen(%w{/usr/bin/envbundleoutdatedgemname})do|proc|output=proc.readlines.join("\n")returnoutput.include?("Yourbundleisuptodate!")end 最佳答案 避免外部执行

ruby-on-rails - RESTful 身份验证还是 Authlogic?

我在两者之间难以取舍。它们看起来都是很棒的插件,但我想知道哪个更容易控制。您的同事对这些插件有何体验?你会推荐哪个? 最佳答案 与使用Restful身份验证相比,我更喜欢Authlogic。你是否使用authologic与Restful身份验证相比有一大优势,它作为gem/插件而不是像restful_authentication中的生成器一样出现,它不会用大量代码弄乱你的应用程序。使用Authlogic它很容易理解,并且与Restful身份验证相比更清晰。如果您的应用程序需要电子邮件激活,请使用带有authologic的act_as