Options

These scenarios check the functionality of different options in DHCP server.

Test One Lease Per Client

Description

This scenario checks one-lease-per-client option. For this scenario you need two active leases at the same time. First you check that these leases are active and then, activate this option and check that there aren’t two leases at the same time for the same client (same MAC address).

Scenario

Step 1: Set the following configuration in DUT0:

set interfaces eth1 address 10.215.168.64/24
set interfaces eth0.100 address 10.0.0.1/24
set interfaces eth0.200 address 10.0.0.2/24
set service dhcp-server shared-network dhcp subnet 10.0.0.0/24 start 10.0.0.5 stop 10.0.0.6
set service dhcp-server shared-network dhcp subnet 10.0.0.0/24 options max-lease 4
set service dhcp-server shared-network dhcp subnet 10.0.0.0/24 options lease 4

Step 2: Set the following configuration in DUT1:

set interfaces eth0.100 mac 10:00:00:00:00:01
set interfaces eth0.200 mac 10:00:00:00:00:01

Step 3: Set the following configuration in DUT1:

set interfaces eth0.100 address dhcp
set interfaces eth0.200 address dhcp

Warning

If you do not see changes after enabling the options, you should renew all your interfaces

Step 4: Run command service dhcp-server show leases main | grep 10.0.0.5 at DUT0 and check if output contains the following tokens:

10:00:00:00:00:01
Show output
10.0.0.5   10:00:00:00:00:01  2020/11/08 08:43:51          -1

Step 5: Run command service dhcp-server show leases main | grep 10.0.0.6 at DUT0 and check if output contains the following tokens:

10:00:00:00:00:01
Show output
10.0.0.6   10:00:00:00:00:01  2024/02/26 18:58:41  2024/02/26 18:58:45  2024/02/26 18:58:41

Step 6: Set the following configuration in DUT0:

set service dhcp-server shared-network dhcp subnet 10.0.0.0/24 options one-lease-per-client

Step 7: Run command service dhcp-server show leases main | grep 10.0.0.5 at DUT0 and check if output does not contain the following tokens:

10:00:00:00:00:01

Step 8: Run command service dhcp-server show leases main | grep 10.0.0.6 at DUT0 and check if output contains the following tokens:

10:00:00:00:00:01
Show output
10.0.0.6   10:00:00:00:00:01  2024/02/26 18:58:43  2024/02/26 18:58:47  2024/02/26 18:58:43

Step 9: Run command service dhcp-server clear main lease all at DUT0.

Step 10: Run command interfaces show detailed at DUT1 and check if output does not contain the following tokens:

10.0.0.5
Show output
--------------------------------------------------------------------------------------------------------------------
  Name    Idx           IP Address           Admin  Oper  Link  MTU   Vrf  Upper  Lower    Type        Phys addr
--------------------------------------------------------------------------------------------------------------------
    eth0  2    fe80::dcad:beff:feef:6c20/64  up     up    up    1500                     ethernet  de:ad:be:ef:6c:20
eth0.100  43   10.0.0.6/24                   up     up    up    1500              eth0   ethernet  10:00:00:00:00:01
               fe80::dcad:beff:feef:6c20/64
eth0.200  44   10.0.0.6/24                   up     up    up    1500              eth0   ethernet  10:00:00:00:00:01
               fe80::dcad:beff:feef:6c20/64
    eth1  3                                  down   down  down  1500                     ethernet  de:ad:be:ef:6c:21
   tunl0  15                                 down   down  down  1480                     tunnel    0.0.0.0

Step 11: Run command interfaces show detailed at DUT1 and check if output contains the following tokens:

10.0.0.6
Show output
--------------------------------------------------------------------------------------------------------------------
  Name    Idx           IP Address           Admin  Oper  Link  MTU   Vrf  Upper  Lower    Type        Phys addr
--------------------------------------------------------------------------------------------------------------------
    eth0  2    fe80::dcad:beff:feef:6c20/64  up     up    up    1500                     ethernet  de:ad:be:ef:6c:20
