summaryrefslogtreecommitdiffstats
path: root/docs/release/installation/requirements.rst
blob: 9aefa21d1a25a18644903be994033bf812617ceb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
Setup Requirements
==================

Jump Host Requirements
---------------------

The Jump Host requirements are outlined below:

1.     CentOS 7 (from ISO or self-installed).

2.     Root access.

3.     libvirt virtualization support.

4.     minimum 1 networks and maximum 5 networks, multiple NIC and/or VLAN
       combinations are supported.  This is virtualized for a VM deployment.

5.     The Fraser Apex RPMs and their dependencies.

6.     16 GB of RAM for a bare metal deployment, 64 GB of RAM for a Virtual
       Deployment.

Network Requirements
--------------------

Network requirements include:

1.     No DHCP or TFTP server running on networks used by OPNFV.

2.     1-5 separate networks with connectivity between Jump Host and nodes.

       -  Control Plane (Provisioning)

       -  Private Tenant-Networking Network*

       -  External Network*

       -  Storage Network*

       -  Internal API Network* (required for IPv6 \*\*)

3.     Lights out OOB network access from Jump Host with IPMI node enabled
       (bare metal deployment only).

4.     External network is a routable network from outside the cloud,
       deployment. The External network is where public internet access would
       reside if available.

\*These networks can be combined with each other or all combined on the
Control Plane network.

\*\*Internal API network, by default, is collapsed with provisioning in IPv4
deployments, this is not possible with the current lack of PXE boot
support and therefore the API network is required to be its own
network in an IPv6 deployment.

Bare Metal Node Requirements
----------------------------

Bare metal nodes require:

1.     IPMI enabled on OOB interface for power control.

2.     BIOS boot priority should be PXE first then local hard disk.

3.     BIOS PXE interface should include Control Plane network mentioned above.

Execution Requirements (Bare Metal Only)
----------------------------------------

In order to execute a deployment, one must gather the following information:

1.     IPMI IP addresses for the nodes.

2.     IPMI login information for the nodes (user/pass).

3.     MAC address of Control Plane / Provisioning interfaces of the overcloud
       nodes.
ibution, and is available at # http://www.apache.org/licenses/LICENSE-2.0 ############################################################################## # Unittest for yardstick.benchmark.scenarios.compute.cyclictest.Cyclictest from __future__ import absolute_import import unittest import mock from oslo_serialization import jsonutils from yardstick.benchmark.scenarios.compute import cyclictest @mock.patch('yardstick.benchmark.scenarios.compute.cyclictest.ssh') class CyclictestTestCase(unittest.TestCase): def setUp(self): self.scenario_cfg = { "host": "kvm.LF", "setup_options": { "rpm_dir": "/opt/rpm", "host_setup_seqs": [ "host-setup0.sh", "host-setup1.sh", "host-run-qemu.sh" ], "script_dir": "/opt/scripts", "image_dir": "/opt/image", "guest_setup_seqs": [ "guest-setup0.sh", "guest-setup1.sh" ] }, "sla": { "action": "monitor", "max_min_latency": 50, "max_avg_latency": 100, "max_max_latency": 1000 }, "options": { "priority": 99, "threads": 1, "loops": 1000, "affinity": 1, "interval": 1000, "histogram": 90 } } self.context_cfg = { "host": { "ip": "10.229.43.154", "key_filename": "/yardstick/resources/files/yardstick_key", "role": "BareMetal", "name": "kvm.LF", "user": "root" } } def test_cyclictest_successful_setup(self, mock_ssh): c = cyclictest.Cyclictest(self.scenario_cfg, self.context_cfg) mock_ssh.SSH.from_node().execute.return_value = (0, '', '') c.setup() self.assertIsNotNone(c.guest) self.assertIsNotNone(c.host) self.assertEqual(c.setup_done, True) def test_cyclictest_successful_no_sla(self, mock_ssh): result = {} self.scenario_cfg.pop("sla", None) c = cyclictest.Cyclictest(self.scenario_cfg, self.context_cfg) mock_ssh.SSH.from_node().execute.return_value = (0, '', '') c.setup() c.guest = mock_ssh.SSH.from_node() sample_output = '{"min": 100, "avg": 500, "max": 1000}' mock_ssh.SSH.from_node().execute.return_value = (0, sample_output, '') c.run(result) expected_result = jsonutils.loads(sample_output) self.assertEqual(result, expected_result) def test_cyclictest_successful_sla(self, mock_ssh): result = {} self.scenario_cfg.update({"sla": { "action": "monitor", "max_min_latency": 100, "max_avg_latency": 500, "max_max_latency": 1000 } }) c = cyclictest.Cyclictest(self.scenario_cfg, self.context_cfg) mock_ssh.SSH.from_node().execute.return_value = (0, '', '') c.setup() c.guest = mock_ssh.SSH.from_node() sample_output = '{"min": 100, "avg": 500, "max": 1000}' mock_ssh.SSH.from_node().execute.return_value = (0, sample_output, '') c.run(result) expected_result = jsonutils.loads(sample_output) self.assertEqual(result, expected_result) def test_cyclictest_unsuccessful_sla_min_latency(self, mock_ssh): result = {} self.scenario_cfg.update({"sla": {"max_min_latency": 10}}) c = cyclictest.Cyclictest(self.scenario_cfg, self.context_cfg) mock_ssh.SSH.from_node().execute.return_value = (0, '', '') c.setup() c.guest = mock_ssh.SSH.from_node() sample_output = '{"min": 100, "avg": 500, "max": 1000}' mock_ssh.SSH.from_node().execute.return_value = (0, sample_output, '') self.assertRaises(AssertionError, c.run, result) def test_cyclictest_unsuccessful_sla_avg_latency(self, mock_ssh): result = {} self.scenario_cfg.update({"sla": {"max_avg_latency": 10}}) c = cyclictest.Cyclictest(self.scenario_cfg, self.context_cfg) mock_ssh.SSH.from_node().execute.return_value = (0, '', '') c.setup() c.guest = mock_ssh.SSH.from_node() sample_output = '{"min": 100, "avg": 500, "max": 1000}' mock_ssh.SSH.from_node().execute.return_value = (0, sample_output, '') self.assertRaises(AssertionError, c.run, result) def test_cyclictest_unsuccessful_sla_max_latency(self, mock_ssh): result = {} self.scenario_cfg.update({"sla": {"max_max_latency": 10}}) c = cyclictest.Cyclictest(self.scenario_cfg, self.context_cfg) mock_ssh.SSH.from_node().execute.return_value = (0, '', '') c.setup() c.guest = mock_ssh.SSH.from_node() sample_output = '{"min": 100, "avg": 500, "max": 1000}' mock_ssh.SSH.from_node().execute.return_value = (0, sample_output, '') self.assertRaises(AssertionError, c.run, result) def test_cyclictest_unsuccessful_script_error(self, mock_ssh): result = {} self.scenario_cfg.update({"sla": {"max_max_latency": 10}}) c = cyclictest.Cyclictest(self.scenario_cfg, self.context_cfg) mock_ssh.SSH.from_node().execute.return_value = (0, '', '') c.setup() c.guest = mock_ssh.SSH.from_node() mock_ssh.SSH.from_node().execute.return_value = (1, '', 'FOOBAR') self.assertRaises(RuntimeError, c.run, result) def main(): unittest.main() if __name__ == '__main__': main()