2018-05-14 06:31:06 -05:00
|
|
|
#
|
|
|
|
# Copyright (C) 2018 FreeIPA Contributors see COPYING for license
|
|
|
|
#
|
|
|
|
|
2019-06-27 03:52:40 -05:00
|
|
|
from ipaplatform.constants import constants as platformconstants
|
|
|
|
|
|
|
|
# for example, user_u:s0
|
|
|
|
selinuxuser1 = platformconstants.SELINUX_USERMAP_ORDER.split("$$")[0]
|
|
|
|
selinuxuser2 = platformconstants.SELINUX_USERMAP_ORDER.split("$$")[1]
|
|
|
|
|
|
|
|
selinux_mcs_max = platformconstants.SELINUX_MCS_MAX
|
|
|
|
selinux_mls_max = platformconstants.SELINUX_MLS_MAX
|
|
|
|
|
|
|
|
second_mls_level = 's{}'.format(list(range(0, selinux_mls_max + 1))[0])
|
|
|
|
second_mcs_level = 'c{}'.format(list(range(0, selinux_mcs_max + 1))[0])
|
|
|
|
mcs_range = '{0}.{0}'.format(second_mcs_level)
|
|
|
|
|
2018-05-14 06:31:06 -05:00
|
|
|
ENTITY = 'selinuxusermap'
|
|
|
|
|
|
|
|
PKEY = 'itest-selinuxusermap'
|
|
|
|
DATA = {
|
|
|
|
'pkey': PKEY,
|
|
|
|
'add': [
|
|
|
|
('textbox', 'cn', PKEY),
|
2019-06-27 03:52:40 -05:00
|
|
|
('textbox', 'ipaselinuxuser', selinuxuser1),
|
2018-05-14 06:31:06 -05:00
|
|
|
],
|
|
|
|
'mod': [
|
|
|
|
('textarea', 'description', 'itest-selinuxusermap desc'),
|
|
|
|
],
|
|
|
|
}
|
|
|
|
|
|
|
|
PKEY2 = 'itest-selinuxusermap2'
|
|
|
|
DATA2 = {
|
|
|
|
'pkey': PKEY2,
|
|
|
|
'add': [
|
|
|
|
('textbox', 'cn', PKEY2),
|
2019-06-27 03:52:40 -05:00
|
|
|
('textbox', 'ipaselinuxuser', selinuxuser2),
|
2018-05-14 06:31:06 -05:00
|
|
|
],
|
|
|
|
'mod': [
|
|
|
|
('textarea', 'description', 'itest-selinuxusermap desc2'),
|
|
|
|
],
|
|
|
|
}
|
|
|
|
|
|
|
|
PKEY_MLS_RANGE = 'itest-selinuxusermap_MLS_range'
|
|
|
|
DATA_MLS_RANGE = {
|
|
|
|
'pkey': PKEY_MLS_RANGE,
|
|
|
|
'add': [
|
|
|
|
('textbox', 'cn', PKEY_MLS_RANGE),
|
2019-06-27 03:52:40 -05:00
|
|
|
('textbox', 'ipaselinuxuser', 'foo:s0-{}'.format(second_mls_level)),
|
2018-05-14 06:31:06 -05:00
|
|
|
],
|
|
|
|
}
|
|
|
|
|
|
|
|
PKEY_MCS_RANGE = 'itest-selinuxusermap_MLS_range'
|
|
|
|
DATA_MCS_RANGE = {
|
|
|
|
'pkey': PKEY_MCS_RANGE,
|
|
|
|
'add': [
|
|
|
|
('textbox', 'cn', PKEY_MCS_RANGE),
|
2019-06-27 03:52:40 -05:00
|
|
|
('textbox', 'ipaselinuxuser',
|
|
|
|
'foo:s0-s{}:c0.c{}'.format(selinux_mls_max, selinux_mcs_max)
|
|
|
|
),
|
2018-05-14 06:31:06 -05:00
|
|
|
],
|
|
|
|
}
|
|
|
|
|
|
|
|
PKEY_MCS_COMMAS = 'itest-selinuxusermap_MCS_commas'
|
|
|
|
DATA_MCS_COMMAS = {
|
|
|
|
'pkey': PKEY_MCS_COMMAS,
|
|
|
|
'add': [
|
|
|
|
('textbox', 'cn', PKEY_MCS_COMMAS),
|
2019-06-27 03:52:40 -05:00
|
|
|
('textbox', 'ipaselinuxuser',
|
|
|
|
'foo:s0-{}:c0,{},{}'.format(
|
|
|
|
second_mls_level, second_mcs_level, mcs_range),
|
|
|
|
),
|
2018-05-14 06:31:06 -05:00
|
|
|
],
|
|
|
|
}
|
|
|
|
|
|
|
|
PKEY_MLS_SINGLE_VAL = 'itest-selinuxusermap_MLS_single_val'
|
|
|
|
DATA_MLS_SINGLE_VAL = {
|
|
|
|
'pkey': PKEY_MLS_SINGLE_VAL,
|
|
|
|
'add': [
|
|
|
|
('textbox', 'cn', PKEY_MLS_SINGLE_VAL),
|
2019-06-27 03:52:40 -05:00
|
|
|
('textbox', 'ipaselinuxuser',
|
|
|
|
'foo:s0-s0:c0.c{}'.format(selinux_mcs_max)
|
|
|
|
),
|
2018-05-14 06:31:06 -05:00
|
|
|
],
|
|
|
|
}
|
|
|
|
|
|
|
|
PKEY_NON_EXIST_SEUSER = 'itest-selinuxusermap_nonexistent_user'
|
|
|
|
DATA_NON_EXIST_SEUSER = {
|
|
|
|
'pkey': PKEY_NON_EXIST_SEUSER,
|
|
|
|
'add': [
|
|
|
|
('textbox', 'cn', PKEY_NON_EXIST_SEUSER),
|
2019-06-27 03:52:40 -05:00
|
|
|
('textbox', 'ipaselinuxuser', 'foo:s0'),
|
2018-05-14 06:31:06 -05:00
|
|
|
],
|
|
|
|
}
|
|
|
|
|
|
|
|
PKEY_INVALID_MCS = 'itest-selinuxusermap_invalid_MCS'
|
|
|
|
DATA_INVALID_MCS = {
|
|
|
|
'pkey': PKEY_INVALID_MCS,
|
|
|
|
'add': [
|
|
|
|
('textbox', 'cn', PKEY_INVALID_MCS),
|
2019-06-27 03:52:40 -05:00
|
|
|
('textbox', 'ipaselinuxuser', 'foo:s0:c'),
|
2018-05-14 06:31:06 -05:00
|
|
|
],
|
|
|
|
}
|
|
|
|
|
|
|
|
PKEY_INVALID_MLS = 'itest-selinuxusermap_invalid_MLS'
|
|
|
|
DATA_INVALID_MLS = {
|
|
|
|
'pkey': PKEY_INVALID_MLS,
|
|
|
|
'add': [
|
|
|
|
('textbox', 'cn', PKEY_INVALID_MLS),
|
2019-06-27 03:52:40 -05:00
|
|
|
('textbox', 'ipaselinuxuser', 'foo'),
|
2018-05-14 06:31:06 -05:00
|
|
|
],
|
|
|
|
}
|
|
|
|
|
|
|
|
PKEY_FIELD_REQUIRED = 'itest-selinuxusermap_without_SELinux_user'
|
|
|
|
DATA_FIELD_REQUIRED = {
|
|
|
|
'pkey': PKEY_FIELD_REQUIRED,
|
|
|
|
'add': [
|
|
|
|
('textbox', 'cn', PKEY_FIELD_REQUIRED),
|
|
|
|
],
|
|
|
|
}
|