草庐IT

从玄学走向科学:AB测试驱动的科学增长

全部标签

ruby - 在 rspec(和 cucumber )中测试 rake 任务

我是Ruby的新手,我一直在尝试学习Rake、RSpec和Cucumber。我找到了一些可以帮助我测试Rake任务的代码,但我无法让它正常工作。有人告诉我:http://blog.codahale.com/2007/12/20/rake-vs-rspec-fight/放弃这个:defdescribe_rake_task(task_name,filename,&block)require"rake"describe"Raketask#{task_name}"doattr_reader:taskbefore(:all)do@rake=Rake::Application.newRake.ap

ruby-on-rails - 使用 Rspec 和 Rack::Test 测试 REST-API 响应

我有点难过。我有以下集成测试:require"spec_helper"describe"/foods",:type=>:apidoincludeRack::Test::Methodslet(:current_user){create_user!}let(:host){"http://www.example.com"}beforedologin(current_user)@food=FactoryGirl.create_list(:food,10,:user=>current_user)endcontext"viewingallfoodsownedbyuser"doit"asJSON"d

ruby - ruby 1.9 和 RSpec2 有什么好的突变测试工具吗?

我曾经使用过Heckle,但由于ParseTree的问题,它与ruby​​1.9不兼容。我一直在寻找替代方案,但唯一看起来有前途的是Chaser,它没有任何明确的文档可供我使用,看看我是否可以让它与RSpec一起工作。它似乎具有Test::Unit依赖性。那么-是否有人使用任何很棒的工具来真正检查您的测试质量?或者-是否有提供比c0覆盖更好的覆盖工具?这将有助于解决同样的问题。我现在正在使用cover_me,但它是c0,就像rcov。 最佳答案 你看过Mutantgem吗??它适用于Rspec。Thereisanicetutoria

ruby-on-rails - 在不更改系统时钟的情况下在 rspec 测试中设置系统时间

我正在努力让Rails3应用程序准备好使用时区。我的开发机器在美国东部时间,我托管的服务器在UTC。在我的rspec测试中有没有一种方法可以更改ruby​​使用的系统时区,这样我就可以使用相同的系统时区运行测试,而不必更改我计算机上的系统时钟?我研究过Delorean和Timecop,它们不是我要找的。我正在寻找类似的东西Time.system_time_zone="UTC"...然后Time.now将返回UTC时间,而不是我的系统时区设置的时间。 最佳答案 before{Time.stub(:now){Time.now.utc}}

ruby-on-rails - 在 Rails 中对暂存/生产环境进行冒烟测试的最佳方法是什么?

首先,设置...我目前正在使用Ruby1.8.7MRI在MacOSX上开发Rails3应用程序,针对MySQL数据库运行测试和本地开发。我有3个“其他”非本地环境,我们在公司使用这些环境来处理名为dev、tqa和prod的每个应用程序。它们使用JRuby(1.8.7)在Tomcat中运行,以Oracle作为后端。如您所见,环境大不相同,我们在部署到本地不存在的Oracle/JRuby环境时遇到了一些错误(例如日期处理和指定Oracle中的默认模式)。我喜欢在本地运行Cucumber/Webrat/Capybara之类的东西来访问应用程序中公开的每个URL,以确保基本功能正常运行(即冒烟

ruby-on-rails - 多个数据库的测试和 database_cleaner

我们有一个邮箱模型,它使用另一个邮件应用程序也连接到的辅助数据库。这称为使用establish_connection:mail_database现在,我想我可以尝试将它包装在if语句中,以便它为测试环境使用不同的连接,但我想知道如何保持这个数据库的清洁,最好使用我们已经将其用于“常规”数据库的database_cleaner。我希望有人能将我推向正确的方向。 最佳答案 我有一个使用rspec(2.12.0)和使用database_cleaner(0.9.1f4b44bb)测试的rails3.2.10应用程序,它有两个用于mysql的

ruby - 如何测试 JSON REST API

我是ruby​​的新手(第一天使用ruby​​)所以请原谅任何新手问题和缺乏理解。我正在尝试验证对http标注的响应。例如,假设端点如下:https://applicationname-api-sbox02.herokuapp.com而且,我正在尝试通过发送这样的获取请求来验证用户身份:get_response=RestClient.get("https://applicationname-api-sbox02.herokuapp.com/api/v1/users",{"Content-Type"=>"application/json","Authorization"=>"token4

ruby-on-rails - Rails 3.0.7 -> 如何让测试运行得更快?

我正在运行mysql、database_cleaner、Rspec等。到目前为止我有大约518个测试,它们需要88秒才能运行。这对我来说是NotAcceptable,因为我的应用程序开发才刚刚开始。因此,在进一步深入之前,我想尝试找到减少运行这些测试所需时间的方法-希望不必实际更改测试。在大多数情况下,我尝试使用stub。但是,当我测试模型和查询时,我会使用数据库。我认为database_cleaner正在减慢它们的速度,但我不知道如何在没有它的情况下测试查询和其他内容。使用带有“:memory:”选项的sqlite3似乎只减少了大约10秒(有点令人失望的结果......)我该怎么做才

ruby - 在 Jekyll 驱动的站点上创建类别

我很难理解如何为我在博客上使用的每个类别生成存档页面。我希望用户能够单击一个类别,然后被带到一个页面,该页面列出了所有分配了所需类别的文章。我能想到的唯一方法是为根目录中的每个类别手动创建一个特定的html文件。但我确定一定有更动态的方式?我在github上托管了网站-https://github.com/sirbrad/sirbrad.github.com提前致谢!布拉德 最佳答案 您可以使用site.categories数据生成所有可用类别的列表,使用每个类别的第一个元素(数组)获取类别名称:{%forcatinsite.cat

ruby-on-rails - 测试 ActiveRecord::RecordNotFound

当模型无法检索记录时,我的应用程序正在将ActiveRecord::RecordNotFound传播到Controller。这是数据库查询:defself.select_intro_verseoffset=rand(IntroVerse.count)IntroVerse.select('line_one','line_two','line_three','line_four','line_five').offset(offset).first!.as_jsonendfirst!如果没有找到记录,则引发一个ActiveRecord::RecordNotFound,我可以挽救它并在我的Co