草庐IT

gcloud-sql-test

全部标签

ruby-on-rails - rails 4 : How to reset test database?

我在使用Rails4并注意到我的一些RSpec测试失败了,因为我的一些测试重构使用了前置过滤器(大概是因为事务)。这篇文章描述了一个类似的问题:railstestdatabasenotclearingaftersomeruns代替使用DatabaseCleanergem,是否有清除测试数据库的rake命令?我相信rakedb:test:prepare在Rails4中被弃用了。此外,如果在交易之前,如`post:create,user:Fabricate.attributes_for(:user)`是持久性的,是否有另一种重构方式来避免手动清除测试数据库的需要?

ruby-on-rails - 如何在 RSpec 测试中打开 ActiveRecord 的 SQL 调试日志记录?

我对我的模型进行了一些RSpec测试,我想像在Rails服务器模式中看到的那样打开SQLActiveRecord日志记录。如何做到这一点?我开始我的测试RAILS_ENV=testbundleexecrspecmy/test_spec.rb谢谢 最佳答案 您可以尝试在某处的测试中将ActiveRecord记录器设置为标准输出。如果您正在使用rspec,也许在spechelper中?ActiveRecord::Base.logger=Logger.new(STDOUT) 关于ruby-on

ruby-on-rails - 如何在测试环境运行Rails控制台并加载test_helper.rb?

背景:我在使用Thoughtbot的“工厂女孩”gem时遇到了一些问题,该gem用于创建要在单元测试和其他测试中使用的对象。我想转到控制台并运行不同的FactoryGirl调用以检查发生了什么。例如,我想去那里做...>>Factory(:user).inspect我知道您可以在不同的环境中运行控制台...$脚本/控制台RAILS_ENV=test但是当我这样做时,工厂类不可用。看起来好像test_helper.rb没有加载。我尝试了各种require调用,包括一个带有到test_helper.rb的绝对路径的调用,但它们的失败与此类似:$script/consoleRAILS_ENV

sql - Rails 4 LIKE 查询 - ActiveRecord 添加引号

我正在尝试像这样做一个类似的查询defself.search(search,page=1)paginate:per_page=>5,:page=>page,:conditions=>["nameLIKE'%?%'ORpostal_codelike'%?%'",search,search],order=>'name'end但是当它运行时,某些东西会添加引号,导致sql语句像这样出现SELECTCOUNT(*)FROM"schools"WHERE(nameLIKE'%'havard'%'ORpostal_codelike'%'havard'%')):所以你可以看到我的问题。我正在使用Rai

ruby-on-rails - 什么是 rake db :test:prepare actually do?

我正在观看Rails教程视频,但我无法弄清楚db:test:prepare命令的实际作用。有人可以提供解释吗? 最佳答案 Therakedb:migrateaboverunsanypendingmigrationsonthedevelopmentenvironmentandupdatesdb/schema.rb.Therakedb:test:loadrecreatesthetestdatabasefromthecurrentdb/schema.rb.Onsubsequentattempts,itisagoodideatofirstr

javascript - 类型错误 : parsed is undefined on angularjs service unit test

我正在尝试对使用$http的服务进行单元测试。我正在使用Jasmine,但我一直收到此错误:TypeError:parsedisundefinedinangular.js(line13737)这是我的服务的样子:angular.module('myapp.services',[]).factory('inviteService',['$rootScope','$http',function($rootScope,$http){varinviteService={token:'',getInvite:function(callback,errorCallback){$http.get('

asp.net - 在 asp.net 应用程序上显示存储在 sql 数据库中的 utc 时间的本地时间

我已经将时间以utc格式保存在sql数据库中。我在gridview上显示这些时间,但它们仍然是UTC格式。我想将它们转换为本地时间的客户端浏览器。问题是虽然我可以获得仅适用于当前日期/时间的时区偏移量。如果future的某些日期最终发生在夏令时期间,则该偏移量可能会发生变化。我对Web编程比较陌生,但似乎我需要做的是运行一些Javascript,因为每个条目都绑定(bind)到以某种方式获取C#datetimeoffset对象并将其转换为本地时间的gridview。或者这不可能? 最佳答案 如果您有一个TimeZoneInfo对象,

javascript - 使函数调用等待 web SQL 查询

无论传递的数字是否为质数,Primecheck函数都应该返回true或false。如果数字是素数,函数将其添加到PRIMES表中。这是埃拉托色尼筛法算法,但还没有完成。functionprimecheck(number){varisprime=true;if(number%10==1||number%10==3||number%10==7||number%10==9){db.transaction(function(tx){tx.executeSql('SELECT*fromPrimes',[],function(tx,result){for(vari=1;i问题:当我传递不以1、3、

javascript - Node : Testing with sinon and async/await

使用sinon和async/await运行此测试时遇到问题。这是我正在做的一个例子://infilefuncsasyncfunctionfuncA(id){leturl=getRoute53()+idreturnawaitfuncB(url);}asyncfunctionfuncB(url){//emptyfunction}和测试:letfuncs=require('./funcs');...//describeletstubRoute53=null;letstubFuncB=null;letroute53='https://sample-route53.com/'letid='123

javascript - React-testing-library:因输入而改变

我正在尝试测试组件是否会因输入元素的更改而更新。我使用fireEvent.change()函数,如果我随后检查我使用getByPlaceholderText找到的节点的值,它已按预期更新。但是我看不到react组件本身的变化。这可能是因为更改直到重新渲染才会发生;我将如何测试这个?react-testing-library的rerender似乎“从头开始”启动组件(即没有新的输入值),并且waitForElement永远找不到它在等待什么。这是组件TestForm.js:importReactfrom'react';import{withState}from'recompose';co