# frozen_string_literal: true

require 'test_helper'
require 'rubyXL'

module Exports; end

class Exports::ReservationsExportTest < ActionDispatch::IntegrationTest
  setup do
    admin = User.with_role(:admin).first
    login_as(admin, scope: :user)
  end

  test 'export reservations to Excel' do
    # First, we create a new export
    get '/api/members/export_reservations.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 = UsersExportWorker.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 worksheet
    assert_not_nil workbook[I18n.t('export_reservations.reservations')]

    # test data
    reservation = Reservation.find(1)
    wb = workbook[I18n.t('export_reservations.reservations')]
    assert_equal reservation.user.id, wb.sheet_data[1][0].value
    assert_equal reservation.created_at.to_date, wb.sheet_data[1][3].value.to_date
    assert_equal reservation.reservable_type, wb.sheet_data[1][4].value

    # Clean XLSX file
    require 'fileutils'
    FileUtils.rm(e.file)
  end
end