eth0.100  43   10.0.0.6/24                   up     up    up    1500              eth0   ethernet  10:00:00:00:00:01
               fe80::dcad:beff:feef:6c20/64
eth0.200  44   10.0.0.6/24                   up     up    up    1500              eth0   ethernet  10:00:00:00:00:01
               fe80::dcad:beff:feef:6c20/64
    eth1  3                                  down   down  down  1500                     ethernet  de:ad:be:ef:6c:21
   tunl0  15                                 down   down  down  1480                     tunnel    0.0.0.0

Test One Lease Per Client VRF

Description

This scenario checks one-lease-per-client option for DHCP-server but it is configured with VRF instead of regular interfaces. First this scenario checks there are 2 leases for the same client at the same time and then enable the option and check there are not two leases active at the same time for the same client.

Scenario

Step 1: Set the following configuration in DUT0:

set interfaces eth1 address 10.215.168.64/24
set interfaces eth0.100 address 10.0.0.1/24
set interfaces eth0.100 vrf VRF0
set interfaces eth0.200 address 10.0.0.2/24
set interfaces eth0.200 vrf VRF0
set service dhcp-server shared-network dhcp local-vrf VRF0
set service dhcp-server shared-network dhcp subnet 10.0.0.0/24 start 10.0.0.5 stop 10.0.0.6
set service dhcp-server shared-network dhcp subnet 10.0.0.0/24 options max-lease 4
set service dhcp-server shared-network dhcp subnet 10.0.0.0/24 options lease 4
set system vrf VRF0

Step 2: Set the following configuration in DUT1:

set interfaces eth0.100 mac 10:00:00:00:00:01
set interfaces eth0.200 mac 10:00:00:00:00:01

Step 3: Set the following configuration in DUT1:

set interfaces eth0.100 address dhcp
set interfaces eth0.200 address dhcp

Warning

If you do not see changes after enabling the options, you should renew all your interfaces

Step 4: Run command service dhcp-server show leases VRF0 | grep 10.0.0.5 at DUT0 and check if output contains the following tokens:

10:00:00:00:00:01
Show output
10.0.0.5   10:00:00:00:00:01  2020/11/08 08:43:51        -1

Step 5: Run command service dhcp-server show leases VRF0 | grep 10.0.0.6 at DUT0 and check if output contains the following tokens:

10:00:00:00:00:01
Show output
10.0.0.6   10:00:00:00:00:01  2024/02/26 18:59:07  2024/02/26 18:59:11  2024/02/26 18:59:07

Step 6: Set the following configuration in DUT0:

set service dhcp-server shared-network dhcp subnet 10.0.0.0/24 options one-lease-per-client

Step 7: Run command service dhcp-server show leases VRF0 | grep 10.0.0.5 at DUT0 and check if output does not contain the following tokens:

10:00:00:00:00:01

Step 8: Run command service dhcp-server show leases VRF0 | grep 10.0.0.6 at DUT0 and check if output contains the following tokens:

10:00:00:00:00:01
Show output
10.0.0.6   10:00:00:00:00:01  2024/02/26 18:59:09  2024/02/26 18:59:13  2024/02/26 18:59:09

Step 9: Run command service dhcp-server clear VRF0 lease all at DUT0.

Step 10: Run command interfaces show detailed at DUT1 and check if output does not contain the following tokens:

10.0.0.5
Show output
--------------------------------------------------------------------------------------------------------------------
  Name    Idx           IP Address           Admin  Oper  Link  MTU   Vrf  Upper  Lower    Type        Phys addr
--------------------------------------------------------------------------------------------------------------------
    eth0  2    fe80::dcad:beff:feef:6c20/64  up     up    up    1500                     ethernet  de:ad:be:ef:6c:20
eth0.100  45   10.0.0.6/24                   up     up    up    1500              eth0   ethernet  10:00:00:00:00:01
               fe80::dcad:beff:feef:6c20/64
