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/models/projects/exporter/csv_integration_spec.rb

91 lines
2.9 KiB

#-- encoding: UTF-8
#-- copyright
# OpenProject is an open source project management software.
# Copyright (C) 2012-2021 the OpenProject GmbH
#
# 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 COPYRIGHT and LICENSE files for more details.
#++
require 'spec_helper'
require_relative 'exportable_project_context'
describe Projects::Exports::CSV, 'integration', type: :model do
include_context 'with a project with an arrangement of custom fields'
include_context 'with an instance of the described exporter'
let(:parsed) do
CSV.parse(output)
end
let(:header) { parsed.first }
let(:rows) { parsed.drop(1) }
it 'performs a successful export' do
expect(parsed.size).to eq(2)
expect(parsed.last).to eq [project.id.to_s, project.identifier, project.name, 'Off track', 'false']
end
describe 'custom field columns selected' do
before do
Setting.enabled_projects_columns += custom_fields.map { |cf| "cf_#{cf.id}" }
end
context 'when ee enabled', with_ee: %i[custom_fields_in_projects_list] do
it 'renders all those columns' do
expect(parsed.size).to eq 2
cf_names = custom_fields.map(&:name)
expect(header).to eq ['id', 'Identifier', 'Name', 'Status', 'Public', *cf_names]
custom_values = custom_fields.map do |cf|
if cf == bool_cf
'true'
else
project.formatted_custom_value_for(cf)
end
end
expect(rows.first)
.to eq [project.id.to_s, project.identifier, project.name, 'Off track', 'false', *custom_values]
end
end
context 'when ee not enabled' do
it 'renders only the default columns' do
expect(header).to eq %w[id Identifier Name Status Public]
end
end
end
context 'with no project visible' do
let(:current_user) { User.anonymous }
it 'does not include the project' do
expect(output).not_to include project.identifier
expect(parsed.size).to eq(1)
end
end
end