commit | 85855e8445109a2f56014223cb7e6cb814cd4288 | [log] [tgz] |
---|---|---|
author | Matt Jeanneret <mj3580@att.com> | Tue Jan 29 16:01:36 2019 -0500 |
committer | Matt Jeanneret <mj3580@att.com> | Tue Jan 29 22:20:31 2019 +0000 |
tree | 721e3384a00dfc8611af22b032811c7164310bbc | |
parent | 9be9fd476427d60d325899cbab7c09c1eeba9b92 [diff] |
BUGFIX: Disable mib resync and mds check allowing onu disable/enable to work For certain onu there is always a mib mismatch (MDS value) between whats stored in the mib db and whats configured on the onu. This results in numerous reattempts at resyncing the mib. In cases were Volatile mib storage is used this also prevent an onu from being re-enabled. Long term need to discover why certain onu me, namely vlan_tagging_operation_table cannot be synced properly. Change-Id: I8e324cec7540a9a4e12b0cb18b28f93e317f8d65
Voltha aims to provide a layer of abstraction on top of legacy and next generation access network equipment for the purpose of control and management. Its initial focus is on PON (GPON, EPON, NG PON 2), but it aims to go beyond to eventually cover other access technologies (xDSL, Docsis, G.FAST, dedicated Ethernet, fixed wireless).
Key concepts of Voltha:
Control and management in the access network space is a mess. Each access technology brings its own bag of protocols, and on top of that vendors have their own interpretation/extension of the same standards. Compounding the problem is that these vendor- and technology specific differences ooze way up into the centralized OSS systems of the service provider, creating a lot of inefficiencies.
Ideally, all vendor equipment for the same access technology should provide an identical interface for control and management. Moreover, there shall be much higher synergies across technologies. While we wait for vendors to unite, Voltha provides an increment to that direction, by confining the differences to the locality of access and hiding them from the upper layers of the OSS stack.
While we are still at the early phase of development, you can check out the BUILD.md file to see how you can build it, run it, test it, etc.
Contributions, small and large, are welcome. Minor contributions and bug fixes are always welcome in form of pull requests. For larger work, the best is to check in with the existing developers to see where help is most needed and to make sure your solution is compatible with the general philosophy of Voltha.
To begin, make sure to have a development environement installed according to the OpenCord WIKI. Next, In a shell environment
source env.sh; # Source the environment Settings and create a virtual environment make utest-with-coverage; # Execute the Unit Test with coverage reporting
New unit tests for the core can be written in the nosetest framework and can be found under /tests/utest/
Each adapter's unit tests are discovered by the presence of a test.mk submake file underneath the adapter's directory. for example)
# voltha/adapters/my_new_adapter/test.mk .PHONY test test: @echo "Testing my amazing new adapter" @./my_test_harness
Voltha's test framework will execute the FIRST Target in the submake file as the unit test function. It may include as many dependencies as needed, such as using a different python framework for testing (pytest, unittest, tox) or even alternate languages (go, rust, php).
In order for you adapter's test-coverage to be reported, make sure that your test_harness creates a coverage report in a junit xml format. Most test harnesses can easily produce this report format. The Jenkins Job will pick up your coverage report file if named appropriately junit-report.xml according to the Jenkins configuration.