eth0.200  46   10.0.0.6/24                   up     up    up    1500              eth0   ethernet  10:00:00:00:00:01
               fe80::dcad:beff:feef:6c20/64
    eth1  3                                  down   down  down  1500                     ethernet  de:ad:be:ef:6c:21
   tunl0  15                                 down   down  down  1480                     tunnel    0.0.0.0

Step 11: Run command interfaces show detailed at DUT1 and check if output contains the following tokens:

10.0.0.6
Show output
--------------------------------------------------------------------------------------------------------------------
  Name    Idx           IP Address           Admin  Oper  Link  MTU   Vrf  Upper  Lower    Type        Phys addr
--------------------------------------------------------------------------------------------------------------------
    eth0  2    fe80::dcad:beff:feef:6c20/64  up     up    up    1500                     ethernet  de:ad:be:ef:6c:20
eth0.100  45   10.0.0.6/24                   up     up    up    1500              eth0   ethernet  10:00:00:00:00:01
               fe80::dcad:beff:feef:6c20/64
eth0.200  46   10.0.0.6/24                   up     up    up    1500              eth0   ethernet  10:00:00:00:00:01
               fe80::dcad:beff:feef:6c20/64
    eth1  3                                  down   down  down  1500                     ethernet  de:ad:be:ef:6c:21
   tunl0  15                                 down   down  down  1480                     tunnel    0.0.0.0

Test Authoritative

Description

This scenario checks authoritative option. First you need to configure a DHCP server without the option enabled and give a lease to the client. Then change the configuration of the server for another subnet. The client will renew his lease and see a problem, the new server is not in the same subnet and it is not authorized to give a lease. Finally, if you enable the option and renew the interface, you will see the server is authorized and it can give the lease to the client.

Scenario

Step 1: Set the following configuration in DUT0:

set interfaces eth0 address 10.0.0.1/24
set service dhcp-server shared-network authoritative subnet 10.0.0.0/24 start 10.0.0.5 stop 10.0.0.5

Step 2: Set the following configuration in DUT1:

set interfaces ethernet eth0 mac 10:00:00:00:00:01

Step 3: Set the following configuration in DUT1:

set interfaces ethernet eth0 address dhcp

Warning

If you do not see changes after enabling the options, you should renew all your interfaces

Step 4: Run command interfaces ethernet eth0 show at DUT1 and check if output contains the following tokens:

10.0.0.5
Show output
-----------------------------------------------------------------
Name           IP Address           Admin  Oper  Vrf  Description
-----------------------------------------------------------------
eth0  10.0.0.5/24                   up     up
      fe80::dcad:beff:feef:6c20/64

Step 5: Set the following configuration in DUT0:

delete service
delete interfaces

Step 6: Set the following configuration in DUT0:

set interfaces eth0 address 11.0.0.1/24
set service dhcp-server shared-network authoritative subnet 11.0.0.0/24 start 11.0.0.5 stop 11.0.0.5

Step 7: Run command interfaces ethernet eth0 show at DUT1 and check if output contains the following tokens:

10.0.0.5
Show output
-----------------------------------------------------------------
Name           IP Address           Admin  Oper  Vrf  Description
-----------------------------------------------------------------
eth0  10.0.0.5/24                   up     up
      fe80::dcad:beff:feef:6c20/64

Step 8: Run command system journal show | tail at DUT0 and check if output contains the following tokens:

