Chris@909: # Redmine - project management software Chris@1494: # Copyright (C) 2006-2014 Jean-Philippe Lang Chris@0: # Chris@0: # This program is free software; you can redistribute it and/or Chris@0: # modify it under the terms of the GNU General Public License Chris@0: # as published by the Free Software Foundation; either version 2 Chris@0: # of the License, or (at your option) any later version. Chris@909: # Chris@0: # This program is distributed in the hope that it will be useful, Chris@0: # but WITHOUT ANY WARRANTY; without even the implied warranty of Chris@0: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the Chris@0: # GNU General Public License for more details. Chris@909: # Chris@0: # You should have received a copy of the GNU General Public License Chris@0: # along with this program; if not, write to the Free Software Chris@0: # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. Chris@0: Chris@119: require File.expand_path('../../test_helper', __FILE__) Chris@0: Chris@0: class WelcomeControllerTest < ActionController::TestCase Chris@1115: fixtures :projects, :news, :users, :members Chris@909: Chris@0: def setup Chris@0: User.current = nil Chris@0: end Chris@909: Chris@0: def test_index Chris@0: get :index Chris@0: assert_response :success Chris@0: assert_template 'index' Chris@0: assert_not_nil assigns(:news) Chris@0: assert_not_nil assigns(:projects) Chris@1464: assert !assigns(:projects).include?(Project.where(:is_public => false).first) Chris@0: end Chris@909: Chris@0: def test_browser_language Chris@0: Setting.default_language = 'en' Chris@0: @request.env['HTTP_ACCEPT_LANGUAGE'] = 'fr,fr-fr;q=0.8,en-us;q=0.5,en;q=0.3' Chris@0: get :index Chris@0: assert_equal :fr, @controller.current_language Chris@0: end Chris@909: Chris@0: def test_browser_language_alternate Chris@0: Setting.default_language = 'en' Chris@0: @request.env['HTTP_ACCEPT_LANGUAGE'] = 'zh-TW' Chris@0: get :index Chris@0: assert_equal :"zh-TW", @controller.current_language Chris@0: end Chris@909: Chris@0: def test_browser_language_alternate_not_valid Chris@0: Setting.default_language = 'en' Chris@0: @request.env['HTTP_ACCEPT_LANGUAGE'] = 'fr-CA' Chris@0: get :index Chris@0: assert_equal :fr, @controller.current_language Chris@0: end Chris@909: Chris@0: def test_robots Chris@0: get :robots Chris@0: assert_response :success Chris@0: assert_equal 'text/plain', @response.content_type Chris@0: assert @response.body.match(%r{^Disallow: /projects/ecookbook/issues\r?$}) Chris@0: end Chris@909: Chris@245: def test_warn_on_leaving_unsaved_turn_on Chris@245: user = User.find(2) Chris@245: user.pref.warn_on_leaving_unsaved = '1' Chris@245: user.pref.save! Chris@245: @request.session[:user_id] = 2 Chris@909: Chris@245: get :index Chris@245: assert_tag 'script', Chris@245: :attributes => {:type => "text/javascript"}, Chris@1115: :content => %r{warnLeavingUnsaved} Chris@245: end Chris@909: Chris@245: def test_warn_on_leaving_unsaved_turn_off Chris@245: user = User.find(2) Chris@245: user.pref.warn_on_leaving_unsaved = '0' Chris@245: user.pref.save! Chris@245: @request.session[:user_id] = 2 Chris@909: Chris@245: get :index Chris@245: assert_no_tag 'script', Chris@245: :attributes => {:type => "text/javascript"}, Chris@1115: :content => %r{warnLeavingUnsaved} Chris@1115: end Chris@1115: Chris@1464: def test_logout_link_should_post Chris@1464: @request.session[:user_id] = 2 Chris@1464: Chris@1464: get :index Chris@1464: assert_select 'a[href=/logout][data-method=post]', :text => 'Sign out' Chris@1464: end Chris@1464: Chris@1115: def test_call_hook_mixed_in Chris@1115: assert @controller.respond_to?(:call_hook) Chris@1115: end Chris@1115: Chris@1115: def test_project_jump_box_should_escape_names_once Chris@1115: Project.find(1).update_attribute :name, 'Foo & Bar' Chris@1115: @request.session[:user_id] = 2 Chris@1115: Chris@1115: get :index Chris@1115: assert_select "#header select" do Chris@1115: assert_select "option", :text => 'Foo & Bar' Chris@1115: end Chris@1115: end Chris@1115: Chris@1464: def test_api_offset_and_limit_without_params Chris@1464: assert_equal [0, 25], @controller.api_offset_and_limit({}) Chris@1464: end Chris@1115: Chris@1464: def test_api_offset_and_limit_with_limit Chris@1464: assert_equal [0, 30], @controller.api_offset_and_limit({:limit => 30}) Chris@1464: assert_equal [0, 100], @controller.api_offset_and_limit({:limit => 120}) Chris@1464: assert_equal [0, 25], @controller.api_offset_and_limit({:limit => -10}) Chris@1464: end Chris@1115: Chris@1464: def test_api_offset_and_limit_with_offset Chris@1464: assert_equal [10, 25], @controller.api_offset_and_limit({:offset => 10}) Chris@1464: assert_equal [0, 25], @controller.api_offset_and_limit({:offset => -10}) Chris@1464: end Chris@1115: Chris@1464: def test_api_offset_and_limit_with_offset_and_limit Chris@1464: assert_equal [10, 50], @controller.api_offset_and_limit({:offset => 10, :limit => 50}) Chris@1464: end Chris@1115: Chris@1464: def test_api_offset_and_limit_with_page Chris@1464: assert_equal [0, 25], @controller.api_offset_and_limit({:page => 1}) Chris@1464: assert_equal [50, 25], @controller.api_offset_and_limit({:page => 3}) Chris@1464: assert_equal [0, 25], @controller.api_offset_and_limit({:page => 0}) Chris@1464: assert_equal [0, 25], @controller.api_offset_and_limit({:page => -2}) Chris@1464: end Chris@1115: Chris@1464: def test_api_offset_and_limit_with_page_and_limit Chris@1464: assert_equal [0, 100], @controller.api_offset_and_limit({:page => 1, :limit => 100}) Chris@1464: assert_equal [200, 100], @controller.api_offset_and_limit({:page => 3, :limit => 100}) Chris@1464: end Chris@1115: Chris@1464: def test_unhautorized_exception_with_anonymous_should_redirect_to_login Chris@1464: WelcomeController.any_instance.stubs(:index).raises(::Unauthorized) Chris@1115: Chris@1464: get :index Chris@1464: assert_response 302 Chris@1464: assert_redirected_to('/login?back_url='+CGI.escape('http://test.host/')) Chris@1464: end Chris@1115: Chris@1464: def test_unhautorized_exception_with_anonymous_and_xmlhttprequest_should_respond_with_401_to_anonymous Chris@1464: WelcomeController.any_instance.stubs(:index).raises(::Unauthorized) Chris@1115: Chris@1464: @request.env["HTTP_X_REQUESTED_WITH"] = "XMLHttpRequest" Chris@1464: get :index Chris@1464: assert_response 401 Chris@245: end Chris@0: end