Ожидаемый ответ: <2XX: success>, но был <403: запрещен> для теста контроллера - PullRequest
0 голосов
/ 06 марта 2020

Я пытаюсь запустить простой тест на Ruby в приложении на Rails 6.0, но получаю ошибку 403.

Alberts-MacBook-Pro:rr albertski$ rails test test/controllers/categories_controller_test.rb
Running via Spring preloader in process 72301
Run options: --seed 53214

# Running:

F

Failure:
CategoriesControllerTest#test_should_get_categories_index [/Users/albertski/Sites/rr/test/controllers/categories_controller_test.rb:10]:
Expected response to be a <2XX: success>, but was a <403: Forbidden>

Categories_controller.rb

class CategoriesController < ApplicationController
  def index

  end

  def new

  end

  def show

  end
end

Categories_controller_test.rb

require 'test_helper'

class CategoriesControllerTest < ActionDispatch::IntegrationTest
  def setup
    @category = Category.create(name: "sports")
  end

  test "should get categories index" do
    get categories_path
    assert_response :success
  end

end

application_controller.rb

class ApplicationController < ActionController::Base

  helper_method :current_user, :logged_in?

  def current_user
    @current_user ||= User.find(session[:user_id]) if session[:user_id]
  end

  def logged_in?
    !!current_user
  end

  def require_user
    if !logged_in?
      flash[:danger] = "You must be logged in to perform this action"
      redirect_to root_path
    end
  end
end

config / environment / test.rb

# The test environment is used exclusively to run your application's
# test suite. You never need to work with it otherwise. Remember that
# your test database is "scratch space" for the test suite and is wiped
# and recreated between test runs. Don't rely on the data there!

Rails.application.routes.default_url_options[:host] = 'http://localhost:3000'

Rails.application.configure do
  # Settings specified here will take precedence over those in config/application.rb.
  config.hosts << "localhost:3000"

  config.cache_classes = false

  # Do not eager load code on boot. This avoids loading your whole application
  # just for the purpose of running a single test. If you are using a tool that
  # preloads Rails for running tests, you may have to set it to true.
  config.eager_load = false

  # Configure public file server for tests with Cache-Control for performance.
  config.public_file_server.enabled = true
  config.public_file_server.headers = {
    'Cache-Control' => "public, max-age=#{1.hour.to_i}"
  }

  # Show full error reports and disable caching.
  config.consider_all_requests_local       = true
  config.action_controller.perform_caching = false
  config.cache_store = :null_store

  # Raise exceptions instead of rendering exception templates.
  config.action_dispatch.show_exceptions = false

  # Disable request forgery protection in test environment.
  config.action_controller.allow_forgery_protection = false

  # Store uploaded files on the local file system in a temporary directory.
  config.active_storage.service = :test

  config.action_mailer.perform_caching = false

  # Tell Action Mailer not to deliver emails to the real world.
  # The :test delivery method accumulates sent emails in the
  # ActionMailer::Base.deliveries array.
  config.action_mailer.delivery_method = :test

  # Print deprecation notices to the stderr.
  config.active_support.deprecation = :stderr

  # Raises error for missing translations.
  # config.action_view.raise_on_missing_translations = true
end

Я сделал отладку get categories_path и она возвращает /categories. Кроме того, при просмотре пути /categories в браузере у меня нет проблем; это происходит только в тесте.

1 Ответ

1 голос
/ 07 марта 2020

Мне удалось найти проблему, добавив byebug к моему тесту и распечатав response, который указал мне следующее сообщение:

Blocked host: www.example.com

To allow requests to www.example.com, add the following to your environment configuration:

config.hosts << \"www.example.com\"

Обновление до config.hosts << "www.example.com" устранило проблему .

Кроме того, не уверен, почему у меня там было config.hosts << "localhost:3000". Удаление этой строки также устраняет проблему.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...