topology


Nametopology JSON
Version 1.19.1 PyPI version JSON
download
home_pagehttp://topology.rtfd.org/
SummaryTopology is a framework for building and testing network topologies, with support for pytest.
upload_time2024-11-05 21:22:44
maintainerNone
docs_urlNone
authorHewlett Packard Enterprise Development LP
requires_python>=3.6
licenseNone
keywords topology
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            ==================
Topology Framework
==================

Framework for building and testing network topologies, with support for pytest.


Documentation
=============

    https://topology.readthedocs.io/


License
=======

.. code-block:: text

   Copyright (C) 2015-2023 Hewlett Packard Enterprise Development LP

   Licensed under the Apache License, Version 2.0 (the "License");
   you may not use this file except in compliance with the License.
   You may obtain a copy of the License at

       http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing,
   software distributed under the License is distributed on an
   "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
   KIND, either express or implied.  See the License for the
   specific language governing permissions and limitations
   under the License.


Changelog
=========

1.19.0 (2024-10-23)
-------------------

Changes
~~~~~~~

- Add a step before build to resolve the topology graph. This additional step
  allows the user to take decisions before trying to build the topology and
  figuring out it is not possible too late.

- Add "platform" property so users can access the platform instance from the
  topology manager.

1.18.3 (2024-06-25)
-------------------

Fix
~~~

- Move argparse type from 'int' to int.

  In latest version of pytest, the 'int' value as type is
  no longer supported, causing issues when topology is
  started.

1.18.2 (2023-06-15)
-------------------

Fixes
~~~~~
- 'topology' executable was broken and could not be called. Fixed.


1.18.1 (2022-10-31)
-------------------

Fixes
~~~~~
- Using topology as module did not inject attributes appropriately. Now it uses
  the topology file path as top search-path.


1.18.0 (2022-08-39)
-------------------

Changes
~~~~~~~
- Add support for subnode. Subnodes can be specified using the ``node>subnode``
  syntax and they can be nested as well. Ports can be specified for any node
  and links can be specified between any pair of nodes regardless the nesting
  level, for example: ``node>subnode1>subnode2:p1 -- node:p1``.

- Replace NMLExtendedManager by a new TopologyGraph class and other classes
  for Node, Link and Port. TopologyGraph has the same API as the old
  NMLExtendedManager, thus backwards compatibility is preserved.

- Drop support for NML and graphviz plot output which implies these pytest
  plugin flags and CLI arguments now do nothing. Notice they might be removed
  in a future release:

  - --topology-nml-dir
  - --topology-plot-dir
  - --topology-plot-format


1.17.0 (2022-01-25)
-------------------

Changes
~~~~~~~
- pytest flag ``--topology-platform-options`` now uses the ExtendAction to
  allowing extending and overriding options in CLI. [Francisco Mata]


1.16.0 (2021-05-11)
-------------------

New
~~~
- Add pytest option ``--topology-szn-dir``. [Jose Martinez]

  This new option will allow to pass the path of a directory where topologies
  files ``*.szn`` will be defined.


1.15.0 (2021-03-03)
-------------------

New
~~~
- Add pytest option ``--topology-build-retries``. [David Diaz]

  Allow for unstable backends to try topology build more than once.


1.14.0 (2021-01-06)
-------------------

Changes
~~~~~~~
- Call topology rollback on keyboardInterrupt during build. [David Diaz]


1.13.0 (2020-08-05)
-------------------

New
~~~
- Ignore the same paths pytest ignores. [David Diaz]

  When running topology via the pytest plugin, ignore the same paths pytest
  does by using norecursedirs ini option.

  Also move topology plugin configuration to sessionstart as logs on pytest are
  live only after that point.


1.12.0 (2020-06-05)
-------------------

Changes
~~~~~~~
- Use realpath for pytest plugin search paths. [David Diaz]

  Starting on pytest 3.9.2 pytest resolves symbolic links:

  https://github.com/pytest-dev/pytest/pull/4108/

  This causes an incompatibility with the attribute injection feature as the
  paths pytest sees (realpaths) differ from the injected_attr (abspath) found
  on the topology_plugin.


1.11.0 (2020-03-16)
-------------------

Changes
~~~~~~~
- Set a meaningful identifier for NML bilinks. [David Diaz]

  Currently the bilinks ID is the Python instance ID, this commit set it to a
  combination of the port IDs using the same syntax as pyszn:

     ``node0:port0 -- node1:port1``


