RSpec naming conventions for files and directory structure

前端 未结 2 1270
慢半拍i
慢半拍i 2021-01-02 02:05

I\'m writing RSpec tests and I have come to a point where I am not reading the same opinions on different websites. The directory structure for RSpec is clear when we are d

相关标签:
2条回答
  • 2021-01-02 02:45

    The files read by the rspec gem are simply those that end in _spec.rb and that are anywhere in the hierarchy below the spec folder as long as the top of the hierarchy is an alpha-numeric word (that is, files under a folder named spec/##/ would not be considered in generating specs.) This is the relevant line of code that implements this, in /gems/rspec-rails-2.14.1/lib/rspec/rails/tasks/rspec.rake:

    namespace :spec do
      types = begin
        dirs = Dir['./spec/**/*_spec.rb'].
               map { |f| g=f.sub(/^\.\/(spec\/\w+)\/.*/, '\\1') ; puts ">>> Found #{g}."; g }.
               uniq.
               select { |f| File.directory?(f) }
        Hash[dirs.map { |d| [d.split('/').last, d] }]
      end
    

    So all the text in the filename previous to _spec.rb is a convention - it doesn't change how Rails processes the files.

    I'd have to read through the code a lot more to figure out what the significance of each folder name, under spec, is - it gets passed through to the Rake spec task that's created, so it's being used for something but I don't know what.

    0 讨论(0)
  • 2021-01-02 02:55

    Check the dates of the books and the versions of RSpec for which they were written. The naming structure has changed slightly over time.

    According to the docs for rspec-rails, request specs can go in spec/requests, spec/api, or spec/integration. I prefer to put request specs in spec/requests.

    To make things more interesting, if you are using Capybara with rspec-rails, it will work with spec/requests for Capybara 1.x, and spec/features for Capybara 2.

    As to individual spec file names, when there is a specific class under test, like a Rails model, you should use an analogous spec file name:

    app/models/user.rb -> spec/models/user_spec.rb

    View specs should use the template name:

    app/views/users/index.html.erb -> spec/views/users/index.html.erb_spec.rb

    Namespaced models should include the namespace in the spec file path:

    app/models/admin/user.rb -> spec/models/admin/user_spec.rb

    The RSpec scaffold generator is a good guide for showing where these specs belong.

    When there is no specific class under test, as is the case with request specs, IMHO you should feel free to use a name that describes the thing being tested. E.g. spec/requests/place_an_order_spec.rb.

    0 讨论(0)
提交回复
热议问题