public inbox for passt-dev@passt.top
 help / color / mirror / code / Atom feed
blob d8b7856819fc327aa2102bc2c687d993144c4882 3593 bytes (raw)

  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
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
 
#! /usr/bin/env python3

# SPDX-License-Identifier: GPL-2.0-or-later
#
# Copyright Red Hat
# Author: David Gibson <david@gibson.dropbear.id.au>

"""
Test A Simple Socket Transport

scenario/simple.py - Smallest sensible network to use passt/pasta
"""

import contextlib

from .. import address, nstool, transfer


class __SimpleNet:  # pylint: disable=R0903
    """A simple network setup scenario

    The sample network has 2 snhs (network namespaces) connected with
    a veth link:
            [simhost]   <-veth->    [gw]

    gw is set up as the default router for simhost.

    simhost has addresses:
        self.IP4 (IPv4), self.IP6 (IPv6), self.ip6_ll (IPv6 link local)

    gw has addresses:
        self.GW_IP4 (IPv4), self.GW_IP6 (IPv6),
            self.gw_ip6_ll (IPv6 link local)
        self.REMOTE_IP4 (IPv4), self.REMOTE_IP6 (IPv6)

    The "remote" addresses are on a different subnet from the others,
    so the only way for simhost to reach them is via its default
    route.  This helps to exercise that we're actually using that,
    rather than just local net routes.

    """

    IFNAME = 'veth'
    ipa_local = address.IpiAllocator()
    (IP4, IP6) = ipa_local.next_ipis()
    (GW_IP4, GW_IP6) = ipa_local.next_ipis()

    ipa_remote = address.IpiAllocator(address.TEST_NET_2,
                                      address.TEST_NET6_TASST_B)
    (REMOTE_IP4, REMOTE_IP6) = ipa_remote.next_ipis()

    def __init__(self, simhost, gw):
        self.simhost = simhost
        self.gw = gw

        ifname = self.IFNAME
        self.gw_ifname = 'gw' + ifname
        self.simhost.veth(self.IFNAME, self.gw_ifname, self.gw)

        self.gw.ifup('lo')
        self.gw.ifup(self.gw_ifname, self.GW_IP4, self.GW_IP6,
                     self.REMOTE_IP4, self.REMOTE_IP6)

        self.simhost.ifup('lo')
        self.simhost.ifup(ifname, self.IP4, self.IP6)

        # Once link is up on both sides, SLAAC will run
        self.gw_ip6_ll = self.gw.addr_wait(self.gw_ifname,
                                           family='inet6', scope='link')[0]
        self.ip6_ll = self.simhost.addr_wait(ifname,
                                             family='inet6', scope='link')[0]

        # Set up the default route
        self.simhost.fg('ip', '-4', 'route', 'add', 'default',
                        'via', f'{self.GW_IP4.ip}', capable=True)
        self.simhost.fg('ip', '-6', 'route', 'add', 'default',
                        'via', f'{self.gw_ip6_ll.ip}', 'dev', f'{ifname}',
                        capable=True)


@contextlib.contextmanager
def simple_net():
    with nstool.unshare_snh('simhost', '-Ucnpf', '--mount-proc') as simhost, \
         nstool.unshare_snh('gw', '-n', parent=simhost, capable=True) as gw:
        yield __SimpleNet(simhost, gw)


@contextlib.contextmanager
def simple_transfer4_setup():
    with simple_net() as snet:
        yield transfer.TransferTestScenario(client=snet.simhost,
                                            server=snet.gw,
                                            connect_ip=snet.REMOTE_IP4.ip,
                                            connect_port=10000)


transfer.transfer_tests(simple_transfer4_setup)


@contextlib.contextmanager
def simple_transfer6_setup():
    with simple_net() as snet:
        yield transfer.TransferTestScenario(client=snet.simhost,
                                            server=snet.gw,
                                            connect_ip=snet.REMOTE_IP6.ip,
                                            connect_port=10000)


transfer.transfer_tests(simple_transfer6_setup)

debug log:

solving d8b78568 ...
found d8b78568 in https://archives.passt.top/passt-dev/20240805123701.1720730-22-david@gibson.dropbear.id.au/

applying [1/1] https://archives.passt.top/passt-dev/20240805123701.1720730-22-david@gibson.dropbear.id.au/
diff --git a/test/tasst/scenario/simple.py b/test/tasst/scenario/simple.py
new file mode 100644
index 00000000..d8b78568

Checking patch test/tasst/scenario/simple.py...
Applied patch test/tasst/scenario/simple.py cleanly.

index at:
100644 d8b7856819fc327aa2102bc2c687d993144c4882	test/tasst/scenario/simple.py

Code repositories for project(s) associated with this public inbox

	https://passt.top/passt

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for IMAP folder(s).