1.10.0 (2020-01-28)
-------------------

New
~~~
- Platform arguments can now be passed from the CLI and/or the Pytest plugin.
  Use ``--option key=value`` in the CLI and
  ``--topology-platform-option key=value`` in Pytest. Options given using
  this method will be passed as keyword arguments to the platform. Values will
  be "autoparsed" to a Python type using the following order: floats, integers,
  booleans  (yes, no, true, false, case insensitive) and finally any other is
  considered a strings. [Carlos Jenkins & David Diaz]


1.9.15 (2019-11-18)
-------------------

Changes
~~~~~~~
- Removed long ago deprecated module topology.platforms.base [Carlos Jenkins]

    Change imports:

    - topology.platforms.base.BasePlatform => topology.platforms.platform.BasePlatform
    - topology.platforms.base.BaseNode => topology.platforms.node.BaseNode
    - topology.platforms.base.CommonNode => topology.platforms.node.CommonNode

- Update BaseShell __call__ and execute to pass args and kwargs to the wrapped
  call to send_command() (#76) [Sergio Morales]
- Changes to support newer versions of pytest. (#79) [Diego Dompe]
- Drop support for Python 3.4. Minimal version is now 3.5. [Carlos Jenkins]

Fix
~~~
- Topology shells will now use pexpect poll() to support more than 1024 file
  descriptors. This change requires pexpect >= 4.6. [Carlos Jenkins]


1.9.14 (2018-11-21)
-------------------

Changes
~~~~~~~
- Make new testlog func private. [Matthew Hall]


1.9.13 (2018-11-16)
-------------------

New
~~~
- Environment attributes are now passed to the NMLManager. [Javier
  Peralta]
- Add functions for new test specific log. [Matthew Hall]

Changes
~~~~~~~
- Remove unit test of functionalty no longer on topology. [Javier
  Peralta]
- Moving injection to pyszn. [Diego Hurtado]
- Customize term codes regex. [David Diaz]

  Add the ability to customize the terminal regex code for special shells

Fix
~~~
- Pyszn uses correct depedency declaration. [Javier Peralta]
- Minor fixes. [David Diaz]


1.9.12 (2018-06-05)
-------------------

New
~~~
- Add a dynamic timeout option. [Matthew Hall]

  When this option is used expect will be repeated as long as output is
  still being returned.

Changes
~~~~~~~
- Add FORCED_PROMPT to the initial prompt. [Joseph Loaiza]

  The original initial prompt does not match the FORCED_PROMPT, this makes the
  shell to throw a timeout exception when trying to reconnect to a previously
  used shell.

Fix
~~~
- Adding missing release information. [Diego Hurtado]
- Updating to new PEP8 requirements. [Diego Hurtado]


1.9.11 (2017-11-20)
-------------------

Changes
~~~~~~~
- Modify pexpect logger to match actual data stream. [Javier Peralta]

  This change adds a new filehandler that doesn't introduce line changes
  arbitrarily. Also Add some line changes on known places to keep output
  log file readable. With this changes the log file should match
  pexpect's command output stream closer.


1.9.10 (2017-09-06)
-------------------

Changes
~~~~~~~
- Extending connection and disconnection arguments. [Diego Hurtado]

Fix
~~~
- Refactoring _get_connection. [Diego Hurtado]
- Removing support for Python 2.7. [Diego Hurtado]
- Several fixes in the usage of the connection argument. [Diego Hurtado]

  This intentionally breaks compatibility with Python 2.7 since it uses
  syntax introduced in PEP 3102.

- Increase echo sleep 1 second. [Javier Peralta]


1.9.9 (2017-07-26)
------------------

New
~~~
- Adding support for sending control characters. [Diego Hurtado]

Fix
~~~
- Increased delay_after_echo_off a bit. [Javier Peralta]


1.9.8 (2017-06-13)
------------------

Changes
~~~~~~~
- Log python error when plugin load fails. [Javier Peralta]


1.9.7 (2017-05-16)
------------------

Fix
~~~
- Adding a delay after setting echo off. [Javier Peralta]

  Command to set prompt was sometimes too fast and were sent before bash turned
  off echo (stty -echo) resulting in unwanted information being displayed. This
  commit makes sure bash always have time to turn echo off.


1.9.6 (2017-05-03)
------------------

New
~~~
- Adding reason to ``platform_incompatible`` marker.
- Adding timestamps to logs.

Changes
~~~~~~~
- Adding workaround for bug in mock.
- Using ``python3`` as base Python.


1.9.5 (2017-01-06)
------------------

Fix
~~~
- Calling missing ``super``.


1.9.4 (2016-12-13)
------------------

Fix
~~~
- Fixing typo in README.


1.9.3 (2016-12-09)
------------------

Fix
~~~
- Making ``StepLogger`` backwards compatible.


1.9.2 (2016-12-01)
------------------

Fix
~~~
- Fixing broken ``step`` logger.
- Fixing the ``test_id`` marker to make it work with Pytest > 3.0.0.


1.9.1 (2016-11-23)
------------------

Fix
~~~
- Removing fixed dependencies.


1.9.0 (2016-11-10)
------------------

New
~~~
- Adding logging functionality.

Fix
~~~
- Fixing the shells connect process.
- Handling calls to ``decode`` safely.


1.8.1 (2016-09-22)
------------------

Fix
~~~
- Removed internal imports of deprecated modules.


1.8.0 (2016-08-26)
------------------

New
~~~
- A new ServicesAPI for the nodes is now available. This new API allows to
  register and later on fetch information about the services a node provides.
- Greatly improved documentation for the Shell Low Level API introduced in
  1.4.0. Check "The low-level shell API" in User Guide.
- The Low Level Shell API will now be able to log user commands. This new
  feature is backward compatible.

Changes
~~~~~~~
- Module ``topology.platforms.base`` is now deprecated. Please change your
  imports to:

  ::

      topology.platforms.base.BasePlatform => topology.platforms.platform.BasePlatform
      topology.platforms.base.BaseNode     => topology.platforms.node.BaseNode
      topology.platforms.base.CommonNode   => topology.platforms.node.CommonNode


1.7.2 (2016-06-09)
------------------

Changes
~~~~~~~
- Adding ``user`` as an option for ``PExpectShell`` to support shells that use
  this kind of authentication.

Fix
~~~
- Raising the proper exception when a shell connection fails for the user to
  handle it properly.


1.7.1 (2016-05-26)
------------------

Changes
~~~~~~~
- Removing the version requirement of Pexpect since this may cause version
  collisions with other Python packages commonly used with the framework.


1.7.0 (2016-05-26)
------------------

New
~~~
- The reference documentation for the *vtysh*, *ping* and *ip* communication
  libraries has been added to the documentation.
- PExpect shells now support multiple connections. This means that the same
  shell object can now use several ``pexpect`` ``spawn`` objects.

Changes
~~~~~~~
- The documentation for *communication libraries* has been improved a lot with
  specific examples for common use cases added.
- The ``pexpect`` ``spawn`` arguments are now reachable from the initialization
  of a shell object.
- The attribute injection feature is now capable of following symbolic links
  while walking through directory paths.
- The version of all dependencies has been fixed. This is to avoid unexpected
  code breaks when a bug is introduced in one of them.

Fix
~~~
- The base node class ``BaseNode`` now includes a ``ports`` attribute. This has
  been used by all platform engine nodes so far, but was missing in their base
  class.
- A missing history file does not raise an error whene executing ``topology``,
  but is just logged as an error.
- A few CSS and other theme issues have been fixed.


1.6.0 (2016-03-21)
------------------

Changes
~~~~~~~
- When expanding the search path for attribute injection all hidden folders
  (starting with '.') will now be ignored.
- When processing files that matched the search path for attribute injection
  all files that have ill formed / unparseable SZN strings will be logged as
  error and skipped instead of raising an exception.
- When processing files that matched the search path for attribute injection
  all ``.py``'s that doesn't possess a ``TOPOLOGY`` variable will now be warned
  and skipped instead of raising an exception.

Fix
~~~
- Fixed attribute injection crashing when a SZN file is in the node expansion
  search path.
- Fixed rollback routine not being triggered when an non ``Exception`` subclass
  is raised.


1.5.0 (2016-03-02)
------------------

New
~~~
- New ``topology.platforms.shell.PExpectBashShell`` class that allows to easily
  setup shells that uses bash.

Fix
~~~
- Fixed small identation bug that caused the function ``get_shell()`` in the
  node API to return always ``None``.


1.4.0 (2016-03-01)
------------------

New
~~~
- New low level shell API that allows to define a common behavior for all low
  level shell manipulation. This API is implemented by the
  ``topology.platforms.shell`` module.
- Two new high level API methods for accesing the low level shell API::

      myshell = mynode.get_shell('python')
      response = myshell.execute('1 + 1')

  Or using a context manager::

      with mynode.use_shell('python') as python:
          # This context manager sets the default shell to 'python'
          mynode('from os import getcwd')
          cwd = mynode('print(getcwd())')

          # Access to the low-level shell API
          python.send_command('foo = (', matches=['... '])

Changes
~~~~~~~
- The shell used to execute a command will now be logged.


1.3.0 (2016-02-17)
------------------

Changes
~~~~~~~
- Attribute injection will now try to match files on any subfolder of the
  search paths and not only on the search paths themselves.

Fix
~~~
- Fixed critical bug in injection attribute not considering matches in some
  cases.


1.2.0 (2016-02-13)
------------------

New
~~~
- Added new API for the topology nodes that allow to set the default shell.
  For example, you may now use ``mynode.default_shell = 'bash'``.
- Documentation for the *Attribute Injection* feature was added.
- Improvements for file matching in attribute injection files. Now, if using
  pytest, all test folders passed as arguments will be used as search paths for
  relative files specified in the attribute injection file. With this, it is no
  longer required to use an absolute path, and this practice becomes deprecated.

Fix
~~~
- Fixed a bug in attribute injection when using ``attribute=value`` as node
  identifier that caused all nodes with the attribute to use that value.


1.1.0 (2016-01-26)
------------------

New
~~~
- Added a common ``stateprovider`` decorator to ``topology.libraries.utils``
  that allows to easily inject state to an enode in a Communication library.
- Added a common ``NodeLoader`` class to ``topology.platforms.utils`` that
  allows a Platform Engine to find a load nodes for it's platform.


1.0.1 (2016-01-22)
------------------

Fix
~~~
- Fixed fatal bug when running a single node topology without ports.
- Fixed new PEP8 checks on the codebase.


1.0.0 (2016-01-05)
------------------

New
~~~
- Initial public release.

            

Raw data

            {
    "_id": null,
    "home_page": "http://topology.rtfd.org/",
    "name": "topology",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.6",
    "maintainer_email": null,
    "keywords": "topology",
    "author": "Hewlett Packard Enterprise Development LP",
    "author_email": "hpe-networking@lists.hp.com",
    "download_url": "https://files.pythonhosted.org/packages/79/32/0d3051fa42801dc3dfb408a6738e7240053c4c936c1eb8f0281a3c14e373/topology-1.19.1.tar.gz",
    "platform": null,
    "description": "==================\nTopology Framework\n==================\n\nFramework for building and testing network topologies, with support for pytest.\n\n\nDocumentation\n=============\n\n    https://topology.readthedocs.io/\n\n\nLicense\n=======\n\n.. code-block:: text\n\n   Copyright (C) 2015-2023 Hewlett Packard Enterprise Development LP\n\n   Licensed under the Apache License, Version 2.0 (the \"License\");\n   you may not use this file except in compliance with the License.\n   You may obtain a copy of the License at\n\n       http://www.apache.org/licenses/LICENSE-2.0\n\n   Unless required by applicable law or agreed to in writing,\n   software distributed under the License is distributed on an\n   \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n   KIND, either express or implied.  See the License for the\n   specific language governing permissions and limitations\n   under the License.\n\n\nChangelog\n=========\n\n1.19.0 (2024-10-23)\n-------------------\n\nChanges\n~~~~~~~\n\n- Add a step before build to resolve the topology graph. This additional step\n  allows the user to take decisions before trying to build the topology and\n  figuring out it is not possible too late.\n\n- Add \"platform\" property so users can access the platform instance from the\n  topology manager.\n\n1.18.3 (2024-06-25)\n-------------------\n\nFix\n~~~\n\n- Move argparse type from 'int' to int.\n\n  In latest version of pytest, the 'int' value as type is\n  no longer supported, causing issues when topology is\n  started.\n\n1.18.2 (2023-06-15)\n-------------------\n\nFixes\n~~~~~\n- 'topology' executable was broken and could not be called. Fixed.\n\n\n1.18.1 (2022-10-31)\n-------------------\n\nFixes\n~~~~~\n- Using topology as module did not inject attributes appropriately. Now it uses\n  the topology file path as top search-path.\n\n\n1.18.0 (2022-08-39)\n-------------------\n\nChanges\n~~~~~~~\n- Add support for subnode. Subnodes can be specified using the ``node>subnode``\n  syntax and they can be nested as well. Ports can be specified for any node\n  and links can be specified between any pair of nodes regardless the nesting\n  level, for example: ``node>subnode1>subnode2:p1 -- node:p1``.\n\n- Replace NMLExtendedManager by a new TopologyGraph class and other classes\n  for Node, Link and Port. TopologyGraph has the same API as the old\n  NMLExtendedManager, thus backwards compatibility is preserved.\n\n- Drop support for NML and graphviz plot output which implies these pytest\n  plugin flags and CLI arguments now do nothing. Notice they might be removed\n  in a future release:\n\n  - --topology-nml-dir\n  - --topology-plot-dir\n  - --topology-plot-format\n\n\n1.17.0 (2022-01-25)\n-------------------\n\nChanges\n~~~~~~~\n- pytest flag ``--topology-platform-options`` now uses the ExtendAction to\n  allowing extending and overriding options in CLI. [Francisco Mata]\n\n\n1.16.0 (2021-05-11)\n-------------------\n\nNew\n~~~\n- Add pytest option ``--topology-szn-dir``. [Jose Martinez]\n\n  This new option will allow to pass the path of a directory where topologies\n  files ``*.szn`` will be defined.\n\n\n1.15.0 (2021-03-03)\n-------------------\n\nNew\n~~~\n- Add pytest option ``--topology-build-retries``. [David Diaz]\n\n  Allow for unstable backends to try topology build more than once.\n\n\n1.14.0 (2021-01-06)\n-------------------\n\nChanges\n~~~~~~~\n- Call topology rollback on keyboardInterrupt during build. [David Diaz]\n\n\n1.13.0 (2020-08-05)\n-------------------\n\nNew\n~~~\n- Ignore the same paths pytest ignores. [David Diaz]\n\n  When running topology via the pytest plugin, ignore the same paths pytest\n  does by using norecursedirs ini option.\n\n  Also move topology plugin configuration to sessionstart as logs on pytest are\n  live only after that point.\n\n\n1.12.0 (2020-06-05)\n-------------------\n\nChanges\n~~~~~~~\n- Use realpath for pytest plugin search paths. [David Diaz]\n\n  Starting on pytest 3.9.2 pytest resolves symbolic links:\n\n  https://github.com/pytest-dev/pytest/pull/4108/\n\n  This causes an incompatibility with the attribute injection feature as the\n  paths pytest sees (realpaths) differ from the injected_attr (abspath) found\n  on the topology_plugin.\n\n\n1.11.0 (2020-03-16)\n-------------------\n\nChanges\n~~~~~~~\n- Set a meaningful identifier for NML bilinks. [David Diaz]\n\n  Currently the bilinks ID is the Python instance ID, this commit set it to a\n  combination of the port IDs using the same syntax as pyszn:\n\n     ``node0:port0 -- node1:port1``\n\n\n1.10.0 (2020-01-28)\n-------------------\n\nNew\n~~~\n- Platform arguments can now be passed from the CLI and/or the Pytest plugin.\n  Use ``--option key=value`` in the CLI and\n  ``--topology-platform-option key=value`` in Pytest. Options given using\n  this method will be passed as keyword arguments to the platform. Values will\n  be \"autoparsed\" to a Python type using the following order: floats, integers,\n  booleans  (yes, no, true, false, case insensitive) and finally any other is\n  considered a strings. [Carlos Jenkins & David Diaz]\n\n\n1.9.15 (2019-11-18)\n-------------------\n\nChanges\n~~~~~~~\n- Removed long ago deprecated module topology.platforms.base [Carlos Jenkins]\n\n    Change imports:\n\n    - topology.platforms.base.BasePlatform => topology.platforms.platform.BasePlatform\n    - topology.platforms.base.BaseNode => topology.platforms.node.BaseNode\n    - topology.platforms.base.CommonNode => topology.platforms.node.CommonNode\n\n- Update BaseShell __call__ and execute to pass args and kwargs to the wrapped\n  call to send_command() (#76) [Sergio Morales]\n- Changes to support newer versions of pytest. (#79) [Diego Dompe]\n- Drop support for Python 3.4. Minimal version is now 3.5. [Carlos Jenkins]\n\nFix\n~~~\n- Topology shells will now use pexpect poll() to support more than 1024 file\n  descriptors. This change requires pexpect >= 4.6. [Carlos Jenkins]\n\n\n1.9.14 (2018-11-21)\n-------------------\n\nChanges\n~~~~~~~\n- Make new testlog func private. [Matthew Hall]\n\n\n1.9.13 (2018-11-16)\n-------------------\n\nNew\n~~~\n- Environment attributes are now passed to the NMLManager. [Javier\n  Peralta]\n- Add functions for new test specific log. [Matthew Hall]\n\nChanges\n~~~~~~~\n- Remove unit test of functionalty no longer on topology. [Javier\n  Peralta]\n- Moving injection to pyszn. [Diego Hurtado]\n- Customize term codes regex. [David Diaz]\n\n  Add the ability to customize the terminal regex code for special shells\n\nFix\n~~~\n- Pyszn uses correct depedency declaration. [Javier Peralta]\n- Minor fixes. [David Diaz]\n\n\n1.9.12 (2018-06-05)\n-------------------\n\nNew\n~~~\n- Add a dynamic timeout option. [Matthew Hall]\n\n  When this option is used expect will be repeated as long as output is\n  still being returned.\n\nChanges\n~~~~~~~\n- Add FORCED_PROMPT to the initial prompt. [Joseph Loaiza]\n\n  The original initial prompt does not match the FORCED_PROMPT, this makes the\n  shell to throw a timeout exception when trying to reconnect to a previously\n  used shell.\n\nFix\n~~~\n- Adding missing release information. [Diego Hurtado]\n- Updating to new PEP8 requirements. [Diego Hurtado]\n\n\n1.9.11 (2017-11-20)\n-------------------\n\nChanges\n~~~~~~~\n- Modify pexpect logger to match actual data stream. [Javier Peralta]\n\n  This change adds a new filehandler that doesn't introduce line changes\n  arbitrarily. Also Add some line changes on known places to keep output\n  log file readable. With this changes the log file should match\n  pexpect's command output stream closer.\n\n\n1.9.10 (2017-09-06)\n-------------------\n\nChanges\n~~~~~~~\n- Extending connection and disconnection arguments. [Diego Hurtado]\n\nFix\n~~~\n- Refactoring _get_connection. [Diego Hurtado]\n- Removing support for Python 2.7. [Diego Hurtado]\n- Several fixes in the usage of the connection argument. [Diego Hurtado]\n\n  This intentionally breaks compatibility with Python 2.7 since it uses\n  syntax introduced in PEP 3102.\n\n- Increase echo sleep 1 second. [Javier Peralta]\n\n\n1.9.9 (2017-07-26)\n------------------\n\nNew\n~~~\n- Adding support for sending control characters. [Diego Hurtado]\n\nFix\n~~~\n- Increased delay_after_echo_off a bit. [Javier Peralta]\n\n\n1.9.8 (2017-06-13)\n------------------\n\nChanges\n~~~~~~~\n- Log python error when plugin load fails. [Javier Peralta]\n\n\n1.9.7 (2017-05-16)\n------------------\n\nFix\n~~~\n- Adding a delay after setting echo off. [Javier Peralta]\n\n  Command to set prompt was sometimes too fast and were sent before bash turned\n  off echo (stty -echo) resulting in unwanted information being displayed. This\n  commit makes sure bash always have time to turn echo off.\n\n\n1.9.6 (2017-05-03)\n------------------\n\nNew\n~~~\n- Adding reason to ``platform_incompatible`` marker.\n- Adding timestamps to logs.\n\nChanges\n~~~~~~~\n- Adding workaround for bug in mock.\n- Using ``python3`` as base Python.\n\n\n1.9.5 (2017-01-06)\n------------------\n\nFix\n~~~\n- Calling missing ``super``.\n\n\n1.9.4 (2016-12-13)\n------------------\n\nFix\n~~~\n- Fixing typo in README.\n\n\n1.9.3 (2016-12-09)\n------------------\n\nFix\n~~~\n- Making ``StepLogger`` backwards compatible.\n\n\n1.9.2 (2016-12-01)\n------------------\n\nFix\n~~~\n- Fixing broken ``step`` logger.\n- Fixing the ``test_id`` marker to make it work with Pytest > 3.0.0.\n\n\n1.9.1 (2016-11-23)\n------------------\n\nFix\n~~~\n- Removing fixed dependencies.\n\n\n1.9.0 (2016-11-10)\n------------------\n\nNew\n~~~\n- Adding logging functionality.\n\nFix\n~~~\n- Fixing the shells connect process.\n- Handling calls to ``decode`` safely.\n\n\n1.8.1 (2016-09-22)\n------------------\n\nFix\n~~~\n- Removed internal imports of deprecated modules.\n\n\n1.8.0 (2016-08-26)\n------------------\n\nNew\n~~~\n- A new ServicesAPI for the nodes is now available. This new API allows to\n  register and later on fetch information about the services a node provides.\n- Greatly improved documentation for the Shell Low Level API introduced in\n  1.4.0. Check \"The low-level shell API\" in User Guide.\n- The Low Level Shell API will now be able to log user commands. This new\n  feature is backward compatible.\n\nChanges\n~~~~~~~\n- Module ``topology.platforms.base`` is now deprecated. Please change your\n  imports to:\n\n  ::\n\n      topology.platforms.base.BasePlatform => topology.platforms.platform.BasePlatform\n      topology.platforms.base.BaseNode     => topology.platforms.node.BaseNode\n      topology.platforms.base.CommonNode   => topology.platforms.node.CommonNode\n\n\n1.7.2 (2016-06-09)\n------------------\n\nChanges\n~~~~~~~\n- Adding ``user`` as an option for ``PExpectShell`` to support shells that use\n  this kind of authentication.\n\nFix\n~~~\n- Raising the proper exception when a shell connection fails for the user to\n  handle it properly.\n\n\n1.7.1 (2016-05-26)\n------------------\n\nChanges\n~~~~~~~\n- Removing the version requirement of Pexpect since this may cause version\n  collisions with other Python packages commonly used with the framework.\n\n\n1.7.0 (2016-05-26)\n------------------\n\nNew\n~~~\n- The reference documentation for the *vtysh*, *ping* and *ip* communication\n  libraries has been added to the documentation.\n- PExpect shells now support multiple connections. This means that the same\n  shell object can now use several ``pexpect`` ``spawn`` objects.\n\nChanges\n~~~~~~~\n- The documentation for *communication libraries* has been improved a lot with\n  specific examples for common use cases added.\n- The ``pexpect`` ``spawn`` arguments are now reachable from the initialization\n  of a shell object.\n- The attribute injection feature is now capable of following symbolic links\n  while walking through directory paths.\n- The version of all dependencies has been fixed. This is to avoid unexpected\n  code breaks when a bug is introduced in one of them.\n\nFix\n~~~\n- The base node class ``BaseNode`` now includes a ``ports`` attribute. This has\n  been used by all platform engine nodes so far, but was missing in their base\n  class.\n- A missing history file does not raise an error whene executing ``topology``,\n  but is just logged as an error.\n- A few CSS and other theme issues have been fixed.\n\n\n1.6.0 (2016-03-21)\n------------------\n\nChanges\n~~~~~~~\n- When expanding the search path for attribute injection all hidden folders\n  (starting with '.') will now be ignored.\n- When processing files that matched the search path for attribute injection\n  all files that have ill formed / unparseable SZN strings will be logged as\n  error and skipped instead of raising an exception.\n- When processing files that matched the search path for attribute injection\n  all ``.py``'s that doesn't possess a ``TOPOLOGY`` variable will now be warned\n  and skipped instead of raising an exception.\n\nFix\n~~~\n- Fixed attribute injection crashing when a SZN file is in the node expansion\n  search path.\n- Fixed rollback routine not being triggered when an non ``Exception`` subclass\n  is raised.\n\n\n1.5.0 (2016-03-02)\n------------------\n\nNew\n~~~\n- New ``topology.platforms.shell.PExpectBashShell`` class that allows to easily\n  setup shells that uses bash.\n\nFix\n~~~\n- Fixed small identation bug that caused the function ``get_shell()`` in the\n  node API to return always ``None``.\n\n\n1.4.0 (2016-03-01)\n------------------\n\nNew\n~~~\n- New low level shell API that allows to define a common behavior for all low\n  level shell manipulation. This API is implemented by the\n  ``topology.platforms.shell`` module.\n- Two new high level API methods for accesing the low level shell API::\n\n      myshell = mynode.get_shell('python')\n      response = myshell.execute('1 + 1')\n\n  Or using a context manager::\n\n      with mynode.use_shell('python') as python:\n          # This context manager sets the default shell to 'python'\n          mynode('from os import getcwd')\n          cwd = mynode('print(getcwd())')\n\n          # Access to the low-level shell API\n          python.send_command('foo = (', matches=['... '])\n\nChanges\n~~~~~~~\n- The shell used to execute a command will now be logged.\n\n\n1.3.0 (2016-02-17)\n------------------\n\nChanges\n~~~~~~~\n- Attribute injection will now try to match files on any subfolder of the\n  search paths and not only on the search paths themselves.\n\nFix\n~~~\n- Fixed critical bug in injection attribute not considering matches in some\n  cases.\n\n\n1.2.0 (2016-02-13)\n------------------\n\nNew\n~~~\n- Added new API for the topology nodes that allow to set the default shell.\n  For example, you may now use ``mynode.default_shell = 'bash'``.\n- Documentation for the *Attribute Injection* feature was added.\n- Improvements for file matching in attribute injection files. Now, if using\n  pytest, all test folders passed as arguments will be used as search paths for\n  relative files specified in the attribute injection file. With this, it is no\n  longer required to use an absolute path, and this practice becomes deprecated.\n\nFix\n~~~\n- Fixed a bug in attribute injection when using ``attribute=value`` as node\n  identifier that caused all nodes with the attribute to use that value.\n\n\n1.1.0 (2016-01-26)\n------------------\n\nNew\n~~~\n- Added a common ``stateprovider`` decorator to ``topology.libraries.utils``\n  that allows to easily inject state to an enode in a Communication library.\n- Added a common ``NodeLoader`` class to ``topology.platforms.utils`` that\n  allows a Platform Engine to find a load nodes for it's platform.\n\n\n1.0.1 (2016-01-22)\n------------------\n\nFix\n~~~\n- Fixed fatal bug when running a single node topology without ports.\n- Fixed new PEP8 checks on the codebase.\n\n\n1.0.0 (2016-01-05)\n------------------\n\nNew\n~~~\n- Initial public release.\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "Topology is a framework for building and testing network topologies, with support for pytest.",
    "version": "1.19.1",
    "project_urls": {
        "Homepage": "http://topology.rtfd.org/"
    },
    "split_keywords": [
        "topology"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "06bd2f2e128da4bf97574262fcf4e49b4bfa312fd7f294aad6284a3f9b3e3f17",
                "md5": "120f351872c99c635e9a54aaded3de47",
                "sha256": "6084a3e8971fdbf7254983188ff8fbae6fc020c2ee9185e94631d40db1787ec8"
            },
            "downloads": -1,
            "filename": "topology-1.19.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "120f351872c99c635e9a54aaded3de47",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.6",
            "size": 68467,
            "upload_time": "2024-11-05T21:22:42",
            "upload_time_iso_8601": "2024-11-05T21:22:42.755554Z",
            "url": "https://files.pythonhosted.org/packages/06/bd/2f2e128da4bf97574262fcf4e49b4bfa312fd7f294aad6284a3f9b3e3f17/topology-1.19.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "79320d3051fa42801dc3dfb408a6738e7240053c4c936c1eb8f0281a3c14e373",
                "md5": "c5321d60d6e17b5068b88272a34db29e",
                "sha256": "63cb183465dccaa3b38b842252b29bf2fdcef68de7e9773c7caf784cab71b4d7"
            },
            "downloads": -1,
            "filename": "topology-1.19.1.tar.gz",
            "has_sig": false,
            "md5_digest": "c5321d60d6e17b5068b88272a34db29e",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.6",
            "size": 54822,
            "upload_time": "2024-11-05T21:22:44",
            "upload_time_iso_8601": "2024-11-05T21:22:44.494412Z",
            "url": "https://files.pythonhosted.org/packages/79/32/0d3051fa42801dc3dfb408a6738e7240053c4c936c1eb8f0281a3c14e373/topology-1.19.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-11-05 21:22:44",
    "github": false,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "lcname": "topology"
}
        
Elapsed time: 0.77582s