DHCPREQUEST for 10.0.0.5 from 10:00:00:00:00:01 via eth0: ignored (not authoritative)
Show output
Feb 26 18:59:26.506359 osdx OSDxCLI[2572]: User 'admin' added a new cfg line: 'set interfaces eth0 address 11.0.0.1/24'.
Feb 26 18:59:26.630856 osdx OSDxCLI[2572]: User 'admin' added a new cfg line: 'set service dhcp-server shared-network authoritative subnet 11.0.0.0/24 start 11.0.0.5 stop 11.0.0.5'.
Feb 26 18:59:26.785400 osdx kernel: 8021q: adding VLAN 0 to HW filter on device eth0
Feb 26 18:59:26.877070 osdx systemd[1]: Started "DHCP Server Service instance main".
Feb 26 18:59:26.881147 osdx cfgd[997]: [2572]Completed change to active configuration
Feb 26 18:59:26.901065 osdx OSDxCLI[2572]: User 'admin' committed the configuration.
Feb 26 18:59:26.905813 osdx dhcpd[3117]: Wrote 0 leases to leases file.
Feb 26 18:59:26.951571 osdx OSDxCLI[2572]: User 'admin' left the configuration menu.
Feb 26 18:59:26.983253 osdx dhcpd[3117]: Server starting service.
Feb 26 18:59:27.380002 osdx dhcpd[3117]: DHCPREQUEST for 10.0.0.5 from 10:00:00:00:00:01 via eth0: ignored (not authoritative).

Step 9: Set the following configuration in DUT0:

set service dhcp-server options authoritative

Step 10: Run command system journal show | tail at DUT0 and check if output contains the following tokens:

DHCPNAK on 10.0.0.5 to 10:00:00:00:00:01 via eth0
Show output
Feb 26 18:59:28.104352 osdx systemd[1]: dhcpd@main.service: Succeeded.
Feb 26 18:59:28.104788 osdx systemd[1]: Stopped "DHCP Server Service instance main".
Feb 26 18:59:28.106747 osdx systemd[1]: Started "DHCP Server Service instance main".
Feb 26 18:59:28.110582 osdx cfgd[997]: [2572]Completed change to active configuration
Feb 26 18:59:28.120202 osdx OSDxCLI[2572]: User 'admin' committed the configuration.
Feb 26 18:59:28.126552 osdx dhcpd[3154]: Wrote 0 leases to leases file.
Feb 26 18:59:28.172400 osdx OSDxCLI[2572]: User 'admin' left the configuration menu.
Feb 26 18:59:28.267163 osdx dhcpd[3154]: Server starting service.
Feb 26 18:59:28.598467 osdx dhcpd[3154]: DHCPREQUEST for 10.0.0.5 from 10:00:00:00:00:01 via eth0: wrong network.
Feb 26 18:59:28.598759 osdx dhcpd[3154]: DHCPNAK on 10.0.0.5 to 10:00:00:00:00:01 via eth0

Step 11: Run command interfaces ethernet eth0 show at DUT1 and check if output contains the following tokens:

11.0.0.5
Show output
-----------------------------------------------------------------
Name           IP Address           Admin  Oper  Vrf  Description
-----------------------------------------------------------------
eth0  11.0.0.5/24                   up     up
      fe80::dcad:beff:feef:6c20/64

Test Authoritative VRF

Description

This scenario checks authoritative option but the server is configured with VRF instead of regular interfaces. First, configure the server and give a lease to the client. Then, change the configuration of the server and put it on a different subnet. In addition, renew the interfaces and you will see the server cannot. Change the configuration again and add the authoritative option. With this change, the server will be able to give a lease to the client.

Scenario

Step 1: Set the following configuration in DUT0:

set interfaces eth0 address 10.0.0.1/24
set interfaces eth0 vrf VRF0
set service dhcp-server shared-network authoritative subnet 10.0.0.0/24 start 10.0.0.5 stop 10.0.0.5
set service dhcp-server shared-network authoritative local-vrf VRF0
set system vrf VRF0

Step 2: Set the following configuration in DUT1:

set interfaces ethernet eth0 mac 10:00:00:00:00:01

Step 3: Set the following configuration in DUT1:

set interfaces ethernet eth0 address dhcp

Warning

If you do not see changes after enabling the options, you should renew all your interfaces

Step 4: Run command interfaces ethernet eth0 show at DUT1 and check if output contains the following tokens:

10.0.0.5
Show output
-----------------------------------------------------------------
Name           IP Address           Admin  Oper  Vrf  Description
-----------------------------------------------------------------
eth0  10.0.0.5/24                   up     up
      fe80::dcad:beff:feef:6c20/64

Step 5: Set the following configuration in DUT0:

delete service
delete interfaces

