Skip to content
Snippets Groups Projects
README.md 2.45 KiB
Newer Older
Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
# Mock MicroWave SDN Controller

This REST server implements very basic support for the following YANG data models:
- IETF YANG data model for Network Topology
  - Ref: https://www.rfc-editor.org/rfc/rfc8345.html
- IETF YANG data model for Transport Network Client Signals
  - Ref: https://www.ietf.org/archive/id/draft-ietf-ccamp-client-signal-yang-07.html

The aim of this server is to enable testing the MicroWaveDeviceDriver and the MicroWaveServiceHandler.
Follow the steps below to perform the test:

## 1. Deploy TeraFlowSDN controller and the scenario
Deploy the test scenario "microwave_deploy.sh":
```bash
source src/tests/tools/mock_mw_sdn_ctrl/scenario/microwave_deploy.sh
./deploy/all.sh
Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
```

## 2. Install requirements and run the Mock MicroWave SDN controller
__NOTE__: if you run the Mock MicroWave SDN controller from the PyEnv used for developping on the TeraFlowSDN framework,
all the requirements are already in place. Install them only if you execute it in a separate/standalone environment.

Install the required dependencies as follows:
```bash
pip install Flask==2.1.3 Flask-RESTful==0.3.9
```

Run the Mock MicroWave SDN Controller as follows:
```bash
python src/tests/tools/mock_mw_sdn_ctrl/MockMWSdnCtrl.py
Lluis Gifre Renom's avatar
Lluis Gifre Renom committed
```

## 3. Deploy the test descriptors
Edit the descriptors to meet your environment specifications.
Edit "network_descriptors.json" and change IP address and port of the MicroWave SDN controller of the "MW" device.
- Set value of config rule "_connect/address" to the address of the host where the Mock MicroWave SDN controller is
  running (default="192.168.1.1").
- Set value of config rule "_connect/port" to the port where your Mock MicroWave SDN controller is listening on
  (default="8443").

Upload the "network_descriptors.json" through the TeraFlowSDN WebUI.
- If not already selected, select context "admin".
- Check that a network topology with 4 routers + 1 microwave radio system are loaded. They should form 2 rings.

Upload the "service_descriptor.json" through the TeraFlowSDN WebUI.
- Check that 2 services have been created.
- The "mw-svc" should have a connection and be supported by a sub-service.
- The sub-service should also have a connection.
- The R1, R3, and MW devices should have configuration rules established.

# 4. Delete the microwave service
Find the "mw-svc" on the WebUI, navigate to its details, and delete the service pressing the "Delete Service" button.
The service, sub-service, and device configuration rules should be removed.