From patchwork Sun Apr 2 12:52:53 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: michael-dev X-Patchwork-Id: 746174 Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org Received: from bombadil.infradead.org (bombadil.infradead.org [65.50.211.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ozlabs.org (Postfix) with ESMTPS id 3vwwCw2Cvsz9s0m for ; Sun, 2 Apr 2017 22:54:03 +1000 (AEST) Authentication-Results: ozlabs.org; dkim=pass (2048-bit key; unprotected) header.d=lists.infradead.org header.i=@lists.infradead.org header.b="mNPsLUXw"; dkim-atps=neutral DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender: Content-Transfer-Encoding:Content-Type:MIME-Version:Cc:List-Subscribe: List-Help:List-Post:List-Archive:List-Unsubscribe:List-Id:References: In-Reply-To:Message-Id:Date:Subject:To:From:Reply-To:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc :Resent-Message-ID:List-Owner; bh=vQpN7ybfPyeRALuOaOAkjA663zs4DIG58kRmgoQWktw=; b=mNPsLUXwW5jjKoco7+xd3T+Ivk WRFAnGIO9ZASr7GXM/zbWXAGIqWiYYKng21yJ5mI/csRugeeChcE3tVs7l0qaMo6e18OLrGBQ1oZ5 pmAj6hmPo442eQEl2bYb53nbfp4J5VWn8zeqfgHR6F5j4vtW0+YuumxzVKAFB531CYNskITMNoZxc 6TZd5lWj9gdxR5JujFjOHreXLr5rpyO9U0W2sgPJz3QZx0pe22g3dBd9GaXRNMUrChbDmp6ZynNRk ai/Ur7e8IgWC1K7FF136bZDq5B23/WyKwf5JMJ+cP/qurH2iSywsZpksdS8TZp1eD5ibCiCQ3hzbw XH9kk/dg==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.87 #1 (Red Hat Linux)) id 1cuf16-0003ve-Hl; Sun, 02 Apr 2017 12:54:00 +0000 Received: from mail.fem.tu-ilmenau.de ([141.24.220.54]) by bombadil.infradead.org with esmtp (Exim 4.87 #1 (Red Hat Linux)) id 1cuf12-0003uG-Lt for hostap@lists.infradead.org; Sun, 02 Apr 2017 12:53:58 +0000 Received: from localhost (localhost [127.0.0.1]) by mail.fem.tu-ilmenau.de (Postfix) with ESMTP id BB3866B07; Sun, 2 Apr 2017 14:53:37 +0200 (CEST) X-Virus-Scanned: amavisd-new at fem.tu-ilmenau.de Received: from mail.fem.tu-ilmenau.de ([127.0.0.1]) by localhost (mail.fem.tu-ilmenau.de [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id EgGGhJPG7j70; Sun, 2 Apr 2017 14:53:36 +0200 (CEST) Received: from a234.fem.tu-ilmenau.de (ray-controller.net.fem.tu-ilmenau.de [10.42.51.234]) by mail.fem.tu-ilmenau.de (Postfix) with ESMTP; Sun, 2 Apr 2017 14:53:33 +0200 (CEST) Received: by a234.fem.tu-ilmenau.de (Postfix, from userid 1000) id 90BED306ACB1; Sun, 2 Apr 2017 14:52:54 +0200 (CEST) From: Michael Braun To: hostap@lists.infradead.org Subject: [PATCHv6 5/5] test: FT with broadcasts Date: Sun, 2 Apr 2017 14:52:53 +0200 Message-Id: <1491137573-643-6-git-send-email-michael-dev@fami-braun.de> X-Mailer: git-send-email 2.1.4 In-Reply-To: <1491137573-643-1-git-send-email-michael-dev@fami-braun.de> References: <1491137573-643-1-git-send-email-michael-dev@fami-braun.de> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20170402_055357_038998_B45A522F X-CRM114-Status: UNSURE ( 6.52 ) X-CRM114-Notice: Please train this message. X-Spam-Score: -4.2 (----) X-Spam-Report: SpamAssassin version 3.4.1 on bombadil.infradead.org summary: Content analysis details: (-4.2 points) pts rule name description ---- ---------------------- -------------------------------------------------- -2.3 RCVD_IN_DNSWL_MED RBL: Sender listed at http://www.dnswl.org/, medium trust [141.24.220.54 listed in list.dnswl.org] -1.9 BAYES_00 BODY: Bayes spam probability is 0 to 1% [score: 0.0000] X-BeenThere: hostap@lists.infradead.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: projekt-wlan@fem.tu-ilmenau.de, Michael Braun MIME-Version: 1.0 Sender: "Hostap" Errors-To: hostap-bounces+incoming=patchwork.ozlabs.org@lists.infradead.org Signed-off-by: Michael Braun --- tests/hwsim/test_ap_ft.py | 49 ++++++++++++++++++++++++++++++++++------------- 1 file changed, 36 insertions(+), 13 deletions(-) diff --git a/tests/hwsim/test_ap_ft.py b/tests/hwsim/test_ap_ft.py index a5a5aef..118182d 100644 --- a/tests/hwsim/test_ap_ft.py +++ b/tests/hwsim/test_ap_ft.py @@ -53,11 +53,15 @@ def ft_params1a(rsn=True, ssid=None, passphrase=None): params['r1_key_holder'] = "000102030405" return params -def ft_params1(rsn=True, ssid=None, passphrase=None): +def ft_params1(rsn=True, ssid=None, passphrase=None, discovery=False): params = ft_params1a(rsn, ssid, passphrase) - params['r0kh'] = [ "02:00:00:00:03:00 nas1.w1.fi 100102030405060708090a0b0c0d0e0f100102030405060708090a0b0c0d0e0f", - "02:00:00:00:04:00 nas2.w1.fi 300102030405060708090a0b0c0d0e0f300102030405060708090a0b0c0d0e0f" ] - params['r1kh'] = "02:00:00:00:04:00 00:01:02:03:04:06 200102030405060708090a0b0c0d0e0f200102030405060708090a0b0c0d0e0f" + if discovery: + params['r0kh'] = "ff:ff:ff:ff:ff:ff * 100102030405060708090a0b0c0d0e0f100102030405060708090a0b0c0d0e0f" + params['r1kh'] = "00:00:00:00:00:00 00:00:00:00:00:00 100102030405060708090a0b0c0d0e0f100102030405060708090a0b0c0d0e0f" + else: + params['r0kh'] = [ "02:00:00:00:03:00 nas1.w1.fi 100102030405060708090a0b0c0d0e0f100102030405060708090a0b0c0d0e0f", + "02:00:00:00:04:00 nas2.w1.fi 300102030405060708090a0b0c0d0e0f300102030405060708090a0b0c0d0e0f" ] + params['r1kh'] = "02:00:00:00:04:00 00:01:02:03:04:06 200102030405060708090a0b0c0d0e0f200102030405060708090a0b0c0d0e0f" return params def ft_params2a(rsn=True, ssid=None, passphrase=None): @@ -66,11 +70,15 @@ def ft_params2a(rsn=True, ssid=None, passphrase=None): params['r1_key_holder'] = "000102030406" return params -def ft_params2(rsn=True, ssid=None, passphrase=None): +def ft_params2(rsn=True, ssid=None, passphrase=None, discovery=False): params = ft_params2a(rsn, ssid, passphrase) - params['r0kh'] = [ "02:00:00:00:03:00 nas1.w1.fi 200102030405060708090a0b0c0d0e0f200102030405060708090a0b0c0d0e0f", - "02:00:00:00:04:00 nas2.w1.fi 000102030405060708090a0b0c0d0e0f000102030405060708090a0b0c0d0e0f" ] - params['r1kh'] = "02:00:00:00:03:00 00:01:02:03:04:05 300102030405060708090a0b0c0d0e0f300102030405060708090a0b0c0d0e0f" + if discovery: + params['r0kh'] = "ff:ff:ff:ff:ff:ff * 100102030405060708090a0b0c0d0e0f100102030405060708090a0b0c0d0e0f" + params['r1kh'] = "00:00:00:00:00:00 00:00:00:00:00:00 100102030405060708090a0b0c0d0e0f100102030405060708090a0b0c0d0e0f" + else: + params['r0kh'] = [ "02:00:00:00:03:00 nas1.w1.fi 200102030405060708090a0b0c0d0e0f200102030405060708090a0b0c0d0e0f", + "02:00:00:00:04:00 nas2.w1.fi 000102030405060708090a0b0c0d0e0f000102030405060708090a0b0c0d0e0f" ] + params['r1kh'] = "02:00:00:00:03:00 00:01:02:03:04:05 300102030405060708090a0b0c0d0e0f300102030405060708090a0b0c0d0e0f" return params def ft_params1_r0kh_mismatch(rsn=True, ssid=None, passphrase=None): @@ -479,13 +487,12 @@ def test_ap_ft_sae_over_ds(dev, apdev): run_roams(dev[0], apdev, hapd0, hapd1, ssid, passphrase, sae=True, over_ds=True) -def test_ap_ft_eap(dev, apdev): - """WPA2-EAP-FT AP""" +def generic_ap_ft_eap(dev, apdev, over_ds=False, discovery=False, roams=1): ssid = "test-ft" passphrase="12345678" radius = hostapd.radius_params() - params = ft_params1(ssid=ssid, passphrase=passphrase) + params = ft_params1(ssid=ssid, passphrase=passphrase, discovery=discovery) params['wpa_key_mgmt'] = "FT-EAP" params["ieee8021x"] = "1" params = dict(radius.items() + params.items()) @@ -493,13 +500,13 @@ def test_ap_ft_eap(dev, apdev): key_mgmt = hapd.get_config()['key_mgmt'] if key_mgmt.split(' ')[0] != "FT-EAP": raise Exception("Unexpected GET_CONFIG(key_mgmt): " + key_mgmt) - params = ft_params2(ssid=ssid, passphrase=passphrase) + params = ft_params2(ssid=ssid, passphrase=passphrase, discovery=discovery) params['wpa_key_mgmt'] = "FT-EAP" params["ieee8021x"] = "1" params = dict(radius.items() + params.items()) hapd1 = hostapd.add_ap(apdev[1], params) - run_roams(dev[0], apdev, hapd, hapd1, ssid, passphrase, eap=True) + run_roams(dev[0], apdev, hapd, hapd1, ssid, passphrase, eap=True, over_ds=over_ds, roams=roams) if "[WPA2-FT/EAP-CCMP]" not in dev[0].request("SCAN_RESULTS"): raise Exception("Scan results missing RSN element info") check_mib(dev[0], [ ("dot11RSNAAuthenticationSuiteRequested", "00-0f-ac-3"), @@ -520,6 +527,22 @@ def test_ap_ft_eap(dev, apdev): time.sleep(0.1) hwsim_utils.test_connectivity(dev[0], ap) +def test_ap_ft_eap(dev, apdev): + """WPA2-EAP-FT AP""" + generic_ap_ft_eap(dev, apdev) + +def test_ap_ft_eap_over_ds(dev, apdev): + """WPA2-EAP-FT AP w over_ds""" + generic_ap_ft_eap(dev, apdev, over_ds=True) + +def test_ap_ft_eap_dis(dev, apdev): + """WPA2-EAP-FT AP w discovery""" + generic_ap_ft_eap(dev, apdev, discovery=True) + +def test_ap_ft_eap_dis_over_ds(dev, apdev): + """WPA2-EAP-FT AP w discovery + over_ds""" + generic_ap_ft_eap(dev, apdev, over_ds=True, discovery=True) + def test_ap_ft_eap_pull(dev, apdev): """WPA2-EAP-FT AP (pull PMK)""" ssid = "test-ft"