170 lines
4.9 KiB
Ruby
170 lines
4.9 KiB
Ruby
|
# encoding: utf-8
|
||
|
require 'test_helper'
|
||
|
|
||
|
class ObjectCreateUpdateWithRefNameTest < ActiveSupport::TestCase
|
||
|
test 'organization' do
|
||
|
roles = Role.where(name: %w(Agent Admin))
|
||
|
groups = Group.all
|
||
|
user1 = User.create_or_update(
|
||
|
login: 'object_ref_name1@example.org',
|
||
|
firstname: 'object_ref_name1',
|
||
|
lastname: 'object_ref_name1',
|
||
|
email: 'object_ref_name1@example.org',
|
||
|
password: 'some_pass',
|
||
|
active: true,
|
||
|
updated_by_id: 1,
|
||
|
created_by_id: 1,
|
||
|
roles: roles,
|
||
|
groups: groups,
|
||
|
)
|
||
|
user2 = User.create_or_update(
|
||
|
login: 'object_ref_name2@example.org',
|
||
|
firstname: 'object_ref_name2',
|
||
|
lastname: 'object_ref_name2',
|
||
|
email: 'object_ref_name2@example.org',
|
||
|
password: 'some_pass',
|
||
|
active: true,
|
||
|
updated_by_id: 1,
|
||
|
created_by_id: 1,
|
||
|
roles: roles,
|
||
|
groups: groups,
|
||
|
)
|
||
|
|
||
|
org1 = Organization.create_if_not_exists_with_ref(
|
||
|
name: 'some org update_with_ref member',
|
||
|
members: ['object_ref_name1@example.org'],
|
||
|
updated_by_id: 1,
|
||
|
created_by_id: 1,
|
||
|
)
|
||
|
|
||
|
assert(org1.member_ids.sort.include?(user1.id))
|
||
|
assert_not(org1.member_ids.sort.include?(user2.id))
|
||
|
|
||
|
org2 = Organization.create_or_update_with_ref(
|
||
|
name: 'some org update_with_ref member',
|
||
|
members: ['object_ref_name2@example.org'],
|
||
|
updated_by_id: 1,
|
||
|
created_by_id: 1,
|
||
|
)
|
||
|
|
||
|
assert_not(org2.member_ids.sort.include?(user1.id))
|
||
|
assert(org2.member_ids.sort.include?(user2.id))
|
||
|
assert_equal(org1.id, org2.id)
|
||
|
|
||
|
org3 = Organization.create_or_update_with_ref(
|
||
|
name: 'some org update_with_ref member2',
|
||
|
members: ['object_ref_name2@example.org'],
|
||
|
updated_by_id: 1,
|
||
|
created_by_id: 1,
|
||
|
)
|
||
|
|
||
|
assert_not(org3.member_ids.sort.include?(user1.id))
|
||
|
assert(org3.member_ids.sort.include?(user2.id))
|
||
|
assert_not_equal(org2.id, org3.id)
|
||
|
|
||
|
assert_raises( ActiveRecord::AssociationTypeMismatch ) {
|
||
|
Organization.create_or_update_with_ref(
|
||
|
name: 'some org update_with_ref member2',
|
||
|
members: ['object_ref_name2@example.org'],
|
||
|
member_ids: [2],
|
||
|
updated_by_id: 1,
|
||
|
created_by_id: 1,
|
||
|
)
|
||
|
}
|
||
|
|
||
|
end
|
||
|
|
||
|
test 'user' do
|
||
|
org1 = Organization.create_if_not_exists_with_ref(
|
||
|
name: 'some org update_with_ref user',
|
||
|
updated_by_id: 1,
|
||
|
created_by_id: 1,
|
||
|
)
|
||
|
user1 = User.create_or_update_with_ref(
|
||
|
login: 'object_ref_name1@example.org',
|
||
|
firstname: 'object_ref_name1',
|
||
|
lastname: 'object_ref_name1',
|
||
|
email: 'object_ref_name1@example.org',
|
||
|
password: 'some_pass',
|
||
|
active: true,
|
||
|
organization: 'some org update_with_ref user',
|
||
|
updated_by_id: 1,
|
||
|
created_by_id: 1,
|
||
|
roles: %w(Agent Admin),
|
||
|
groups: ['Users'],
|
||
|
)
|
||
|
user2 = User.create_or_update_with_ref(
|
||
|
login: 'object_ref_name2@example.org',
|
||
|
firstname: 'object_ref_name2',
|
||
|
lastname: 'object_ref_name2',
|
||
|
email: 'object_ref_name2@example.org',
|
||
|
password: 'some_pass',
|
||
|
organization_id: nil,
|
||
|
active: true,
|
||
|
updated_by_id: 1,
|
||
|
created_by_id: 1,
|
||
|
roles: ['Customer'],
|
||
|
groups: [],
|
||
|
)
|
||
|
admin_role = Role.lookup(name: 'Admin')
|
||
|
agent_role = Role.lookup(name: 'Agent')
|
||
|
customer_role = Role.lookup(name: 'Customer')
|
||
|
|
||
|
users_group = Group.lookup(name: 'Users')
|
||
|
|
||
|
assert(user1.organization.name, 'some org update_with_ref user')
|
||
|
assert(user1.group_ids.include?(users_group.id))
|
||
|
assert(user1.role_ids.include?(admin_role.id))
|
||
|
assert(user1.role_ids.include?(agent_role.id))
|
||
|
assert_not(user1.role_ids.include?(customer_role.id))
|
||
|
|
||
|
assert_equal(nil, user2.organization_id)
|
||
|
assert_not(user2.group_ids.include?(users_group.id))
|
||
|
assert_not(user2.role_ids.include?(admin_role.id))
|
||
|
assert_not(user2.role_ids.include?(agent_role.id))
|
||
|
assert(user2.role_ids.include?(customer_role.id))
|
||
|
|
||
|
end
|
||
|
|
||
|
test 'group' do
|
||
|
user1 = User.create_or_update_with_ref(
|
||
|
login: 'object_ref_name1@example.org',
|
||
|
firstname: 'object_ref_name1',
|
||
|
lastname: 'object_ref_name1',
|
||
|
email: 'object_ref_name1@example.org',
|
||
|
password: 'some_pass',
|
||
|
active: true,
|
||
|
organization_id: nil,
|
||
|
updated_by_id: 1,
|
||
|
created_by_id: 1,
|
||
|
roles: %w(Agent Admin),
|
||
|
groups: [],
|
||
|
)
|
||
|
user2 = User.create_or_update_with_ref(
|
||
|
login: 'object_ref_name2@example.org',
|
||
|
firstname: 'object_ref_name2',
|
||
|
lastname: 'object_ref_name2',
|
||
|
email: 'object_ref_name2@example.org',
|
||
|
password: 'some_pass',
|
||
|
organization_id: nil,
|
||
|
active: true,
|
||
|
updated_by_id: 1,
|
||
|
created_by_id: 1,
|
||
|
roles: ['Customer'],
|
||
|
groups: [],
|
||
|
)
|
||
|
|
||
|
group1 = Group.create_if_not_exists_with_ref(
|
||
|
name: 'some group update_with_ref',
|
||
|
users: ['object_ref_name1@example.org'],
|
||
|
updated_by_id: 1,
|
||
|
created_by_id: 1,
|
||
|
)
|
||
|
|
||
|
assert(group1.name, 'some group update_with_ref')
|
||
|
assert(group1.user_ids.include?(user1.id))
|
||
|
assert_not(group1.user_ids.include?(user2.id))
|
||
|
|
||
|
end
|
||
|
end
|