草庐IT

任务处理

全部标签

ruby-on-rails - rake 任务在哪里定义?

在新创建的Rails项目(由railssomeName生成)中,可以运行一些“默认”rake任务,例如:抽取测试rake数据库:迁移等等问题是,这些任务是在哪里描述的?默认的Rakefile没有所有这些任务。此外,我检查了一些使用rspec的项目,我能够运行rakespec来运行所有测试。spec目标在哪里定义? 最佳答案 如果描述你的意思是定义,rake-W是你的friend。示例:$rake-Wdb:create=>rakedb:create/path/to/ruby/gems/1.9.1/gems/activerecord-3

ruby-on-rails - 我有一个 Rails 任务 : should I use script/runner or rake?

对于adhocRails任务,我们有一些实现方案,其中主要的似乎是:script/runnersome_useful_thing和:rakesome:other_useful_thing我应该选择哪个选项?如果有一个明确的最爱,那么什么时候,如果有的话,我应该考虑使用另一个?如果从来没有,那么您为什么认为它仍然存在于框架中而没有弃用警告? 最佳答案 它们之间的区别在于script/runner启动Rails,而Rake任务不会启动Rails,除非您通过使任务依赖于:environment来告诉它,例如这个:task:some_use

ruby-on-rails - 在 Controller 中运行 rake 任务

我想在我的Controller中运行一个rake任务。有什么办法吗? 最佳答案 我同意ddfreynee的观点,但如果您知道自己需要什么,代码可以如下所示:require'rake'Rake::Task.clear#necessarytoavoidtasksbeingloadedseveraltimesindevmodeSample::Application.load_tasks#providingyourapplicationnameis'sample'classRakeController您可以改为在初始化程序中要求'rake'

ruby 以四人为一组处理数组元素

当每个元素都需要处理时,我有一个ruby​​脚本数组:threads=[]elemets.eachdo|element|threads.push(Thread.new{process(element)}}endthreads.each{|aThread|aThread.join}由于资源限制,如果一次不再处理四个元素,脚本将以最佳方式运行。不,我知道我可以转储每个循环并使用一个变量来计算4个元素,然后等待但是有没有更酷的ruby​​方法来做到这一点? 最佳答案 您可以以4为一组枚举数组:>>[1,2,3,4,5,6,7,8,9,10

ruby-on-rails - 如何在 rake 任务中使用 "gets"?

每当我尝试在rake任务中使用函数gets时,我都会收到错误消息。有没有办法让它发挥作用?错误说,“没有这样的文件或目录-(rake任务名称)” 最佳答案 问题是Kernel#gets(如果你只是单独使用gets,这就是你所调用的)假设你正在从一个由传递给Rake的参数命名的文件中提取。这意味着gets尝试返回名为[rake-task-here]的文件的内容,该文件几乎肯定不存在。尝试STDIN.gets. 关于ruby-on-rails-如何在rake任务中使用"gets"?,我们在S

ARM异常处理(3):Bus faults、Memory management faults、Usage faults、Hard faults详解

之前介绍了了ARM异常处理(1):异常类型、优先级分组和异常向量表,里面有很多异常类型,其中有几个异常在错误处理中非常有用:文章目录1BusFault2MemoryManagementFault3Uagefaults4HardFaults1BusFault当在AHB接口上传输期间收到错误响应时,就会产生Busfault。它可能发生在以下几个阶段:指令预取阶段,通常称为prefetchabort数据读/写阶段,通常称为dataabort在Cortex-M3中,出现下面几种情况也会产生Busfault:堆栈在中断处理的开始处PUSH,称为stackingerror堆栈在中断处理的结束处POP,称为

ruby-on-rails - Rails 如何运行 rake 任务

如何在终端/控制台中运行这个rake文件?我在lib/tasks中的statistik.rakedesc"Importerstatistikker"namespace:reklamerdotask:iqmedier=>:environmentdo...endtask:euroads=>:environmentdo...endtask:mikkelsen=>:environmentdo...endtask:orville=>:environmentdo...endend 最佳答案 您可以通过运行从shell运行Rake任务:raket

ruby - Rake 命名空间的默认任务

给出类似的东西:namespace:my_tasksdotask:foododo_somethingendtask:bardodo_something_elseendtask:all=>[:foo,:bar]end如何使:all成为默认任务,以便运行rakemy_tasks时调用它(而不是必须调用rakemy_tasks:all)? 最佳答案 像这样把它放在命名空间之外:namespace:my_tasksdotask:foododo_somethingendtask:bardodo_something_elseendendtask

ruby - 我如何从 Capistrano 运行 rake 任务?

我已经有一个deploy.rb可以在我的生产服务器上部署我的应用程序。我的应用程序包含一个自定义rake任务(lib/tasks目录中的一个.rake文件)。我想创建一个cap任务来远程运行该rake任务。 最佳答案 更明确一点,在您的\config\deploy.rb中,在任何任务或命名空间之外添加:namespace:rakedodesc"Runataskonaremoteserver."#runlike:capstagingrake:invoketask=a_certain_tasktask:invokedorun("cd#{

ruby-on-rails - 在 rails 中处理 STI 子类路由的最佳实践

我的RailsView和Controller到处都是redirect_to,link_to,和form_for方法调用。有时link_to和redirect_to在它们链接的路径中是显式的(例如link_to'NewPerson',new_person_path),但很多时候路径是隐式的(例如link_to'Show',person)。我在我的模型中添加了一些单表继承(STI)(比如Employee),并且所有这些方法都会中断子类的一个实例(比如Employee);当Rails执行link_to@person时,它错误undefinedmethodemployee_path'for#: