Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/ruby/24.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/ruby-on-rails-3/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Ruby 控制台中没有保护监视文件的rspec输出_Ruby_Ruby On Rails 3_Rspec_Railstutorial.org_Guard - Fatal编程技术网

Ruby 控制台中没有保护监视文件的rspec输出

Ruby 控制台中没有保护监视文件的rspec输出,ruby,ruby-on-rails-3,rspec,railstutorial.org,guard,Ruby,Ruby On Rails 3,Rspec,Railstutorial.org,Guard,我已经安装了“guard”和“guard rspec”,我还配置了Guardfile(以观察“应用程序/视图”中的更改),但当我运行“bundle exec guard”时,我总是得到以下信息: vagrant@vagrant-debian-squeeze:/vagrant/sample_app$ bundle exec guard Guard could not detect any of the supported notification libraries. Guard is

我已经安装了“guard”和“guard rspec”,我还配置了Guardfile(以观察“应用程序/视图”中的更改),但当我运行“bundle exec guard”时,我总是得到以下信息:

  vagrant@vagrant-debian-squeeze:/vagrant/sample_app$ bundle exec guard
  Guard could not detect any of the supported notification libraries.
  Guard is now watching at '/vagrant/sample_app'
  Guard::RSpec is running, with RSpec 2!
  Running all specs
  ........

  Finished in 0.97359 seconds
  8 examples, 0 failures
  >
它已经完成了guard控制台提示,如果我从“app/views/”编辑一些文件(例如app/view/static_pages/home.html.erb)并保存它,guard不会显示任何规范输出,只是仍然等待一些控制台命令

我想它应该在保存监视的文件后显示一些rspec输出

档案:

警卫文件:

“应用程序/视图”的守卫监视规则为

运行时环境:

Debian挤压32位游荡盒

顺便说一句,我正在学习Rails表单,并在


非常感谢您的帮助。

取消对测试组中通知库的注释,使您的文件看起来像

group :test do
  gem 'capybara', '1.1.2'
  gem 'rb-inotify', '0.8.8'
  gem 'libnotify', '0.5.9'
end
应该这样做。享受Rails教程的乐趣,它很棒


编辑:假设您正在运行Linux。OSX和Windows有自己的测试库。继续阅读教程,你会看到的

我已经拆除了防护装置并安装了Watchr,看来它使他的工作正常了。这帮助了我:

试试这个(从
guard init
生成的Guardfile):

正则表达式是正确的,但它似乎与块中的文件名'spec/requests/#{m[1].singularize}_pages_spec.rb'有关,它会导致
guard
自动失败,好像表达式不匹配一样。我不知道为什么。

(我的例子是Ubuntu)

您可以通过
-p
选项强制guard轮询文件系统(增加CPU使用率,不断点击硬盘,并可能导致笔记本电脑温度升高-虽然不理想,但仍能正常工作)


我做到了,但我得到了同样的结果。运行“bundle exec guard”后,将运行规范测试,测试完成后将显示控制台提示。我不明白为什么,在这一集中,在更改了一个监视文件后,一个规范测试会立即运行。看来这个防护对我根本不起作用。我尝试了你的建议,但我得到了同样的结果,守卫在等待另一个命令时不会显示任何内容。Watchr工作得非常完美,所以我不想再为另一个棘手的保护配置而烦恼(是的,我知道在Watchr快死的时候,保护是主动开发的项目,但它做了我想要的)。不管怎样,谢谢你的回答。值得一提的是,我是一个看守和流浪汉,也有同样的问题。一个问题-如果我从本地机器上的共享目录打开并编辑文件,什么都不会发生。如果我在vm上的会话中执行相同的操作,Guard会运行我的规范两次。因此,我想知道这是否与Guard如何检测到文件发生了意外变化有关,而这一变化与介于两者之间的虚拟机无关。从我的角度来看,无论我是在主机上还是在笔记本上编辑了文件,结果都是一样的,什么都没有发生。无论如何,这是一个有趣的音符。谢谢。要降低资源使用率,可以使用
--latency/-l
标志<代码>bundle exec guard-p-l 10似乎减少了很多。顺便说一句,Guard可以监听来自网络的文件更改。您的主机操作系统可以运行一个小型侦听脚本,通过TCP将文件系统更改转发给Guard。有关更多信息:
# A sample Guardfile
# More info at https://github.com/guard/guard#readme

require 'active_support/core_ext'

guard 'rspec', :version => 2, :all_after_pass => false do
  watch(%r{^spec/.+_spec\.rb$})
  watch(%r{^lib/(.+)\.rb$})     { |m| "spec/lib/#{m[1]}_spec.rb" }
  watch('spec/spec_helper.rb')  { "spec" }

  # Rails example
  watch(%r{^spec/.+_spec\.rb$})
  watch(%r{^app/(.+)\.rb$})                           { |m| "spec/#{m[1]}_spec.rb" }
  watch(%r{^app/(.*)(\.erb|\.haml)$})                 { |m| "spec/#{m[1]}#{m[2]}_spec.rb" }
  watch(%r{^lib/(.+)\.rb$})                           { |m| "spec/lib/#{m[1]}_spec.rb" }
  watch(%r{^app/controllers/(.+)_(controller)\.rb$})  { |m| ["spec/routing/#{m[1]}_routing_spec.rb", "spec/#{m[2]}s/#{m[1]}_#{m[2]}_spec.rb", "spec/acceptance/#{m[1]}_spec.rb", (m[1][/_pages/] ? "spec/requests/#{m[1]}_spec.rb" : "spec/requests/#{m[1].singularize}_pages_spec.rb")]}
  watch(%r{^spec/support/(.+)\.rb$})                  { "spec" }
  watch('spec/spec_helper.rb')                        { "spec" }
  watch('config/routes.rb')                           { "spec/routing" }
  watch('app/controllers/application_controller.rb')  { "spec/controllers" }
  # Capybara request specs
  watch(%r{^app/views/(.+)/}) do |m|
    "spec/requests/#{m[1].singularize}_pages_spec.rb"
  end
end
  watch(%r{^app/views/(.+)/}) do |m|
    "spec/requests/#{m[1].singularize}_pages_spec.rb"
  end
group :test do
  gem 'capybara', '1.1.2'
  gem 'rb-inotify', '0.8.8'
  gem 'libnotify', '0.5.9'
end
watch(%r{^app/views/(.+)/}) { |m| "spec/requests/#{m[1]}_spec.rb" }
bundle exec guard -p