перенаправление i18n ломает мои тесты - PullRequest
1 голос
/ 06 апреля 2010

У меня есть большое приложение, которое прошло более тысячи тестов через rspec.

Мы только что сделали выбор: перенаправить любую страницу, например:

/
/foo
/foo/4/bar/34
...

TO:

/en
/en/foo
/fr/foo/4/bar/34 
....

Итак, я сделал фильтр before в application.rb примерно так:

if params[:locale].blank?
  headers["Status"] = "301 Moved Permanently"
  redirect_to request.env['REQUEST_URI'].sub!(%r(^(http.?://[^/]*)?(.*))) { "#{$1}/#{I18n.locale}#{$2}" }
end

Он отлично работает, но ... он ломает многие мои тесты, например:

  it "should return 404" do
    Video.should_receive(:failed_encodings).and_return([])
    get :last_failed_encoding
    response.status.should == "404 Not Found"
  end

Чтобы исправить этот тест, я должен сделать:

    get :last_failed_encoding, :locale => "en"

Но ... серьезно, я не хочу исправлять все мои тесты один за другим ...

Я пыталсясделать локаль параметром по умолчанию, подобным этому:

class ActionController::TestCase
  alias_method(:old_get, :get) unless method_defined?(:old_get)
  def get(path, parameters = {}, headers = nil)
    parameters.merge({:locale => "fr"}) if parameters[:locale].blank?
    old_get(path, parameters, headers)
  end  
end

... но не смог заставить это работать ... Есть идеи ??

1 Ответ

0 голосов
/ 06 апреля 2010

Почему бы не определить эту локаль, если не раньше?

В вашем приложении контроллер:

params[:locale] = i18n.locale if params[:locale].blank?

После того, как ваше приложение имеет локальное определение, ссылка может быть хорошей.

...