Cyril, Thank you for the link. This patch solved the issue. Any idea where the issue is exactly? Is it rspec-rails gem or rails itself?
On Wed, 12 Sep 2018 at 01:57, <[email protected]> wrote: > You might want to follow this answer from StackOverflow > <https://stackoverflow.com/a/29442541/2832282>. In my previous mongoid > project I did not need such patching but apparently we either missed > something, or some strong dependencies were added in Rails/RSpec which > makes it harder to separate it from ActiveRecord > > On Tuesday, September 11, 2018 at 10:07:15 PM UTC+2, Surya wrote: >> >> Here is the complete trace: >> >> >> 16) PostsController routing routes to #destroy >> Failure/Error: raise ConnectionNotEstablished, "No connection pool >> with '#{spec_name}' found." unless pool >> >> ActiveRecord::ConnectionNotEstablished: >> No connection pool with 'primary' found. >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/activerecord-5.1.6/lib/active_record/connection_adapters/abstract/connection_pool.rb:930:in >> `retrieve_connection' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/activerecord-5.1.6/lib/active_record/connection_handling.rb:116:in >> `retrieve_connection' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/activerecord-5.1.6/lib/active_record/connection_handling.rb:88:in >> `connection' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/activerecord-5.1.6/lib/active_record/fixtures.rb:516:in >> `create_fixtures' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/activerecord-5.1.6/lib/active_record/fixtures.rb:1028:in >> `load_fixtures' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/activerecord-5.1.6/lib/active_record/fixtures.rb:999:in >> `setup_fixtures' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/activerecord-5.1.6/lib/active_record/fixtures.rb:851:in >> `before_setup' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-rails-3.8.0/lib/rspec/rails/adapters.rb:126:in >> `block (2 levels) in <module:MinitestLifecycleAdapter>' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/example.rb:447:in >> `instance_exec' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/example.rb:447:in >> `instance_exec' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/hooks.rb:373:in >> `execute_with' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/hooks.rb:606:in >> `block (2 levels) in run_around_example_hooks_for' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/example.rb:342:in >> `call' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/hooks.rb:607:in >> `run_around_example_hooks_for' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/hooks.rb:464:in >> `run' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/example.rb:457:in >> `with_around_example_hooks' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/example.rb:500:in >> `with_around_and_singleton_context_hooks' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/example.rb:251:in >> `run' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/example_group.rb:629:in >> `block in run_examples' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/example_group.rb:625:in >> `map' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/example_group.rb:625:in >> `run_examples' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/example_group.rb:591:in >> `run' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/example_group.rb:592:in >> `block in run' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/example_group.rb:592:in >> `map' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/example_group.rb:592:in >> `run' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/runner.rb:116:in >> `block (3 levels) in run_specs' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/runner.rb:116:in >> `map' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/runner.rb:116:in >> `block (2 levels) in run_specs' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/configuration.rb:1989:in >> `with_suite_hooks' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/runner.rb:111:in >> `block in run_specs' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/reporter.rb:74:in >> `report' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/runner.rb:110:in >> `run_specs' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/runner.rb:87:in >> `run' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/runner.rb:71:in >> `run' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/lib/rspec/core/runner.rb:45:in >> `invoke' >> # >> /Users/surya/.rvm/gems/ruby-2.3.1/gems/rspec-core-3.8.0/exe/rspec:4:in >> `<top (required)>' >> # /Users/surya/.rvm/gems/ruby-2.3.1/bin/rspec:23:in `load' >> # /Users/surya/.rvm/gems/ruby-2.3.1/bin/rspec:23:in `<main>' >> # /Users/surya/.rvm/gems/ruby-2.3.1/bin/ruby_executable_hooks:15:in >> `eval' >> # /Users/surya/.rvm/gems/ruby-2.3.1/bin/ruby_executable_hooks:15:in >> `<main>' >> # >> # Showing full backtrace because every line was filtered out. >> # See docs for RSpec::Configuration#backtrace_exclusion_patterns >> and >> # RSpec::Configuration#backtrace_inclusion_patterns for more >> information. >> >> On Wed, 12 Sep 2018 at 01:35, Surya <[email protected]> wrote: >> >>> Hi, >>> >>> I am having trouble setting up rspec rails with mongoid. I get the >>> following exception(one of the exceptions but same for all 16 cases) when >>> running the rspec: >>> >>> >>> 16) PostsController routing routes to #destroy >>> Failure/Error: raise ConnectionNotEstablished, "No connection pool >>> with '#{spec_name}' found." unless pool >>> >>> ActiveRecord::ConnectionNotEstablished: >>> No connection pool with 'primary' found. >>> # >>> /Users/surya/.rvm/gems/ruby-2.3.1/gems/activerecord-5.1.6/lib/active_record/connection_adapters/abstract/connection_pool.rb:930:in >>> `retrieve_connection' >>> # >>> /Users/surya/.rvm/gems/ruby-2.3.1/gems/activerecord-5.1.6/lib/active_record/connection_handling.rb:116:in >>> `retrieve_connection' >>> # >>> /Users/surya/.rvm/gems/ruby-2.3.1/gems/activerecord-5.1.6/lib/active_record/connection_handling.rb:88:in >>> `connection' >>> # >>> /Users/surya/.rvm/gems/ruby-2.3.1/gems/activerecord-5.1.6/lib/active_record/fixtures.rb:516:in >>> `create_fixtures' >>> # >>> /Users/surya/.rvm/gems/ruby-2.3.1/gems/activerecord-5.1.6/lib/active_record/fixtures.rb:1028:in >>> `load_fixtures' >>> # >>> /Users/surya/.rvm/gems/ruby-2.3.1/gems/activerecord-5.1.6/lib/active_record/fixtures.rb:999:in >>> `setup_fixtures' >>> # >>> /Users/surya/.rvm/gems/ruby-2.3.1/gems/activerecord-5.1.6/lib/active_record/fixtures.rb:851:in >>> `before_setup' >>> >>> >>> Here is the sample vanilla application code - >>> https://github.com/suryart/rspec_mongo_test_app >>> >>> Steps that I followed : >>> >>> Create a new rails app - >>> >>> $ rails new rspec_mongo_test_app --api --skip-active-record -T >>> >>> Modify Gemfile to this: >>> >>> source 'https://rubygems.org' >>> >>> git_source(:github) do |repo_name| >>> repo_name = "#{repo_name}/#{repo_name}" unless >>> repo_name.include?("/") >>> "https://github.com/#{repo_name}.git" >>> end >>> >>> >>> # Bundle edge Rails instead: gem 'rails', github: 'rails/rails' >>> gem 'rails', '~> 5.1.6' >>> # Use Puma as the app server >>> gem 'puma', '~> 3.7' >>> # Build JSON APIs with ease. Read more: >>> https://github.com/rails/jbuilder >>> # gem 'jbuilder', '~> 2.5' >>> # Use Redis adapter to run Action Cable in production >>> # gem 'redis', '~> 4.0' >>> # Use ActiveModel has_secure_password >>> # gem 'bcrypt', '~> 3.1.7' >>> >>> # Use Capistrano for deployment >>> # gem 'capistrano-rails', group: :development >>> >>> # Use Rack CORS for handling Cross-Origin Resource Sharing (CORS), >>> making cross-origin AJAX possible >>> # gem 'rack-cors' >>> >>> group :development, :test do >>> # Call 'byebug' anywhere in the code to stop execution and get a >>> debugger console >>> gem 'byebug', platforms: [:mri, :mingw, :x64_mingw] >>> # gem 'database_cleaner', '~> 1.7' >>> gem 'factory_bot_rails', '~> 4.x' >>> gem 'forgery', '~> 0.7' >>> gem 'guard-rspec', '4.7.3' >>> gem 'mongoid-rspec', '~> 4.0' >>> gem 'rspec-rails', '~> 3.8' >>> gem 'rubocop', '~> 0.58.2', require: false >>> gem 'simplecov', '~> 0.16', require: false >>> gem 'reek', '~> 5.0', require: false >>> end >>> >>> group :development do >>> gem 'listen', '>= 3.0.5', '< 3.2' >>> # Spring speeds up development by keeping your application running >>> in the background. Read more: https://github.com/rails/spring >>> gem 'spring' >>> gem 'spring-watcher-listen', '~> 2.0.0' >>> end >>> >>> # Windows does not include zoneinfo files, so bundle the tzinfo-data >>> gem >>> gem 'tzinfo-data', platforms: [:mingw, :mswin, :x64_mingw, :jruby] >>> >>> gem 'mongoid', '~> 7.0' >>> >>> gem 'devise_token_auth', '0.1.43' >>> >>> >>> Setup mongoid: >>> >>> $ rails g mongoid:config >>> $ rails g rspec:install >>> >>> >>> Now create a controller >>> >>> $ rails g scaffold post subject:string content:text >>> >>> Made config change in config/application.rb to take mongoid as ORM for >>> generator( >>> https://github.com/suryart/rspec_mongo_test_app/blob/master/config/application.rb), >>> also modified spec_helper.rb to remove all active record related >>> dependencies( >>> https://github.com/suryart/rspec_mongo_test_app/blob/master/spec/rails_helper.rb >>> ). >>> >>> >>> I'm not quite sure what I'm doing wrong here. The whole setup works if I >>> disable the `require 'rspec/rails'` line in rails_helper.rb file but then I >>> can't run all rails controller/requests related tests as they require >>> get/post etc methods. Please help. >>> >>> >>> >>> >>> -- >>> >>> Please consider the environment before printing this email. >>> >>> Regards, >>> Surya >>> >>> [image: This is my Footrr] <http://footrr.com/l/3697/> >>> >> >> >> -- >> >> Please consider the environment before printing this email. >> >> Regards, >> Surya >> >> [image: This is my Footrr] <http://footrr.com/l/3697/> >> > -- > You received this message because you are subscribed to the Google Groups > "rspec" group. > To unsubscribe from this group and stop receiving emails from it, send an > email to [email protected]. > To post to this group, send email to [email protected]. > To view this discussion on the web visit > https://groups.google.com/d/msgid/rspec/ac26adaf-2659-4cd8-9a5e-2442f798058e%40googlegroups.com > <https://groups.google.com/d/msgid/rspec/ac26adaf-2659-4cd8-9a5e-2442f798058e%40googlegroups.com?utm_medium=email&utm_source=footer> > . > For more options, visit https://groups.google.com/d/optout. > -- Please consider the environment before printing this email. Regards, Surya [image: This is my Footrr] <http://footrr.com/l/3697/> -- You received this message because you are subscribed to the Google Groups "rspec" group. To unsubscribe from this group and stop receiving emails from it, send an email to [email protected]. To post to this group, send email to [email protected]. To view this discussion on the web visit https://groups.google.com/d/msgid/rspec/CAHGOqz5u1s7RG3XHucDHj9yVrtHSQR75ximSfpWYdeN%2B38UgLQ%40mail.gmail.com. For more options, visit https://groups.google.com/d/optout.
