7 from ceph
.deployment
.service_spec
import HostPlacementSpec
, PlacementSpec
, \
8 ServiceSpec
, ServiceSpecValidationError
, RGWSpec
, NFSServiceSpec
, IscsiServiceSpec
9 from ceph
.deployment
.drive_group
import DriveGroupSpec
12 @pytest.mark
.parametrize("test_input,expected, require_network",
13 [("myhost", ('myhost', '', ''), False),
14 ("myhost=sname", ('myhost', '', 'sname'), False),
15 ("myhost:10.1.1.10", ('myhost', '10.1.1.10', ''), True),
16 ("myhost:10.1.1.10=sname", ('myhost', '10.1.1.10', 'sname'), True),
17 ("myhost:10.1.1.0/32", ('myhost', '10.1.1.0/32', ''), True),
18 ("myhost:10.1.1.0/32=sname", ('myhost', '10.1.1.0/32', 'sname'), True),
19 ("myhost:[v1:10.1.1.10:6789]", ('myhost', '[v1:10.1.1.10:6789]', ''), True),
20 ("myhost:[v1:10.1.1.10:6789]=sname", ('myhost', '[v1:10.1.1.10:6789]', 'sname'), True),
21 ("myhost:[v1:10.1.1.10:6789,v2:10.1.1.11:3000]", ('myhost', '[v1:10.1.1.10:6789,v2:10.1.1.11:3000]', ''), True),
22 ("myhost:[v1:10.1.1.10:6789,v2:10.1.1.11:3000]=sname", ('myhost', '[v1:10.1.1.10:6789,v2:10.1.1.11:3000]', 'sname'), True),
24 def test_parse_host_placement_specs(test_input
, expected
, require_network
):
25 ret
= HostPlacementSpec
.parse(test_input
, require_network
=require_network
)
26 assert ret
== expected
27 assert str(ret
) == test_input
30 @pytest.mark
.parametrize(
31 "test_input,expected",
33 ('', "PlacementSpec()"),
34 ("count:2", "PlacementSpec(count=2)"),
35 ("3", "PlacementSpec(count=3)"),
36 ("host1 host2", "PlacementSpec(hosts=[HostPlacementSpec(hostname='host1', network='', name=''), HostPlacementSpec(hostname='host2', network='', name='')])"),
37 ("host1;host2", "PlacementSpec(hosts=[HostPlacementSpec(hostname='host1', network='', name=''), HostPlacementSpec(hostname='host2', network='', name='')])"),
38 ("host1,host2", "PlacementSpec(hosts=[HostPlacementSpec(hostname='host1', network='', name=''), HostPlacementSpec(hostname='host2', network='', name='')])"),
39 ("host1 host2=b", "PlacementSpec(hosts=[HostPlacementSpec(hostname='host1', network='', name=''), HostPlacementSpec(hostname='host2', network='', name='b')])"),
40 ("host1=a host2=b", "PlacementSpec(hosts=[HostPlacementSpec(hostname='host1', network='', name='a'), HostPlacementSpec(hostname='host2', network='', name='b')])"),
41 ("host1:1.2.3.4=a host2:1.2.3.5=b", "PlacementSpec(hosts=[HostPlacementSpec(hostname='host1', network='1.2.3.4', name='a'), HostPlacementSpec(hostname='host2', network='1.2.3.5', name='b')])"),
42 ("myhost:[v1:10.1.1.10:6789]", "PlacementSpec(hosts=[HostPlacementSpec(hostname='myhost', network='[v1:10.1.1.10:6789]', name='')])"),
43 ('2 host1 host2', "PlacementSpec(count=2, hosts=[HostPlacementSpec(hostname='host1', network='', name=''), HostPlacementSpec(hostname='host2', network='', name='')])"),
44 ('label:foo', "PlacementSpec(label='foo')"),
45 ('3 label:foo', "PlacementSpec(count=3, label='foo')"),
46 ('*', "PlacementSpec(host_pattern='*')"),
47 ('3 data[1-3]', "PlacementSpec(count=3, host_pattern='data[1-3]')"),
48 ('3 data?', "PlacementSpec(count=3, host_pattern='data?')"),
49 ('3 data*', "PlacementSpec(count=3, host_pattern='data*')"),
51 def test_parse_placement_specs(test_input
, expected
):
52 ret
= PlacementSpec
.from_string(test_input
)
53 assert str(ret
) == expected
55 @pytest.mark
.parametrize(
59 ("host=a label:wrong"),
63 def test_parse_placement_specs_raises(test_input
):
64 with pytest
.raises(ServiceSpecValidationError
):
65 PlacementSpec
.from_string(test_input
)
67 @pytest.mark
.parametrize("test_input",
69 [("myhost:1.1.1.1/24"),
73 def test_parse_host_placement_specs_raises_wrong_format(test_input
):
74 with pytest
.raises(ValueError):
75 HostPlacementSpec
.parse(test_input
)
78 def _get_dict_spec(s_type
, s_id
):
81 "service_type": s_type
,
83 dict(hosts
=["host1:1.1.1.1"])
86 dict_spec
['pool'] = 'pool'
87 elif s_type
== 'iscsi':
88 dict_spec
['pool'] = 'pool'
89 dict_spec
['api_user'] = 'api_user'
90 dict_spec
['api_password'] = 'api_password'
98 dict_spec
['rgw_realm'] = 'realm'
99 dict_spec
['rgw_zone'] = 'zone'
104 @pytest.mark
.parametrize(
105 "s_type,o_spec,s_id",
107 ("mgr", ServiceSpec
, 'test'),
108 ("mon", ServiceSpec
, 'test'),
109 ("mds", ServiceSpec
, 'test'),
110 ("rgw", RGWSpec
, 'realm.zone'),
111 ("nfs", NFSServiceSpec
, 'test'),
112 ("iscsi", IscsiServiceSpec
, 'test'),
113 ("osd", DriveGroupSpec
, 'test'),
115 def test_servicespec_map_test(s_type
, o_spec
, s_id
):
116 spec
= ServiceSpec
.from_json(_get_dict_spec(s_type
, s_id
))
117 assert isinstance(spec
, o_spec
)
118 assert isinstance(spec
.placement
, PlacementSpec
)
119 assert isinstance(spec
.placement
.hosts
[0], HostPlacementSpec
)
120 assert spec
.placement
.hosts
[0].hostname
== 'host1'
121 assert spec
.placement
.hosts
[0].network
== '1.1.1.1'
122 assert spec
.placement
.hosts
[0].name
== ''
123 assert spec
.validate() is None
124 ServiceSpec
.from_json(spec
.to_json())
128 y
= """service_type: crash
140 service_id: default-rgw-realm.eu-central-1.1
141 service_name: rgw.default-rgw-realm.eu-central-1.1
148 rgw_realm: default-rgw-realm
149 rgw_zone: eu-central-1
153 service_id: osd_spec_default
154 service_name: osd.osd_spec_default
163 objectstore: bluestore
168 for y
in y
.split('---\n'):
169 data
= yaml
.safe_load(y
)
170 object = ServiceSpec
.from_json(data
)
172 assert yaml
.dump(object) == y
173 assert yaml
.dump(ServiceSpec
.from_json(object.to_json())) == y
175 @pytest.mark
.parametrize("spec1, spec2, eq",
196 # Add service_type='mgr'
231 def test_spec_hash_eq(spec1
: ServiceSpec
,
235 assert (spec1
== spec2
) is eq
237 @pytest.mark
.parametrize(
238 "s_type,s_id,s_name",
240 ('mgr', 's_id', 'mgr'),
241 ('mon', 's_id', 'mon'),
242 ('mds', 's_id', 'mds.s_id'),
243 ('rgw', 's_id', 'rgw.s_id'),
244 ('nfs', 's_id', 'nfs.s_id'),
245 ('iscsi', 's_id', 'iscsi.s_id'),
246 ('osd', 's_id', 'osd.s_id'),
248 def test_service_name(s_type
, s_id
, s_name
):
249 spec
= ServiceSpec
.from_json(_get_dict_spec(s_type
, s_id
))
251 assert spec
.service_name() == s_name