OpenProject is the leading open source project management software.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
openproject/spec/legacy/functional/my_controller_spec.rb

174 lines
5.0 KiB

#-- encoding: UTF-8
#-- copyright
# OpenProject is a project management system.
# Copyright (C) 2012-2015 the OpenProject Foundation (OPF)
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License version 3.
#
# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
# Copyright (C) 2006-2013 Jean-Philippe Lang
# Copyright (C) 2010-2013 the ChiliProject Team
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#
# See doc/COPYRIGHT.rdoc for more details.
#++
require 'legacy_spec_helper'
require 'my_controller'
describe MyController, type: :controller do
fixtures :all
before do
session[:user_id] = 2
end
it 'should index' do
get :index
assert_response :success
assert_template 'page'
end
it 'should page' do
get :page
assert_response :success
assert_template 'page'
end
it 'should my account should not show non editable custom fields' do
UserCustomField.find(4).update_attribute :editable, false
get :account
assert_response :success
assert_template 'account'
assert_equal User.find(2), assigns(:user)
assert_no_tag :input, attributes: { name: 'user[custom_field_values][4]' }
end
it 'should update account' do
patch :account,
user: {
firstname: 'Joe',
login: 'root', # should not be allowed
admin: 1,
group_ids: ['10'],
custom_field_values: { '4' => '0100562500' }
}
assert_redirected_to '/my/account'
user = User.find(2)
assert_equal user, assigns(:user)
assert_equal 'Joe', user.firstname
assert_equal 'jsmith', user.login
assert_equal '0100562500', user.custom_value_for(4).value
# ignored
assert !user.admin?
assert user.groups.empty?
end
it 'should page layout' do
get :page_layout
assert_response :success
assert_template 'page_layout'
end
it 'should add block' do
xhr :post, :add_block, block: 'issuesreportedbyme'
assert_response :success
assert User.find(2).pref[:my_page_layout]['top'].include?('issuesreportedbyme')
end
it 'should remove block' do
xhr :post, :remove_block, block: 'issuesassignedtome'
assert_response :success
assert !User.find(2).pref[:my_page_layout].values.flatten.include?('issuesassignedtome')
end
it 'should order blocks' do
xhr :post, :order_blocks, group: 'left', 'list-left' => ['documents', 'calendar', 'latestnews']
assert_response :success
assert_equal ['documents', 'calendar', 'latestnews'], User.find(2).pref[:my_page_layout]['left']
end
context 'POST to reset_rss_key' do
context 'with an existing rss_token' do
before do
@previous_token_value = User.find(2).rss_key # Will generate one if it's missing
post :reset_rss_key
end
it 'should destroy the existing token' do
assert_not_equal @previous_token_value, User.find(2).rss_key
end
it 'should create a new token' do
assert User.find(2).rss_token
end
it { is_expected.to set_flash.to /reset/ }
it { is_expected.to redirect_to '/my/account' }
end
context 'with no rss_token' do
before do
assert_nil User.find(2).rss_token
post :reset_rss_key
end
it 'should create a new token' do
assert User.find(2).rss_token
end
it { is_expected.to set_flash.to /reset/ }
it { is_expected.to redirect_to '/my/account' }
end
end
context 'POST to reset_api_key' do
context 'with an existing api_token' do
before do
@previous_token_value = User.find(2).api_key # Will generate one if it's missing
post :reset_api_key
end
it 'should destroy the existing token' do
assert_not_equal @previous_token_value, User.find(2).api_key
end
it 'should create a new token' do
assert User.find(2).api_token
end
it { is_expected.to set_flash.to /reset/ }
it { is_expected.to redirect_to '/my/account' }
end
context 'with no api_token' do
before do
assert_nil User.find(2).api_token
post :reset_api_key
end
it 'should create a new token' do
assert User.find(2).api_token
end
it { is_expected.to set_flash.to /reset/ }
it { is_expected.to redirect_to '/my/account' }
end
end
end