1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-25 14:52:20 +01:00
fab-manager/test/integration/exports/availabilites_export_test.rb

60 lines
2.0 KiB
Ruby
Raw Normal View History

2020-07-22 11:16:43 +02:00
# frozen_string_literal: true
require 'test_helper'
require 'rubyXL'
module Exports; end
2020-07-22 12:23:01 +02:00
class Exports::AvailabilitiesExportTest < ActionDispatch::IntegrationTest
2020-07-22 11:16:43 +02:00
setup do
admin = User.with_role(:admin).first
login_as(admin, scope: :user)
end
test 'export availabilities to Excel' do
# First, we create a new export
get '/api/availabilities/export_index.xlsx'
# Check response format & status
assert_equal 200, response.status, response.body
assert_equal Mime[:json], response.content_type
# Check the export was created correctly
res = json_response(response.body)
e = Export.where(id: res[:export_id]).first
assert_not_nil e, 'Export was not created in database'
# Run the worker
worker = AvailabilitiesExportWorker.new
worker.perform(e.id)
# notification
assert_not_empty Notification.where(attached_object: e)
# resulting XLSX file
assert FileTest.exist?(e.file), 'XLSX file was not generated'
workbook = RubyXL::Parser.parse(e.file)
# test worksheets
assert_not_nil workbook[I18n.t('export_availabilities.machines')]
assert_not_nil workbook[I18n.t('export_availabilities.trainings')]
assert_not_nil workbook[I18n.t('export_availabilities.events')]
if Setting.get('spaces_module')
assert_not_nil workbook[I18n.t('export_availabilities.spaces')]
else
assert_nil workbook[I18n.t('export_availabilities.spaces')]
end
# test data
availability = Availability.find(13)
machines = workbook[I18n.t('export_availabilities.machines')]
assert_equal availability.start_at.to_date, machines.sheet_data[1][0].value.to_date
assert_equal I18n.l(availability.start_at, format: '%A').capitalize, machines.sheet_data[1][1].value
assert_match(/^#{availability.start_at.strftime('%H:%M')} - /, machines.sheet_data[1][2].value)
assert_includes availability.machines.map(&:name), machines.sheet_data[1][3].value
# Clean XLSX file
require 'fileutils'
FileUtils.rm(e.file)
end
end