mirror of
https://github.com/LaCasemate/fab-manager.git
synced 2024-12-15 00:24:09 +01:00
73 lines
3.7 KiB
Ruby
73 lines
3.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'test_helper'
|
|
|
|
class ImportTest < ActionDispatch::IntegrationTest
|
|
# Called before every test method runs. Can be used
|
|
# to set up fixture information.
|
|
def setup
|
|
@admin = User.find_by(username: 'admin')
|
|
login_as(@admin, scope: :user)
|
|
end
|
|
|
|
test 'bulk import members through CSV' do
|
|
bulk_csv = fixture_file_upload('files/members.csv', 'text/csv')
|
|
post '/api/imports/members',
|
|
params: {
|
|
import_members: bulk_csv,
|
|
update_field: 'id'
|
|
}, headers: default_headers
|
|
|
|
assert_equal 201, response.status, response.body
|
|
assert_equal Mime[:json], response.content_type
|
|
|
|
# Check that the returned import was created
|
|
import = json_response(response.body)
|
|
assert_not_nil import[:id], 'no returned id for the import'
|
|
db_import = Import.find(import[:id])
|
|
assert_not_nil db_import
|
|
|
|
# run the import synchronously
|
|
worker = MembersImportWorker.new
|
|
worker.perform(import[:id])
|
|
|
|
# check the results were written
|
|
db_import.reload
|
|
assert_not_empty db_import.results, 'import results were not written'
|
|
res = db_import.results_hash
|
|
assert_not_nil res[0][:row], 'import result does not contains the imported data row'
|
|
assert_not_nil res[1][:status], 'import result does not contains the operation applied to the row (create/update)'
|
|
assert_not_nil res[1][:result], 'import result does not contains the result of the operation'
|
|
|
|
# check the results match the expectations
|
|
assert_not_nil res[1][:user], 'wrong user: victor hugo is expected to have been created in database'
|
|
assert_equal 'create', res[1][:status], 'wrong operation: victor hugo should have been created'
|
|
assert res[1][:result], 'wrong result: operation should have succeeded'
|
|
assert_equal 1, User.where(id: res[1][:user]).count, 'victor hugo was not found in database'
|
|
assert_equal res[0][:row]['external_id'], User.find(res[1][:user]).invoicing_profile.external_id, 'victor hugo has a wrong external ID'
|
|
|
|
assert_not_nil res[3][:user], 'wrong user: louise michel is expected to have been created in database'
|
|
assert_equal 'create', res[3][:status], 'wrong operation: louise michel should have been created'
|
|
assert res[3][:result], 'wrong result: operation should have succeeded'
|
|
assert_equal 1, User.where(id: res[3][:user]).count, 'louise michel was not found in database'
|
|
|
|
assert_not_nil res[5][:user], 'wrong user: ambroise croizat is expected to have been created in database'
|
|
assert_equal 'create', res[5][:status], 'wrong operation: ambroise croizat should have been created'
|
|
assert res[5][:result], 'wrong result: operation should have succeeded'
|
|
assert_equal 1, User.where(id: res[5][:user]).count, 'ambroise croizat was not found in database'
|
|
|
|
assert_nil res[7][:user], 'wrong user: rirette maitrejean is not expected to have been created in database'
|
|
assert_equal 'create', res[7][:status], 'wrong operation: rirette maitrejean should have been created'
|
|
assert_not res[7][:result], 'wrong result: operation should have failed'
|
|
assert_equal 0, Profile.where(last_name: res[6][:row]['last_name']).count, 'rirette maitrejean was found in database'
|
|
|
|
assert_match(/can't be blank/, res[8][:email].to_json)
|
|
assert_match(/can't be blank/, res[8][:username].to_json)
|
|
|
|
assert_not_nil res[10][:user], 'wrong user: jean dupont is expected to exists in database'
|
|
assert_equal 'update', res[10][:status], 'wrong operation: jean dupont should have been updated'
|
|
assert res[10][:result], 'wrong result: operation should have succeeded'
|
|
assert_equal res[9][:row]['email'], User.find(res[10][:user]).email, 'jean dupont email was not updated'
|
|
end
|
|
end
|