Step 6: Set the following configuration in DUT0:

set interfaces eth0 address 11.0.0.1/24
set interfaces eth0 vrf VRF0
set service dhcp-server shared-network authoritative subnet 11.0.0.0/24 start 11.0.0.5 stop 11.0.0.5
set service dhcp-server shared-network authoritative local-vrf VRF0

Step 7: Run command interfaces ethernet eth0 show at DUT1 and check if output contains the following tokens:

10.0.0.5
Show output
-----------------------------------------------------------------
Name           IP Address           Admin  Oper  Vrf  Description
-----------------------------------------------------------------
eth0  10.0.0.5/24                   up     up
      fe80::dcad:beff:feef:6c20/64

Step 8: Run command system journal show | tail at DUT0 and check if output contains the following tokens:

DHCPREQUEST for 10.0.0.5 from 10:00:00:00:00:01 via eth0: ignored (not authoritative)
Show output
Feb 26 18:59:44.393418 osdx OSDxCLI[2572]: User 'admin' added a new cfg line: 'set service dhcp-server shared-network authoritative local-vrf VRF0'.
Feb 26 18:59:44.557392 osdx kernel: 8021q: adding VLAN 0 to HW filter on device eth0
Feb 26 18:59:44.612645 osdx kernel: 8021q: adding VLAN 0 to HW filter on device eth0
Feb 26 18:59:44.675322 osdx systemd[1]: Started "DHCP Server Service instance VRF0".
Feb 26 18:59:44.679599 osdx cfgd[997]: [2572]Completed change to active configuration
Feb 26 18:59:44.699809 osdx OSDxCLI[2572]: User 'admin' committed the configuration.
Feb 26 18:59:44.704085 osdx dhcpd[3582]: Wrote 0 leases to leases file.
Feb 26 18:59:44.738953 osdx OSDxCLI[2572]: User 'admin' left the configuration menu.
Feb 26 18:59:44.871941 osdx dhcpd[3582]: Server starting service.
Feb 26 18:59:45.166772 osdx dhcpd[3582]: DHCPREQUEST for 10.0.0.5 from 10:00:00:00:00:01 via eth0: ignored (not authoritative).

Step 9: Set the following configuration in DUT0:

set service dhcp-server options authoritative

Step 10: Run command system journal show | tail at DUT0 and check if output contains the following tokens:

DHCPNAK on 10.0.0.5 to 10:00:00:00:00:01 via eth0
Show output
Feb 26 18:59:45.914272 osdx systemd[1]: dhcpd@VRF0.service: Succeeded.
Feb 26 18:59:45.914707 osdx systemd[1]: Stopped "DHCP Server Service instance VRF0".
Feb 26 18:59:45.916655 osdx systemd[1]: Started "DHCP Server Service instance VRF0".
Feb 26 18:59:45.920463 osdx cfgd[997]: [2572]Completed change to active configuration
Feb 26 18:59:45.930714 osdx OSDxCLI[2572]: User 'admin' committed the configuration.
Feb 26 18:59:45.936168 osdx dhcpd[3619]: Wrote 0 leases to leases file.
Feb 26 18:59:45.983074 osdx OSDxCLI[2572]: User 'admin' left the configuration menu.
Feb 26 18:59:46.072137 osdx dhcpd[3619]: Server starting service.
Feb 26 18:59:46.408505 osdx dhcpd[3619]: DHCPREQUEST for 10.0.0.5 from 10:00:00:00:00:01 via eth0: wrong network.
Feb 26 18:59:46.408538 osdx dhcpd[3619]: DHCPNAK on 10.0.0.5 to 10:00:00:00:00:01 via eth0

Step 11: Run command interfaces ethernet eth0 show at DUT1 and check if output contains the following tokens:

11.0.0.5
Show output
-----------------------------------------------------------------
Name           IP Address           Admin  Oper  Vrf  Description
-----------------------------------------------------------------
eth0  11.0.0.5/24                   up     up
      fe80::dcad:beff:feef:6c20/64