Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(anta): add test atomic results #937

Open
wants to merge 72 commits into
base: main
Choose a base branch
from

Conversation

mtache
Copy link
Collaborator

@mtache mtache commented Nov 26, 2024

Description

Add anta.result_manager.models.AtomicTestResult model.
Create a atomic_results field in anta.result_manager.models.TestResult model.

Reports supported are table, text, json and jinja. csv and markdown will be supported in another PR.

Considering the test:

anta.tests.connectivity:
- VerifyReachability:
    filters:
      tags:
      - mtache-leaf2a
    hosts:
    - description: mtache-spine1 Ethernet3/1
      destination: 10.255.255.4
      repeat: 1
      source: Ethernet49/1
      vrf: default
    - destination: 10.255.255.10
      repeat: 1
      source: 10.255.255.11
      vrf: default

The exemple below is a serialisation of the TestResult model of the test defined above:

  {
    "name": "mtache-leaf2a",
    "test": "VerifyReachability",
    "categories": [
      "connectivity"
    ],
    "description": "Test network reachability to one or many destination IP(s).",
    "inputs": {
      "filters": {
        "tags": [
          "mtache-leaf2a"
        ]
      },
      "hosts": [
        {
          "description": "mtache-spine1 Ethernet3/1",
          "destination": "10.255.255.4",
          "source": "Ethernet49/1",
          "vrf": "default",
          "repeat": 1,
          "size": 100,
          "df_bit": false
        },
        {
          "destination": "10.255.255.10",
          "source": "10.255.255.11",
          "vrf": "default",
          "repeat": 1,
          "size": 100,
          "df_bit": false
        }
      ]
    },
    "result": "failure",
    "messages": [
      "Unreachable Destination 10.255.255.4 (mtache-spine1 Ethernet3/1) from Ethernet49/1 in VRF default"
    ],
    "atomic_results": [
      {
        "description": "Destination 10.255.255.4 (mtache-spine1 Ethernet3/1) from Ethernet49/1 in VRF default",
        "inputs": {
          "description": "mtache-spine1 Ethernet3/1",
          "destination": "10.255.255.4",
          "source": "Ethernet49/1",
          "vrf": "default",
          "repeat": 1,
          "size": 100,
          "df_bit": false
        },
        "result": "failure",
        "messages": [
          "Unreachable Destination 10.255.255.4 (mtache-spine1 Ethernet3/1) from Ethernet49/1 in VRF default"
        ]
      },
      {
        "description": "Destination 10.255.255.10 from 10.255.255.11 in VRF default",
        "inputs": {
          "destination": "10.255.255.10",
          "source": "10.255.255.11",
          "vrf": "default",
          "repeat": 1,
          "size": 100,
          "df_bit": false
        },
        "result": "success",
        "messages": []
      }
    ]
  }

Fixes #427

Checklist:

  • My code follows the style guidelines of this project
  • I have performed a self-review of my code
  • I have run pre-commit for code linting and typing (pre-commit run)
  • I have made corresponding changes to the documentation
  • I have added tests that prove my fix is effective or that my feature works
  • New and existing unit tests pass locally with my changes (tox -e testenv)
  • Make the reports display atomic results

@mtache mtache changed the title feat(anta): add anta.result_manager.models.AtomicTestResult feat(anta): add test atomic results Nov 26, 2024
@mtache mtache marked this pull request as ready for review November 26, 2024 15:36
Copy link

codspeed-hq bot commented Nov 26, 2024

CodSpeed Performance Report

Merging #937 will degrade performances by 24.79%

Comparing mtache:issue-427 (0503847) with main (d57b53e)

Summary

⚡ 4 improvements
❌ 4 regressions
✅ 14 untouched benchmarks
🆕 2 new benchmarks

⚠️ Please fix the performance issues or acknowledge them on CodSpeed.

Benchmarks breakdown

Benchmark main mtache:issue-427 Change
test_anta_dry_run[1-device] 56.3 ms 69 ms -18.4%
test_anta_dry_run[2-devices] 97.6 ms 122.7 ms -20.45%
test_jinja[1-device] 52.1 ms 46.5 ms +12.06%
test_jinja[2-devices] 98.9 ms 86.9 ms +13.85%
test_json[1-device] 34.4 ms 21.6 ms +58.95%
test_json[2-devices] 67.4 ms 41.4 ms +62.71%
🆕 test_table_expanded[1-device] N/A 18.7 ms N/A
🆕 test_table_expanded[2-devices] N/A 37.3 ms N/A
test_get_coroutines[1-device] 40.9 ms 54.2 ms -24.57%
test_get_coroutines[2-devices] 80.6 ms 107.1 ms -24.79%

anta/cli/nrfu/__init__.py Outdated Show resolved Hide resolved
anta/cli/nrfu/utils.py Outdated Show resolved Hide resolved
anta/result_manager/__init__.py Show resolved Hide resolved
anta/result_manager/models.py Outdated Show resolved Hide resolved
anta/reporter/__init__.py Outdated Show resolved Hide resolved
@gmuloc gmuloc modified the milestones: v1.2.0, v1.3.0 Dec 24, 2024
anta/reporter/__init__.py Outdated Show resolved Hide resolved
anta/result_manager/__init__.py Outdated Show resolved Hide resolved
anta/models.py Show resolved Hide resolved
anta/cli/get/commands.py Show resolved Hide resolved
anta/cli/nrfu/utils.py Outdated Show resolved Hide resolved
tests/units/reporter/test__init__.py Show resolved Hide resolved
tests/units/result_manager/conftest.py Show resolved Hide resolved
tests/units/result_manager/conftest.py Outdated Show resolved Hide resolved
anta/models.py Show resolved Hide resolved
anta/models.py Show resolved Hide resolved
anta/tests/connectivity.py Show resolved Hide resolved
.pre-commit-config.yaml Outdated Show resolved Hide resolved
anta/cli/debug/utils.py Show resolved Hide resolved
anta/reporter/__init__.py Outdated Show resolved Hide resolved
Copy link

Quality Gate Failed Quality Gate failed

Failed conditions
79.9% Coverage on New Code (required ≥ 80%)

See analysis details on SonarQube Cloud

Copy link
Contributor

This pull request has conflicts, please resolve those before we can evaluate the pull request.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Feat: Add granular results for tests with lists of inputs
3 participants