From: James Prestwood <prestwoj@gmail.com>
To: iwd@lists.linux.dev
Cc: James Prestwood <prestwoj@gmail.com>
Subject: [PATCH 10/11] auto-t: Add test for new SAE default group behavior
Date: Tue, 27 Feb 2024 10:34:04 -0800 [thread overview]
Message-ID: <20240227183405.257206-10-prestwoj@gmail.com> (raw)
In-Reply-To: <20240227183405.257206-1-prestwoj@gmail.com>
Tests the 3 possible options to UseDefaultEccGroup behave as
expected:
- When not provided use the "auto" behavior.
- When false, always use higher order groups
- When true, always use default group
---
autotests/testSAE/default_group_test.py | 96 +++++++++++++++++++
autotests/testSAE/hw.conf | 3 +-
.../profiles/ssidSAE.psk.default_group | 5 +
.../testSAE/profiles/ssidSAE.psk.most_secure | 5 +
autotests/testSAE/ssidSAE-default-group.conf | 12 +++
5 files changed, 120 insertions(+), 1 deletion(-)
create mode 100644 autotests/testSAE/default_group_test.py
create mode 100644 autotests/testSAE/profiles/ssidSAE.psk.default_group
create mode 100644 autotests/testSAE/profiles/ssidSAE.psk.most_secure
create mode 100644 autotests/testSAE/ssidSAE-default-group.conf
diff --git a/autotests/testSAE/default_group_test.py b/autotests/testSAE/default_group_test.py
new file mode 100644
index 00000000..d72c96ca
--- /dev/null
+++ b/autotests/testSAE/default_group_test.py
@@ -0,0 +1,96 @@
+#!/usr/bin/python3
+
+import unittest
+import sys
+import os
+sys.path.append('../util')
+import iwd
+from iwd import IWD
+from iwd import PSKAgent
+from iwd import NetworkType
+from hostapd import HostapdCLI
+import testutil
+
+class Test(unittest.TestCase):
+
+ def validate_connection(self, wd, rejected=False):
+ devices = wd.list_devices(1)
+ self.assertIsNotNone(devices)
+ device = devices[0]
+
+ device.autoconnect = True
+
+ if rejected:
+ device.wait_for_event("ecc-group-rejected", timeout=60)
+
+ condition = 'obj.state == DeviceState.connected'
+ wd.wait_for_object_condition(device, condition)
+
+ wd.wait(2)
+
+ testutil.test_iface_operstate(intf=device.name)
+ testutil.test_ifaces_connected(if0=device.name, if1=self.hostapd.ifname)
+
+ if not rejected:
+ self.assertEqual(device.event_ocurred("ecc-group-rejected"), False)
+
+ print(self.hostapd._get_status())
+
+ sta_status = self.hostapd.sta_status(device.address)
+
+ print(sta_status)
+
+ self.assertEqual(int(sta_status["sae_group"]), 19)
+
+ device.disconnect()
+
+ # IWD should:
+ # - Connect, fail with group 20
+ # - Retry, succeed with group 19
+ # - Disconnect
+ # - Connect, try only group 19
+ def test_auto_selection(self):
+ IWD.copy_to_storage("profiles/ssidSAE.psk.default", name="ssidSAE.psk")
+ self.validate_connection(self.wd, rejected=True)
+
+ self.validate_connection(self.wd, rejected=False)
+
+ # Try group 19 first
+ def test_default_group_enabled(self):
+ IWD.copy_to_storage("profiles/ssidSAE.psk.default_group", name="ssidSAE.psk")
+ self.validate_connection(self.wd)
+
+ # Same as auto-selection but won't retain the default group setting
+ def test_default_group_disabled(self):
+ IWD.copy_to_storage("profiles/ssidSAE.psk.most_secure", name="ssidSAE.psk")
+ self.validate_connection(self.wd, rejected=True)
+
+ # IWD should then retry but use only group 19
+ self.validate_connection(self.wd, rejected=True)
+
+ def setUp(self):
+ self.hostapd.default()
+ self.hostapd.set_value('sae_groups', '19')
+ self.hostapd.set_value('sae_pwe', '0')
+ self.hostapd.reload()
+ self.hostapd.wait_for_event("AP-ENABLED")
+ self.wd = IWD(True)
+
+ self.wd.clear_storage()
+ os.system("ls /tmp/iwd")
+
+ def tearDown(self):
+ self.wd.clear_storage()
+ self.wd = None
+
+ @classmethod
+ def setUpClass(cls):
+ cls.hostapd = HostapdCLI(config='ssidSAE.conf')
+ cls.hostapd.default()
+
+ @classmethod
+ def tearDownClass(cls):
+ pass
+
+if __name__ == '__main__':
+ unittest.main(exit=True)
diff --git a/autotests/testSAE/hw.conf b/autotests/testSAE/hw.conf
index cc0836b7..127bbb31 100644
--- a/autotests/testSAE/hw.conf
+++ b/autotests/testSAE/hw.conf
@@ -1,8 +1,9 @@
[SETUP]
-num_radios=3
+num_radios=4
start_iwd=0
hwsim_medium=yes
[HOSTAPD]
rad0=ssidSAE.conf
rad1=ssidSAE-H2E.conf
+rad2=ssidSAE-default-group.conf
diff --git a/autotests/testSAE/profiles/ssidSAE.psk.default_group b/autotests/testSAE/profiles/ssidSAE.psk.default_group
new file mode 100644
index 00000000..2a016107
--- /dev/null
+++ b/autotests/testSAE/profiles/ssidSAE.psk.default_group
@@ -0,0 +1,5 @@
+[Security]
+Passphrase=secret123
+
+[Settings]
+UseDefaultEccGroup=true
diff --git a/autotests/testSAE/profiles/ssidSAE.psk.most_secure b/autotests/testSAE/profiles/ssidSAE.psk.most_secure
new file mode 100644
index 00000000..3a511991
--- /dev/null
+++ b/autotests/testSAE/profiles/ssidSAE.psk.most_secure
@@ -0,0 +1,5 @@
+[Security]
+Passphrase=secret123
+
+[Settings]
+UseDefaultEccGroup=false
\ No newline at end of file
diff --git a/autotests/testSAE/ssidSAE-default-group.conf b/autotests/testSAE/ssidSAE-default-group.conf
new file mode 100644
index 00000000..752e9c7b
--- /dev/null
+++ b/autotests/testSAE/ssidSAE-default-group.conf
@@ -0,0 +1,12 @@
+hw_mode=g
+channel=1
+ssid=ssidSAE-default-group
+
+wpa=2
+wpa_key_mgmt=SAE
+wpa_pairwise=CCMP
+sae_password=secret123
+sae_groups=19
+ieee80211w=2
+sae_pwe=0
+vendor_elements=dd0cf4f5e8050500000000000000
--
2.34.1
next prev parent reply other threads:[~2024-02-27 18:34 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-02-27 18:33 [PATCH 01/11] doc: Document UseDefaultEccGroup James Prestwood
2024-02-27 18:33 ` [PATCH 02/11] knownnetworks: add option to force a default ECC group James Prestwood
2024-02-27 18:33 ` [PATCH 03/11] network: retain default ECC group for OWE after setting James Prestwood
2024-02-27 18:33 ` [PATCH 04/11] network: set use default ECC group in handshake setup James Prestwood
2024-02-27 18:33 ` [PATCH 05/11] sae: remove sae_sm_set_force_group_19, use handshake James Prestwood
2024-02-27 18:34 ` [PATCH 06/11] netdev: add NETDEV_EVENT_ECC_GROUP_RETRY, handle in station James Prestwood
2024-02-27 18:34 ` [PATCH 07/11] auto-t: add Device.event_ocurred James Prestwood
2024-02-27 18:34 ` [PATCH 08/11] auto-t: add HostapdCLI.sta_status James Prestwood
2024-02-27 18:34 ` [PATCH 09/11] auto-t: refactor/fix testSAE James Prestwood
2024-02-27 18:34 ` James Prestwood [this message]
2024-02-27 18:34 ` [PATCH 11/11] auto-t: add OWE test for auto default group James Prestwood
2024-02-27 19:56 ` [PATCH 01/11] doc: Document UseDefaultEccGroup Denis Kenzior
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20240227183405.257206-10-prestwoj@gmail.com \
--to=prestwoj@gmail.com \
--cc=iwd@lists.linux.dev \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox