1#!/usr/bin/python3.4
2#
3#   Copyright 2017 - The Android Open Source Project
4#
5#   Licensed under the Apache License, Version 2.0 (the "License");
6#   you may not use this file except in compliance with the License.
7#   You may obtain a copy of the License at
8#
9#       http://www.apache.org/licenses/LICENSE-2.0
10#
11#   Unless required by applicable law or agreed to in writing, software
12#   distributed under the License is distributed on an "AS IS" BASIS,
13#   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14#   See the License for the specific language governing permissions and
15#   limitations under the License.
16
17import sys
18import time
19
20from acts import asserts
21from acts.test_decorators import test_tracker_info
22from acts_contrib.test_utils.net import connectivity_const as cconsts
23from acts_contrib.test_utils.wifi.aware import aware_const as aconsts
24from acts_contrib.test_utils.wifi.aware import aware_test_utils as autils
25from acts_contrib.test_utils.wifi.aware.AwareBaseTest import AwareBaseTest
26from acts_contrib.test_utils.wifi.rtt import rtt_const as rconsts
27from acts_contrib.test_utils.wifi.rtt import rtt_test_utils as rutils
28from acts_contrib.test_utils.wifi.rtt.RttBaseTest import RttBaseTest
29
30
31class AwareDiscoveryWithRangingTest(AwareBaseTest, RttBaseTest):
32    """Set of tests for Wi-Fi Aware discovery configured with ranging (RTT)."""
33
34    SERVICE_NAME = "GoogleTestServiceRRRRR"
35
36    # Flag indicating whether the device has a limitation that does not allow it
37    # to execute Aware-based Ranging (whether direct or as part of discovery)
38    # whenever NDP is enabled.
39    RANGING_NDP_CONCURRENCY_LIMITATION = True
40
41    # Flag indicating whether the device has a limitation that does not allow it
42    # to execute Aware-based Ranging (whether direct or as part of discovery)
43    # for both Initiators and Responders. Only the first mode works.
44    RANGING_INITIATOR_RESPONDER_CONCURRENCY_LIMITATION = True
45
46    def setup_test(self):
47        """Manual setup here due to multiple inheritance: explicitly execute the
48    setup method from both parents."""
49        AwareBaseTest.setup_test(self)
50        RttBaseTest.setup_test(self)
51
52    def teardown_test(self):
53        """Manual teardown here due to multiple inheritance: explicitly execute the
54    teardown method from both parents."""
55        AwareBaseTest.teardown_test(self)
56        RttBaseTest.teardown_test(self)
57
58    #########################################################################
59
60    def run_discovery(self,
61                      p_config,
62                      s_config,
63                      expect_discovery,
64                      expect_range=False):
65        """Run discovery on the 2 input devices with the specified configurations.
66
67    Args:
68      p_config, s_config: Publisher and Subscriber discovery configuration.
69      expect_discovery: True or False indicating whether discovery is expected
70                        with the specified configurations.
71      expect_range: True if we expect distance results (i.e. ranging to happen).
72                    Only relevant if expect_discovery is True.
73    Returns:
74      p_dut, s_dut: Publisher/Subscribe DUT
75      p_disc_id, s_disc_id: Publisher/Subscribe discovery session ID
76    """
77        p_dut = self.android_devices[0]
78        p_dut.pretty_name = "Publisher"
79        s_dut = self.android_devices[1]
80        s_dut.pretty_name = "Subscriber"
81
82        # Publisher+Subscriber: attach and wait for confirmation
83        p_id = p_dut.droid.wifiAwareAttach(False)
84        autils.wait_for_event(p_dut, aconsts.EVENT_CB_ON_ATTACHED)
85        time.sleep(self.device_startup_offset)
86        s_id = s_dut.droid.wifiAwareAttach(False)
87        autils.wait_for_event(s_dut, aconsts.EVENT_CB_ON_ATTACHED)
88
89        # Publisher: start publish and wait for confirmation
90        p_disc_id = p_dut.droid.wifiAwarePublish(p_id, p_config)
91        autils.wait_for_event(p_dut, aconsts.SESSION_CB_ON_PUBLISH_STARTED)
92
93        # Subscriber: start subscribe and wait for confirmation
94        s_disc_id = s_dut.droid.wifiAwareSubscribe(s_id, s_config)
95        autils.wait_for_event(s_dut, aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED)
96
97        # Subscriber: wait or fail on service discovery
98        if expect_discovery:
99            event = autils.wait_for_event(
100                s_dut, aconsts.SESSION_CB_ON_SERVICE_DISCOVERED)
101            if expect_range:
102                asserts.assert_true(
103                    aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
104                    "Discovery with ranging expected!")
105            else:
106                asserts.assert_false(
107                    aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
108                    "Discovery with ranging NOT expected!")
109        else:
110            autils.fail_on_event(s_dut,
111                                 aconsts.SESSION_CB_ON_SERVICE_DISCOVERED)
112
113        # (single) sleep for timeout period and then verify that no further events
114        time.sleep(autils.EVENT_TIMEOUT)
115        autils.verify_no_more_events(p_dut, timeout=0)
116        autils.verify_no_more_events(s_dut, timeout=0)
117
118        return p_dut, s_dut, p_disc_id, s_disc_id
119
120    def run_discovery_update(self,
121                             p_dut,
122                             s_dut,
123                             p_disc_id,
124                             s_disc_id,
125                             p_config,
126                             s_config,
127                             expect_discovery,
128                             expect_range=False):
129        """Run discovery on the 2 input devices with the specified update
130    configurations. I.e. update the existing discovery sessions with the
131    configurations.
132
133    Args:
134      p_dut, s_dut: Publisher/Subscriber DUTs.
135      p_disc_id, s_disc_id: Publisher/Subscriber discovery session IDs.
136      p_config, s_config: Publisher and Subscriber discovery configuration.
137      expect_discovery: True or False indicating whether discovery is expected
138                        with the specified configurations.
139      expect_range: True if we expect distance results (i.e. ranging to happen).
140                    Only relevant if expect_discovery is True.
141    """
142
143        # try to perform reconfiguration at same time (and wait once for all
144        # confirmations)
145        if p_config is not None:
146            p_dut.droid.wifiAwareUpdatePublish(p_disc_id, p_config)
147        if s_config is not None:
148            s_dut.droid.wifiAwareUpdateSubscribe(s_disc_id, s_config)
149
150        if p_config is not None:
151            autils.wait_for_event(p_dut,
152                                  aconsts.SESSION_CB_ON_SESSION_CONFIG_UPDATED)
153        if s_config is not None:
154            autils.wait_for_event(s_dut,
155                                  aconsts.SESSION_CB_ON_SESSION_CONFIG_UPDATED)
156
157        # Subscriber: wait or fail on service discovery
158        if expect_discovery:
159            event = autils.wait_for_event(
160                s_dut, aconsts.SESSION_CB_ON_SERVICE_DISCOVERED)
161            if expect_range:
162                asserts.assert_true(
163                    aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
164                    "Discovery with ranging expected!")
165            else:
166                asserts.assert_false(
167                    aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
168                    "Discovery with ranging NOT expected!")
169        else:
170            autils.fail_on_event(s_dut,
171                                 aconsts.SESSION_CB_ON_SERVICE_DISCOVERED)
172
173        # (single) sleep for timeout period and then verify that no further events
174        time.sleep(autils.EVENT_TIMEOUT)
175        autils.verify_no_more_events(p_dut, timeout=0)
176        autils.verify_no_more_events(s_dut, timeout=0)
177
178    def run_discovery_prange_sminmax_outofrange(self, is_unsolicited_passive):
179        """Run discovery with ranging:
180    - Publisher enables ranging
181    - Subscriber enables ranging with min/max such that out of range (min=large,
182      max=large+1)
183
184    Expected: no discovery
185
186    This is a baseline test for the update-configuration tests.
187
188    Args:
189      is_unsolicited_passive: True for Unsolicited/Passive, False for
190                              Solicited/Active.
191    Returns: the return arguments of the run_discovery.
192    """
193        pub_type = (aconsts.PUBLISH_TYPE_UNSOLICITED if is_unsolicited_passive
194                    else aconsts.PUBLISH_TYPE_SOLICITED)
195        sub_type = (aconsts.SUBSCRIBE_TYPE_PASSIVE if is_unsolicited_passive
196                    else aconsts.SUBSCRIBE_TYPE_ACTIVE)
197        return self.run_discovery(
198            p_config=autils.add_ranging_to_pub(
199                autils.create_discovery_config(
200                    self.SERVICE_NAME, pub_type, ssi=self.getname(2)),
201                enable_ranging=True),
202            s_config=autils.add_ranging_to_sub(
203                autils.create_discovery_config(
204                    self.SERVICE_NAME, sub_type, ssi=self.getname(2)),
205                min_distance_mm=1000000,
206                max_distance_mm=1000001),
207            expect_discovery=False)
208
209    def getname(self, level=1):
210        """Python magic to return the name of the *calling* function.
211
212    Args:
213      level: How many levels up to go for the method name. Default = calling
214             method.
215    """
216        return sys._getframe(level).f_code.co_name
217
218    #########################################################################
219    # Run discovery with ranging configuration.
220    #
221    # Names: test_ranged_discovery_<ptype>_<stype>_<p_range>_<s_range>_<ref_dist>
222    #
223    # where:
224    # <ptype>_<stype>: unsolicited_passive or solicited_active
225    # <p_range>: prange or pnorange
226    # <s_range>: smin or smax or sminmax or snorange
227    # <ref_distance>: inrange or outoforange
228    #########################################################################
229
230    @test_tracker_info(uuid="3a216e9a-7a57-4741-89c0-84456975e1ac")
231    def test_ranged_discovery_unsolicited_passive_prange_snorange(self):
232        """Verify discovery with ranging:
233    - Unsolicited Publish/Passive Subscribe
234    - Publisher enables ranging
235    - Subscriber disables ranging
236
237    Expect: normal discovery (as if no ranging performed) - no distance
238    """
239        self.run_discovery(
240            p_config=autils.add_ranging_to_pub(
241                autils.create_discovery_config(
242                    self.SERVICE_NAME,
243                    aconsts.PUBLISH_TYPE_UNSOLICITED,
244                    ssi=self.getname()),
245                enable_ranging=True),
246            s_config=autils.create_discovery_config(
247                self.SERVICE_NAME,
248                aconsts.SUBSCRIBE_TYPE_PASSIVE,
249                ssi=self.getname()),
250            expect_discovery=True,
251            expect_range=False)
252
253    @test_tracker_info(uuid="859a321e-18e2-437b-aa7a-2a45a42ee737")
254    def test_ranged_discovery_solicited_active_prange_snorange(self):
255        """Verify discovery with ranging:
256    - Solicited Publish/Active Subscribe
257    - Publisher enables ranging
258    - Subscriber disables ranging
259
260    Expect: normal discovery (as if no ranging performed) - no distance
261    """
262        self.run_discovery(
263            p_config=autils.add_ranging_to_pub(
264                autils.create_discovery_config(
265                    self.SERVICE_NAME,
266                    aconsts.PUBLISH_TYPE_SOLICITED,
267                    ssi=self.getname()),
268                enable_ranging=True),
269            s_config=autils.create_discovery_config(
270                self.SERVICE_NAME,
271                aconsts.SUBSCRIBE_TYPE_ACTIVE,
272                ssi=self.getname()),
273            expect_discovery=True,
274            expect_range=False)
275
276    @test_tracker_info(uuid="12a4f899-4f70-4641-8f3c-351004669b71")
277    def test_ranged_discovery_unsolicited_passive_pnorange_smax_inrange(self):
278        """Verify discovery with ranging:
279    - Unsolicited Publish/Passive Subscribe
280    - Publisher disables ranging
281    - Subscriber enables ranging with max such that always within range (large
282      max)
283
284    Expect: normal discovery (as if no ranging performed) - no distance
285    """
286        self.run_discovery(
287            p_config=autils.add_ranging_to_pub(
288                autils.create_discovery_config(
289                    self.SERVICE_NAME,
290                    aconsts.PUBLISH_TYPE_UNSOLICITED,
291                    ssi=self.getname()),
292                enable_ranging=False),
293            s_config=autils.add_ranging_to_sub(
294                autils.create_discovery_config(
295                    self.SERVICE_NAME,
296                    aconsts.SUBSCRIBE_TYPE_PASSIVE,
297                    ssi=self.getname()),
298                min_distance_mm=None,
299                max_distance_mm=1000000),
300            expect_discovery=True,
301            expect_range=False)
302
303    @test_tracker_info(uuid="b7f90793-113d-4355-be20-856d92ac939f")
304    def test_ranged_discovery_solicited_active_pnorange_smax_inrange(self):
305        """Verify discovery with ranging:
306    - Solicited Publish/Active Subscribe
307    - Publisher disables ranging
308    - Subscriber enables ranging with max such that always within range (large
309      max)
310
311    Expect: normal discovery (as if no ranging performed) - no distance
312    """
313        self.run_discovery(
314            p_config=autils.add_ranging_to_pub(
315                autils.create_discovery_config(
316                    self.SERVICE_NAME,
317                    aconsts.PUBLISH_TYPE_SOLICITED,
318                    ssi=self.getname()),
319                enable_ranging=False),
320            s_config=autils.add_ranging_to_sub(
321                autils.create_discovery_config(
322                    self.SERVICE_NAME,
323                    aconsts.SUBSCRIBE_TYPE_ACTIVE,
324                    ssi=self.getname()),
325                min_distance_mm=None,
326                max_distance_mm=1000000),
327            expect_discovery=True,
328            expect_range=False)
329
330    @test_tracker_info(uuid="da3ab6df-58f9-44ae-b7be-8200d9e1bb76")
331    def test_ranged_discovery_unsolicited_passive_pnorange_smin_outofrange(
332            self):
333        """Verify discovery with ranging:
334    - Unsolicited Publish/Passive Subscribe
335    - Publisher disables ranging
336    - Subscriber enables ranging with min such that always out of range (large
337      min)
338
339    Expect: normal discovery (as if no ranging performed) - no distance
340    """
341        self.run_discovery(
342            p_config=autils.add_ranging_to_pub(
343                autils.create_discovery_config(
344                    self.SERVICE_NAME,
345                    aconsts.PUBLISH_TYPE_UNSOLICITED,
346                    ssi=self.getname()),
347                enable_ranging=False),
348            s_config=autils.add_ranging_to_sub(
349                autils.create_discovery_config(
350                    self.SERVICE_NAME,
351                    aconsts.SUBSCRIBE_TYPE_PASSIVE,
352                    ssi=self.getname()),
353                min_distance_mm=1000000,
354                max_distance_mm=None),
355            expect_discovery=True,
356            expect_range=False)
357
358    @test_tracker_info(uuid="275e0806-f266-4fa6-9ca0-1cfd7b65a6ca")
359    def test_ranged_discovery_solicited_active_pnorange_smin_outofrange(self):
360        """Verify discovery with ranging:
361    - Solicited Publish/Active Subscribe
362    - Publisher disables ranging
363    - Subscriber enables ranging with min such that always out of range (large
364      min)
365
366    Expect: normal discovery (as if no ranging performed) - no distance
367    """
368        self.run_discovery(
369            p_config=autils.add_ranging_to_pub(
370                autils.create_discovery_config(
371                    self.SERVICE_NAME,
372                    aconsts.PUBLISH_TYPE_SOLICITED,
373                    ssi=self.getname()),
374                enable_ranging=False),
375            s_config=autils.add_ranging_to_sub(
376                autils.create_discovery_config(
377                    self.SERVICE_NAME,
378                    aconsts.SUBSCRIBE_TYPE_ACTIVE,
379                    ssi=self.getname()),
380                min_distance_mm=1000000,
381                max_distance_mm=None),
382            expect_discovery=True,
383            expect_range=False)
384
385    @test_tracker_info(uuid="8cd0aa1e-6866-4a5d-a550-f25483eebea1")
386    def test_ranged_discovery_unsolicited_passive_prange_smin_inrange(self):
387        """Verify discovery with ranging:
388    - Unsolicited Publish/Passive Subscribe
389    - Publisher enables ranging
390    - Subscriber enables ranging with min such that in range (min=0)
391
392    Expect: discovery with distance
393    """
394        self.run_discovery(
395            p_config=autils.add_ranging_to_pub(
396                autils.create_discovery_config(
397                    self.SERVICE_NAME,
398                    aconsts.PUBLISH_TYPE_UNSOLICITED,
399                    ssi=self.getname()),
400                enable_ranging=True),
401            s_config=autils.add_ranging_to_sub(
402                autils.create_discovery_config(
403                    self.SERVICE_NAME,
404                    aconsts.SUBSCRIBE_TYPE_PASSIVE,
405                    ssi=self.getname()),
406                min_distance_mm=0,
407                max_distance_mm=None),
408            expect_discovery=True,
409            expect_range=True)
410
411    @test_tracker_info(uuid="97c22c54-669b-4f7a-bf51-2f484e5f3e74")
412    def test_ranged_discovery_unsolicited_passive_prange_smax_inrange(self):
413        """Verify discovery with ranging:
414    - Unsolicited Publish/Passive Subscribe
415    - Publisher enables ranging
416    - Subscriber enables ranging with max such that in range (max=large)
417
418    Expect: discovery with distance
419    """
420        self.run_discovery(
421            p_config=autils.add_ranging_to_pub(
422                autils.create_discovery_config(
423                    self.SERVICE_NAME,
424                    aconsts.PUBLISH_TYPE_UNSOLICITED,
425                    ssi=self.getname()),
426                enable_ranging=True),
427            s_config=autils.add_ranging_to_sub(
428                autils.create_discovery_config(
429                    self.SERVICE_NAME,
430                    aconsts.SUBSCRIBE_TYPE_PASSIVE,
431                    ssi=self.getname()),
432                min_distance_mm=None,
433                max_distance_mm=1000000),
434            expect_discovery=True,
435            expect_range=True)
436
437    @test_tracker_info(uuid="616673d7-9d0b-43de-a378-e5e949b51b32")
438    def test_ranged_discovery_unsolicited_passive_prange_sminmax_inrange(self):
439        """Verify discovery with ranging:
440    - Unsolicited Publish/Passive Subscribe
441    - Publisher enables ranging
442    - Subscriber enables ranging with min/max such that in range (min=0,
443      max=large)
444
445    Expect: discovery with distance
446    """
447        self.run_discovery(
448            p_config=autils.add_ranging_to_pub(
449                autils.create_discovery_config(
450                    self.SERVICE_NAME,
451                    aconsts.PUBLISH_TYPE_UNSOLICITED,
452                    ssi=self.getname()),
453                enable_ranging=True),
454            s_config=autils.add_ranging_to_sub(
455                autils.create_discovery_config(
456                    self.SERVICE_NAME,
457                    aconsts.SUBSCRIBE_TYPE_PASSIVE,
458                    ssi=self.getname()),
459                min_distance_mm=0,
460                max_distance_mm=1000000),
461            expect_discovery=True,
462            expect_range=True)
463
464    @test_tracker_info(uuid="2bf84912-dcad-4a8f-971f-e445a07f05ce")
465    def test_ranged_discovery_solicited_active_prange_smin_inrange(self):
466        """Verify discovery with ranging:
467    - Solicited Publish/Active Subscribe
468    - Publisher enables ranging
469    - Subscriber enables ranging with min such that in range (min=0)
470
471    Expect: discovery with distance
472    """
473        self.run_discovery(
474            p_config=autils.add_ranging_to_pub(
475                autils.create_discovery_config(
476                    self.SERVICE_NAME,
477                    aconsts.PUBLISH_TYPE_SOLICITED,
478                    ssi=self.getname()),
479                enable_ranging=True),
480            s_config=autils.add_ranging_to_sub(
481                autils.create_discovery_config(
482                    self.SERVICE_NAME,
483                    aconsts.SUBSCRIBE_TYPE_ACTIVE,
484                    ssi=self.getname()),
485                min_distance_mm=0,
486                max_distance_mm=None),
487            expect_discovery=True,
488            expect_range=True)
489
490    @test_tracker_info(uuid="5cfd7961-9665-4742-a1b5-2d1fc97f9795")
491    def test_ranged_discovery_solicited_active_prange_smax_inrange(self):
492        """Verify discovery with ranging:
493    - Solicited Publish/Active Subscribe
494    - Publisher enables ranging
495    - Subscriber enables ranging with max such that in range (max=large)
496
497    Expect: discovery with distance
498    """
499        self.run_discovery(
500            p_config=autils.add_ranging_to_pub(
501                autils.create_discovery_config(
502                    self.SERVICE_NAME,
503                    aconsts.PUBLISH_TYPE_SOLICITED,
504                    ssi=self.getname()),
505                enable_ranging=True),
506            s_config=autils.add_ranging_to_sub(
507                autils.create_discovery_config(
508                    self.SERVICE_NAME,
509                    aconsts.SUBSCRIBE_TYPE_ACTIVE,
510                    ssi=self.getname()),
511                min_distance_mm=None,
512                max_distance_mm=1000000),
513            expect_discovery=True,
514            expect_range=True)
515
516    @test_tracker_info(uuid="5cf650ad-0b42-4b7d-9e05-d5f45fe0554d")
517    def test_ranged_discovery_solicited_active_prange_sminmax_inrange(self):
518        """Verify discovery with ranging:
519    - Solicited Publish/Active Subscribe
520    - Publisher enables ranging
521    - Subscriber enables ranging with min/max such that in range (min=0,
522      max=large)
523
524    Expect: discovery with distance
525    """
526        self.run_discovery(
527            p_config=autils.add_ranging_to_pub(
528                autils.create_discovery_config(
529                    self.SERVICE_NAME,
530                    aconsts.PUBLISH_TYPE_SOLICITED,
531                    ssi=self.getname()),
532                enable_ranging=True),
533            s_config=autils.add_ranging_to_sub(
534                autils.create_discovery_config(
535                    self.SERVICE_NAME,
536                    aconsts.SUBSCRIBE_TYPE_ACTIVE,
537                    ssi=self.getname()),
538                min_distance_mm=0,
539                max_distance_mm=1000000),
540            expect_discovery=True,
541            expect_range=True)
542
543    @test_tracker_info(uuid="5277f418-ac35-43ce-9b30-3c895272898e")
544    def test_ranged_discovery_unsolicited_passive_prange_smin_outofrange(self):
545        """Verify discovery with ranging:
546    - Unsolicited Publish/Passive Subscribe
547    - Publisher enables ranging
548    - Subscriber enables ranging with min such that out of range (min=large)
549
550    Expect: no discovery
551    """
552        self.run_discovery(
553            p_config=autils.add_ranging_to_pub(
554                autils.create_discovery_config(
555                    self.SERVICE_NAME,
556                    aconsts.PUBLISH_TYPE_UNSOLICITED,
557                    ssi=self.getname()),
558                enable_ranging=True),
559            s_config=autils.add_ranging_to_sub(
560                autils.create_discovery_config(
561                    self.SERVICE_NAME,
562                    aconsts.SUBSCRIBE_TYPE_PASSIVE,
563                    ssi=self.getname()),
564                min_distance_mm=1000000,
565                max_distance_mm=None),
566            expect_discovery=False)
567
568    @test_tracker_info(uuid="8a7e6ab1-acf4-41a7-a5fb-8c164d593b5f")
569    def test_ranged_discovery_unsolicited_passive_prange_smax_outofrange(self):
570        """Verify discovery with ranging:
571    - Unsolicited Publish/Passive Subscribe
572    - Publisher enables ranging
573    - Subscriber enables ranging with max such that in range (max=0)
574
575    Expect: no discovery
576    """
577        self.run_discovery(
578            p_config=autils.add_ranging_to_pub(
579                autils.create_discovery_config(
580                    self.SERVICE_NAME,
581                    aconsts.PUBLISH_TYPE_UNSOLICITED,
582                    ssi=self.getname()),
583                enable_ranging=True),
584            s_config=autils.add_ranging_to_sub(
585                autils.create_discovery_config(
586                    self.SERVICE_NAME,
587                    aconsts.SUBSCRIBE_TYPE_PASSIVE,
588                    ssi=self.getname()),
589                min_distance_mm=None,
590                max_distance_mm=0),
591            expect_discovery=False)
592
593    @test_tracker_info(uuid="b744f5f9-2641-4373-bf86-3752e2f9aace")
594    def test_ranged_discovery_unsolicited_passive_prange_sminmax_outofrange(
595            self):
596        """Verify discovery with ranging:
597    - Unsolicited Publish/Passive Subscribe
598    - Publisher enables ranging
599    - Subscriber enables ranging with min/max such that out of range (min=large,
600      max=large+1)
601
602    Expect: no discovery
603    """
604        self.run_discovery(
605            p_config=autils.add_ranging_to_pub(
606                autils.create_discovery_config(
607                    self.SERVICE_NAME,
608                    aconsts.PUBLISH_TYPE_UNSOLICITED,
609                    ssi=self.getname()),
610                enable_ranging=True),
611            s_config=autils.add_ranging_to_sub(
612                autils.create_discovery_config(
613                    self.SERVICE_NAME,
614                    aconsts.SUBSCRIBE_TYPE_PASSIVE,
615                    ssi=self.getname()),
616                min_distance_mm=1000000,
617                max_distance_mm=1000001),
618            expect_discovery=False)
619
620    @test_tracker_info(uuid="d2e94199-b2e6-4fa5-a347-24594883c801")
621    def test_ranged_discovery_solicited_active_prange_smin_outofrange(self):
622        """Verify discovery with ranging:
623    - Solicited Publish/Active Subscribe
624    - Publisher enables ranging
625    - Subscriber enables ranging with min such that out of range (min=large)
626
627    Expect: no discovery
628    """
629        self.run_discovery(
630            p_config=autils.add_ranging_to_pub(
631                autils.create_discovery_config(
632                    self.SERVICE_NAME,
633                    aconsts.PUBLISH_TYPE_SOLICITED,
634                    ssi=self.getname()),
635                enable_ranging=True),
636            s_config=autils.add_ranging_to_sub(
637                autils.create_discovery_config(
638                    self.SERVICE_NAME,
639                    aconsts.SUBSCRIBE_TYPE_ACTIVE,
640                    ssi=self.getname()),
641                min_distance_mm=1000000,
642                max_distance_mm=None),
643            expect_discovery=False)
644
645    @test_tracker_info(uuid="a5619835-496a-4244-a428-f85cba3d4115")
646    def test_ranged_discovery_solicited_active_prange_smax_outofrange(self):
647        """Verify discovery with ranging:
648    - Solicited Publish/Active Subscribe
649    - Publisher enables ranging
650    - Subscriber enables ranging with max such that out of range (max=0)
651
652    Expect: no discovery
653    """
654        self.run_discovery(
655            p_config=autils.add_ranging_to_pub(
656                autils.create_discovery_config(
657                    self.SERVICE_NAME,
658                    aconsts.PUBLISH_TYPE_SOLICITED,
659                    ssi=self.getname()),
660                enable_ranging=True),
661            s_config=autils.add_ranging_to_sub(
662                autils.create_discovery_config(
663                    self.SERVICE_NAME,
664                    aconsts.SUBSCRIBE_TYPE_ACTIVE,
665                    ssi=self.getname()),
666                min_distance_mm=None,
667                max_distance_mm=0),
668            expect_discovery=False)
669
670    @test_tracker_info(uuid="12ebd91f-a973-410b-8ee1-0bd86024b921")
671    def test_ranged_discovery_solicited_active_prange_sminmax_outofrange(self):
672        """Verify discovery with ranging:
673    - Solicited Publish/Active Subscribe
674    - Publisher enables ranging
675    - Subscriber enables ranging with min/max such that out of range (min=large,
676      max=large+1)
677
678    Expect: no discovery
679    """
680        self.run_discovery(
681            p_config=autils.add_ranging_to_pub(
682                autils.create_discovery_config(
683                    self.SERVICE_NAME,
684                    aconsts.PUBLISH_TYPE_SOLICITED,
685                    ssi=self.getname()),
686                enable_ranging=True),
687            s_config=autils.add_ranging_to_sub(
688                autils.create_discovery_config(
689                    self.SERVICE_NAME,
690                    aconsts.SUBSCRIBE_TYPE_ACTIVE,
691                    ssi=self.getname()),
692                min_distance_mm=1000000,
693                max_distance_mm=1000001),
694            expect_discovery=False)
695
696    #########################################################################
697    # Run discovery with ranging configuration & update configurations after
698    # first run.
699    #
700    # Names: test_ranged_updated_discovery_<ptype>_<stype>_<scenario>
701    #
702    # where:
703    # <ptype>_<stype>: unsolicited_passive or solicited_active
704    # <scenario>: test scenario (details in name)
705    #########################################################################
706
707    @test_tracker_info(uuid="59442180-4a6c-428f-b926-86000e8339b4")
708    def test_ranged_updated_discovery_unsolicited_passive_oor_to_ir(self):
709        """Verify discovery with ranging operation with updated configuration:
710    - Unsolicited Publish/Passive Subscribe
711    - Publisher enables ranging
712    - Subscriber:
713      - Starts: Ranging enabled, min/max such that out of range (min=large,
714                max=large+1)
715      - Reconfigured to: Ranging enabled, min/max such that in range (min=0,
716                        max=large)
717
718    Expect: discovery + ranging after update
719    """
720        (p_dut, s_dut, p_disc_id,
721         s_disc_id) = self.run_discovery_prange_sminmax_outofrange(True)
722        self.run_discovery_update(
723            p_dut,
724            s_dut,
725            p_disc_id,
726            s_disc_id,
727            p_config=None,  # no updates
728            s_config=autils.add_ranging_to_sub(
729                autils.create_discovery_config(
730                    self.SERVICE_NAME,
731                    aconsts.SUBSCRIBE_TYPE_PASSIVE,
732                    ssi=self.getname()),
733                min_distance_mm=0,
734                max_distance_mm=1000000),
735            expect_discovery=True,
736            expect_range=True)
737
738    @test_tracker_info(uuid="60188508-104d-42d5-ac3a-3605093c45d7")
739    def test_ranged_updated_discovery_unsolicited_passive_pub_unrange(self):
740        """Verify discovery with ranging operation with updated configuration:
741    - Unsolicited Publish/Passive Subscribe
742    - Publisher enables ranging
743    - Subscriber: Ranging enabled, min/max such that out of range (min=large,
744                  max=large+1)
745    - Reconfigured to: Publisher disables ranging
746
747    Expect: discovery w/o ranging after update
748    """
749        (p_dut, s_dut, p_disc_id,
750         s_disc_id) = self.run_discovery_prange_sminmax_outofrange(True)
751        self.run_discovery_update(
752            p_dut,
753            s_dut,
754            p_disc_id,
755            s_disc_id,
756            p_config=autils.create_discovery_config(
757                self.SERVICE_NAME,
758                aconsts.PUBLISH_TYPE_UNSOLICITED,
759                ssi=self.getname()),
760            s_config=None,  # no updates
761            expect_discovery=True,
762            expect_range=False)
763
764    @test_tracker_info(uuid="f96b434e-751d-4eb5-ae01-0c5c3a6fb4a2")
765    def test_ranged_updated_discovery_unsolicited_passive_sub_unrange(self):
766        """Verify discovery with ranging operation with updated configuration:
767    - Unsolicited Publish/Passive Subscribe
768    - Publisher enables ranging
769    - Subscriber:
770      - Starts: Ranging enabled, min/max such that out of range (min=large,
771                max=large+1)
772      - Reconfigured to: Ranging disabled
773
774    Expect: discovery w/o ranging after update
775    """
776        (p_dut, s_dut, p_disc_id,
777         s_disc_id) = self.run_discovery_prange_sminmax_outofrange(True)
778        self.run_discovery_update(
779            p_dut,
780            s_dut,
781            p_disc_id,
782            s_disc_id,
783            p_config=None,  # no updates
784            s_config=autils.create_discovery_config(
785                self.SERVICE_NAME,
786                aconsts.SUBSCRIBE_TYPE_PASSIVE,
787                ssi=self.getname()),
788            expect_discovery=True,
789            expect_range=False)
790
791    @test_tracker_info(uuid="78970de8-9362-4647-931a-3513bcf58e80")
792    def test_ranged_updated_discovery_unsolicited_passive_sub_oor(self):
793        """Verify discovery with ranging operation with updated configuration:
794    - Unsolicited Publish/Passive Subscribe
795    - Publisher enables ranging
796    - Subscriber:
797      - Starts: Ranging enabled, min/max such that out of range (min=large,
798                max=large+1)
799      - Reconfigured to: different out-of-range setting
800
801    Expect: no discovery after update
802    """
803        (p_dut, s_dut, p_disc_id,
804         s_disc_id) = self.run_discovery_prange_sminmax_outofrange(True)
805        self.run_discovery_update(
806            p_dut,
807            s_dut,
808            p_disc_id,
809            s_disc_id,
810            p_config=None,  # no updates
811            s_config=autils.add_ranging_to_sub(
812                autils.create_discovery_config(
813                    self.SERVICE_NAME,
814                    aconsts.SUBSCRIBE_TYPE_PASSIVE,
815                    ssi=self.getname()),
816                min_distance_mm=100000,
817                max_distance_mm=100001),
818            expect_discovery=False)
819
820    @test_tracker_info(uuid="0841ad05-4899-4521-bd24-04a8e2e345ac")
821    def test_ranged_updated_discovery_unsolicited_passive_pub_same(self):
822        """Verify discovery with ranging operation with updated configuration:
823    - Unsolicited Publish/Passive Subscribe
824    - Publisher enables ranging
825    - Subscriber: Ranging enabled, min/max such that out of range (min=large,
826                  max=large+1)
827    - Reconfigured to: Publisher with same settings (ranging enabled)
828
829    Expect: no discovery after update
830    """
831        (p_dut, s_dut, p_disc_id,
832         s_disc_id) = self.run_discovery_prange_sminmax_outofrange(True)
833        self.run_discovery_update(
834            p_dut,
835            s_dut,
836            p_disc_id,
837            s_disc_id,
838            p_config=autils.add_ranging_to_pub(
839                autils.create_discovery_config(
840                    self.SERVICE_NAME,
841                    aconsts.PUBLISH_TYPE_UNSOLICITED,
842                    ssi=self.getname()),
843                enable_ranging=True),
844            s_config=None,  # no updates
845            expect_discovery=False)
846
847    @test_tracker_info(uuid="ec6ca57b-f115-4516-813a-4572b930c8d3")
848    def test_ranged_updated_discovery_unsolicited_passive_multi_step(self):
849        """Verify discovery with ranging operation with updated configuration:
850    - Unsolicited Publish/Passive Subscribe
851    - Publisher enables ranging
852    - Subscriber: Ranging enabled, min/max such that out of range (min=large,
853                  max=large+1)
854      - Expect: no discovery
855    - Reconfigured to: Ranging enabled, min/max such that in-range (min=0)
856      - Expect: discovery with ranging
857    - Reconfigured to: Ranging enabled, min/max such that out-of-range
858                       (min=large)
859      - Expect: no discovery
860    - Reconfigured to: Ranging disabled
861      - Expect: discovery without ranging
862    """
863        (p_dut, s_dut, p_disc_id,
864         s_disc_id) = self.run_discovery_prange_sminmax_outofrange(True)
865        self.run_discovery_update(
866            p_dut,
867            s_dut,
868            p_disc_id,
869            s_disc_id,
870            p_config=None,  # no updates
871            s_config=autils.add_ranging_to_sub(
872                autils.create_discovery_config(
873                    self.SERVICE_NAME,
874                    aconsts.SUBSCRIBE_TYPE_PASSIVE,
875                    ssi=self.getname()),
876                min_distance_mm=0,
877                max_distance_mm=None),
878            expect_discovery=True,
879            expect_range=True)
880        self.run_discovery_update(
881            p_dut,
882            s_dut,
883            p_disc_id,
884            s_disc_id,
885            p_config=None,  # no updates
886            s_config=autils.add_ranging_to_sub(
887                autils.create_discovery_config(
888                    self.SERVICE_NAME,
889                    aconsts.SUBSCRIBE_TYPE_PASSIVE,
890                    ssi=self.getname()),
891                min_distance_mm=1000000,
892                max_distance_mm=None),
893            expect_discovery=False)
894        self.run_discovery_update(
895            p_dut,
896            s_dut,
897            p_disc_id,
898            s_disc_id,
899            p_config=None,  # no updates
900            s_config=autils.create_discovery_config(
901                self.SERVICE_NAME,
902                aconsts.SUBSCRIBE_TYPE_PASSIVE,
903                ssi=self.getname()),
904            expect_discovery=True,
905            expect_range=False)
906
907    @test_tracker_info(uuid="bbaac63b-000c-415f-bf19-0906f04031cd")
908    def test_ranged_updated_discovery_solicited_active_oor_to_ir(self):
909        """Verify discovery with ranging operation with updated configuration:
910    - Solicited Publish/Active Subscribe
911    - Publisher enables ranging
912    - Subscriber:
913      - Starts: Ranging enabled, min/max such that out of range (min=large,
914                max=large+1)
915      - Reconfigured to: Ranging enabled, min/max such that in range (min=0,
916                        max=large)
917
918    Expect: discovery + ranging after update
919    """
920        (p_dut, s_dut, p_disc_id,
921         s_disc_id) = self.run_discovery_prange_sminmax_outofrange(False)
922        self.run_discovery_update(
923            p_dut,
924            s_dut,
925            p_disc_id,
926            s_disc_id,
927            p_config=None,  # no updates
928            s_config=autils.add_ranging_to_sub(
929                autils.create_discovery_config(
930                    self.SERVICE_NAME,
931                    aconsts.SUBSCRIBE_TYPE_ACTIVE,
932                    ssi=self.getname()),
933                min_distance_mm=0,
934                max_distance_mm=1000000),
935            expect_discovery=True,
936            expect_range=True)
937
938    @test_tracker_info(uuid="c385b361-7955-4f34-9109-8d8ca81cb4cc")
939    def test_ranged_updated_discovery_solicited_active_pub_unrange(self):
940        """Verify discovery with ranging operation with updated configuration:
941    - Solicited Publish/Active Subscribe
942    - Publisher enables ranging
943    - Subscriber: Ranging enabled, min/max such that out of range (min=large,
944                  max=large+1)
945    - Reconfigured to: Publisher disables ranging
946
947    Expect: discovery w/o ranging after update
948    """
949        (p_dut, s_dut, p_disc_id,
950         s_disc_id) = self.run_discovery_prange_sminmax_outofrange(False)
951        self.run_discovery_update(
952            p_dut,
953            s_dut,
954            p_disc_id,
955            s_disc_id,
956            p_config=autils.create_discovery_config(
957                self.SERVICE_NAME,
958                aconsts.PUBLISH_TYPE_SOLICITED,
959                ssi=self.getname()),
960            s_config=None,  # no updates
961            expect_discovery=True,
962            expect_range=False)
963
964    @test_tracker_info(uuid="ec5120ea-77ec-48c6-8820-48b82ad3dfd4")
965    def test_ranged_updated_discovery_solicited_active_sub_unrange(self):
966        """Verify discovery with ranging operation with updated configuration:
967    - Solicited Publish/Active Subscribe
968    - Publisher enables ranging
969    - Subscriber:
970      - Starts: Ranging enabled, min/max such that out of range (min=large,
971                max=large+1)
972      - Reconfigured to: Ranging disabled
973
974    Expect: discovery w/o ranging after update
975    """
976        (p_dut, s_dut, p_disc_id,
977         s_disc_id) = self.run_discovery_prange_sminmax_outofrange(False)
978        self.run_discovery_update(
979            p_dut,
980            s_dut,
981            p_disc_id,
982            s_disc_id,
983            p_config=None,  # no updates
984            s_config=autils.create_discovery_config(
985                self.SERVICE_NAME,
986                aconsts.SUBSCRIBE_TYPE_ACTIVE,
987                ssi=self.getname()),
988            expect_discovery=True,
989            expect_range=False)
990
991    @test_tracker_info(uuid="6231cb42-91e4-48d3-b9db-b37efbe8537c")
992    def test_ranged_updated_discovery_solicited_active_sub_oor(self):
993        """Verify discovery with ranging operation with updated configuration:
994    - Solicited Publish/Active Subscribe
995    - Publisher enables ranging
996    - Subscriber:
997      - Starts: Ranging enabled, min/max such that out of range (min=large,
998                max=large+1)
999      - Reconfigured to: different out-of-range setting
1000
1001    Expect: no discovery after update
1002    """
1003        (p_dut, s_dut, p_disc_id,
1004         s_disc_id) = self.run_discovery_prange_sminmax_outofrange(False)
1005        self.run_discovery_update(
1006            p_dut,
1007            s_dut,
1008            p_disc_id,
1009            s_disc_id,
1010            p_config=None,  # no updates
1011            s_config=autils.add_ranging_to_sub(
1012                autils.create_discovery_config(
1013                    self.SERVICE_NAME,
1014                    aconsts.SUBSCRIBE_TYPE_ACTIVE,
1015                    ssi=self.getname()),
1016                min_distance_mm=100000,
1017                max_distance_mm=100001),
1018            expect_discovery=False)
1019
1020    @test_tracker_info(uuid="ec999420-6a50-455e-b624-f4c9b4cb7ea5")
1021    def test_ranged_updated_discovery_solicited_active_pub_same(self):
1022        """Verify discovery with ranging operation with updated configuration:
1023    - Solicited Publish/Active Subscribe
1024    - Publisher enables ranging
1025    - Subscriber: Ranging enabled, min/max such that out of range (min=large,
1026                  max=large+1)
1027    - Reconfigured to: Publisher with same settings (ranging enabled)
1028
1029    Expect: no discovery after update
1030    """
1031        (p_dut, s_dut, p_disc_id,
1032         s_disc_id) = self.run_discovery_prange_sminmax_outofrange(False)
1033        self.run_discovery_update(
1034            p_dut,
1035            s_dut,
1036            p_disc_id,
1037            s_disc_id,
1038            p_config=autils.add_ranging_to_pub(
1039                autils.create_discovery_config(
1040                    self.SERVICE_NAME,
1041                    aconsts.PUBLISH_TYPE_SOLICITED,
1042                    ssi=self.getname()),
1043                enable_ranging=True),
1044            s_config=None,  # no updates
1045            expect_discovery=False)
1046
1047    @test_tracker_info(uuid="3938a3dc-8032-4096-b184-b528e4564b5e")
1048    def test_ranged_updated_discovery_solicited_active_multi_step(self):
1049        """Verify discovery with ranging operation with updated configuration:
1050    - Unsolicited Publish/Passive Subscribe
1051    - Publisher enables ranging
1052    - Subscriber: Ranging enabled, min/max such that out of range (min=large,
1053                  max=large+1)
1054      - Expect: no discovery
1055    - Reconfigured to: Ranging enabled, min/max such that in-range (min=0)
1056      - Expect: discovery with ranging
1057    - Reconfigured to: Ranging enabled, min/max such that out-of-range
1058                       (min=large)
1059      - Expect: no discovery
1060    - Reconfigured to: Ranging disabled
1061      - Expect: discovery without ranging
1062    """
1063        (p_dut, s_dut, p_disc_id,
1064         s_disc_id) = self.run_discovery_prange_sminmax_outofrange(True)
1065        self.run_discovery_update(
1066            p_dut,
1067            s_dut,
1068            p_disc_id,
1069            s_disc_id,
1070            p_config=None,  # no updates
1071            s_config=autils.add_ranging_to_sub(
1072                autils.create_discovery_config(
1073                    self.SERVICE_NAME,
1074                    aconsts.SUBSCRIBE_TYPE_ACTIVE,
1075                    ssi=self.getname()),
1076                min_distance_mm=0,
1077                max_distance_mm=None),
1078            expect_discovery=True,
1079            expect_range=True)
1080        self.run_discovery_update(
1081            p_dut,
1082            s_dut,
1083            p_disc_id,
1084            s_disc_id,
1085            p_config=None,  # no updates
1086            s_config=autils.add_ranging_to_sub(
1087                autils.create_discovery_config(
1088                    self.SERVICE_NAME,
1089                    aconsts.SUBSCRIBE_TYPE_ACTIVE,
1090                    ssi=self.getname()),
1091                min_distance_mm=1000000,
1092                max_distance_mm=None),
1093            expect_discovery=False)
1094        self.run_discovery_update(
1095            p_dut,
1096            s_dut,
1097            p_disc_id,
1098            s_disc_id,
1099            p_config=None,  # no updates
1100            s_config=autils.create_discovery_config(
1101                self.SERVICE_NAME,
1102                aconsts.SUBSCRIBE_TYPE_ACTIVE,
1103                ssi=self.getname()),
1104            expect_discovery=True,
1105            expect_range=False)
1106
1107    #########################################################################
1108
1109    @test_tracker_info(uuid="6edc47ab-7300-4bff-b7dd-5de83f58928a")
1110    def test_ranged_discovery_multi_session(self):
1111        """Verify behavior with multiple concurrent discovery session with different
1112    configurations:
1113
1114    Device A (Publisher):
1115      Publisher AA: ranging enabled
1116      Publisher BB: ranging enabled
1117      Publisher CC: ranging enabled
1118      Publisher DD: ranging disabled
1119    Device B (Subscriber):
1120      Subscriber AA: ranging out-of-range -> no match
1121      Subscriber BB: ranging in-range -> match w/range
1122      Subscriber CC: ranging disabled -> match w/o range
1123      Subscriber DD: ranging out-of-range -> match w/o range
1124    """
1125        p_dut = self.android_devices[0]
1126        p_dut.pretty_name = "Publisher"
1127        s_dut = self.android_devices[1]
1128        s_dut.pretty_name = "Subscriber"
1129
1130        # Publisher+Subscriber: attach and wait for confirmation
1131        p_id = p_dut.droid.wifiAwareAttach(False)
1132        autils.wait_for_event(p_dut, aconsts.EVENT_CB_ON_ATTACHED)
1133        time.sleep(self.device_startup_offset)
1134        s_id = s_dut.droid.wifiAwareAttach(False)
1135        autils.wait_for_event(s_dut, aconsts.EVENT_CB_ON_ATTACHED)
1136
1137        # Subscriber: start sessions
1138        aa_s_disc_id = s_dut.droid.wifiAwareSubscribe(
1139            s_id,
1140            autils.add_ranging_to_sub(
1141                autils.create_discovery_config("AA",
1142                                               aconsts.SUBSCRIBE_TYPE_PASSIVE),
1143                min_distance_mm=1000000,
1144                max_distance_mm=1000001), True)
1145        bb_s_disc_id = s_dut.droid.wifiAwareSubscribe(
1146            s_id,
1147            autils.add_ranging_to_sub(
1148                autils.create_discovery_config("BB",
1149                                               aconsts.SUBSCRIBE_TYPE_PASSIVE),
1150                min_distance_mm=0,
1151                max_distance_mm=1000000), True)
1152        cc_s_disc_id = s_dut.droid.wifiAwareSubscribe(
1153            s_id,
1154            autils.create_discovery_config(
1155                "CC", aconsts.SUBSCRIBE_TYPE_PASSIVE), True)
1156        dd_s_disc_id = s_dut.droid.wifiAwareSubscribe(
1157            s_id,
1158            autils.add_ranging_to_sub(
1159                autils.create_discovery_config("DD",
1160                                               aconsts.SUBSCRIBE_TYPE_PASSIVE),
1161                min_distance_mm=1000000,
1162                max_distance_mm=1000001), True)
1163
1164        autils.wait_for_event(
1165            s_dut,
1166            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1167                                  aa_s_disc_id))
1168        autils.wait_for_event(
1169            s_dut,
1170            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1171                                  bb_s_disc_id))
1172        autils.wait_for_event(
1173            s_dut,
1174            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1175                                  cc_s_disc_id))
1176        autils.wait_for_event(
1177            s_dut,
1178            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1179                                  dd_s_disc_id))
1180
1181        # Publisher: start sessions
1182        aa_p_disc_id = p_dut.droid.wifiAwarePublish(
1183            p_id,
1184            autils.add_ranging_to_pub(
1185                autils.create_discovery_config(
1186                    "AA", aconsts.PUBLISH_TYPE_UNSOLICITED),
1187                enable_ranging=True), True)
1188        bb_p_disc_id = p_dut.droid.wifiAwarePublish(
1189            p_id,
1190            autils.add_ranging_to_pub(
1191                autils.create_discovery_config(
1192                    "BB", aconsts.PUBLISH_TYPE_UNSOLICITED),
1193                enable_ranging=True), True)
1194        cc_p_disc_id = p_dut.droid.wifiAwarePublish(
1195            p_id,
1196            autils.add_ranging_to_pub(
1197                autils.create_discovery_config(
1198                    "CC", aconsts.PUBLISH_TYPE_UNSOLICITED),
1199                enable_ranging=True), True)
1200        dd_p_disc_id = p_dut.droid.wifiAwarePublish(
1201            p_id,
1202            autils.create_discovery_config(
1203                "DD", aconsts.PUBLISH_TYPE_UNSOLICITED), True)
1204
1205        autils.wait_for_event(
1206            p_dut,
1207            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1208                                  aa_p_disc_id))
1209        autils.wait_for_event(
1210            p_dut,
1211            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1212                                  bb_p_disc_id))
1213        autils.wait_for_event(
1214            p_dut,
1215            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1216                                  cc_p_disc_id))
1217        autils.wait_for_event(
1218            p_dut,
1219            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1220                                  dd_p_disc_id))
1221
1222        # Expected and unexpected service discovery
1223        event = autils.wait_for_event(
1224            s_dut,
1225            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1226                                  bb_s_disc_id))
1227        asserts.assert_true(
1228            aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1229            "Discovery with ranging for BB expected!")
1230        event = autils.wait_for_event(
1231            s_dut,
1232            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1233                                  cc_s_disc_id))
1234        asserts.assert_false(
1235            aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1236            "Discovery with ranging for CC NOT expected!")
1237        event = autils.wait_for_event(
1238            s_dut,
1239            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1240                                  dd_s_disc_id))
1241        asserts.assert_false(
1242            aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1243            "Discovery with ranging for DD NOT expected!")
1244        autils.fail_on_event(
1245            s_dut,
1246            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1247                                  aa_s_disc_id))
1248
1249        # (single) sleep for timeout period and then verify that no further events
1250        time.sleep(autils.EVENT_TIMEOUT)
1251        autils.verify_no_more_events(p_dut, timeout=0)
1252        autils.verify_no_more_events(s_dut, timeout=0)
1253
1254    #########################################################################
1255
1256    @test_tracker_info(uuid="deede47f-a54c-46d9-88bb-f4482fbd8470")
1257    def test_ndp_concurrency(self):
1258        """Verify the behavior of Wi-Fi Aware Ranging whenever an NDP is created -
1259    for those devices that have a concurrency limitation that does not allow
1260    Aware Ranging, whether direct or as part of discovery.
1261
1262    Publisher: start 3 services
1263      AA w/o ranging
1264      BB w/ ranging
1265      CC w/ ranging
1266      DD w/ ranging
1267    Subscriber: start 2 services
1268      AA w/o ranging
1269      BB w/ ranging out-of-range
1270      (do not start CC!)
1271      DD w/ ranging in-range
1272    Expect AA discovery, DD discovery w/range, but no BB
1273    Start NDP in context of AA
1274    IF NDP_CONCURRENCY_LIMITATION:
1275      Verify discovery on BB w/o range
1276    Start EE w/ranging out-of-range
1277    Start FF w/ranging in-range
1278    IF NDP_CONCURRENCY_LIMITATION:
1279      Verify discovery on EE w/o range
1280      Verify discovery on FF w/o range
1281    Else:
1282      Verify discovery on FF w/ range
1283    Tear down NDP
1284    Subscriber
1285      Start CC w/ ranging out-of-range
1286      Wait to verify that do not get match
1287      Update configuration to be in-range
1288      Verify that get match with ranging information
1289    """
1290        p_dut = self.android_devices[0]
1291        p_dut.pretty_name = "Publisher"
1292        s_dut = self.android_devices[1]
1293        s_dut.pretty_name = "Subscriber"
1294
1295        # Publisher+Subscriber: attach and wait for confirmation
1296        p_id = p_dut.droid.wifiAwareAttach(False)
1297        autils.wait_for_event(p_dut, aconsts.EVENT_CB_ON_ATTACHED)
1298        time.sleep(self.device_startup_offset)
1299        s_id = s_dut.droid.wifiAwareAttach(False)
1300        autils.wait_for_event(s_dut, aconsts.EVENT_CB_ON_ATTACHED)
1301
1302        # Publisher: AA w/o ranging, BB w/ ranging, CC w/ ranging, DD w/ ranging
1303        aa_p_id = p_dut.droid.wifiAwarePublish(
1304            p_id,
1305            autils.create_discovery_config(
1306                "AA", aconsts.PUBLISH_TYPE_SOLICITED), True)
1307        autils.wait_for_event(
1308            p_dut,
1309            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1310                                  aa_p_id))
1311        bb_p_id = p_dut.droid.wifiAwarePublish(
1312            p_id,
1313            autils.add_ranging_to_pub(
1314                autils.create_discovery_config(
1315                    "BB", aconsts.PUBLISH_TYPE_UNSOLICITED),
1316                enable_ranging=True), True)
1317        autils.wait_for_event(
1318            p_dut,
1319            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1320                                  bb_p_id))
1321        cc_p_id = p_dut.droid.wifiAwarePublish(
1322            p_id,
1323            autils.add_ranging_to_pub(
1324                autils.create_discovery_config(
1325                    "CC", aconsts.PUBLISH_TYPE_UNSOLICITED),
1326                enable_ranging=True), True)
1327        autils.wait_for_event(
1328            p_dut,
1329            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1330                                  cc_p_id))
1331        dd_p_id = p_dut.droid.wifiAwarePublish(
1332            p_id,
1333            autils.add_ranging_to_pub(
1334                autils.create_discovery_config(
1335                    "DD", aconsts.PUBLISH_TYPE_UNSOLICITED),
1336                enable_ranging=True), True)
1337        autils.wait_for_event(
1338            p_dut,
1339            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1340                                  dd_p_id))
1341
1342        # Subscriber: AA w/o ranging, BB w/ranging out-of-range,
1343        #             DD w /ranging in-range
1344        aa_s_id = s_dut.droid.wifiAwareSubscribe(
1345            s_id,
1346            autils.create_discovery_config(
1347                "AA", aconsts.SUBSCRIBE_TYPE_ACTIVE), True)
1348        autils.wait_for_event(
1349            s_dut,
1350            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1351                                  aa_s_id))
1352        bb_s_id = s_dut.droid.wifiAwareSubscribe(
1353            s_id,
1354            autils.add_ranging_to_sub(
1355                autils.create_discovery_config("BB",
1356                                               aconsts.SUBSCRIBE_TYPE_PASSIVE),
1357                min_distance_mm=1000000,
1358                max_distance_mm=1000001), True)
1359        autils.wait_for_event(
1360            s_dut,
1361            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1362                                  bb_s_id))
1363        dd_s_id = s_dut.droid.wifiAwareSubscribe(
1364            s_id,
1365            autils.add_ranging_to_sub(
1366                autils.create_discovery_config("DD",
1367                                               aconsts.SUBSCRIBE_TYPE_PASSIVE),
1368                min_distance_mm=None,
1369                max_distance_mm=1000000), True)
1370        autils.wait_for_event(
1371            s_dut,
1372            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1373                                  dd_s_id))
1374
1375        # verify: AA discovered, BB not discovered, DD discovery w/range
1376        event = autils.wait_for_event(
1377            s_dut,
1378            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1379                                  aa_s_id))
1380        asserts.assert_false(
1381            aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1382            "Discovery with ranging for AA NOT expected!")
1383        aa_peer_id_on_sub = event['data'][aconsts.SESSION_CB_KEY_PEER_ID]
1384        autils.fail_on_event(
1385            s_dut,
1386            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1387                                  bb_s_id))
1388        event = autils.wait_for_event(
1389            s_dut,
1390            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1391                                  dd_s_id))
1392        asserts.assert_true(
1393            aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1394            "Discovery with ranging for DD expected!")
1395
1396        # start NDP in context of AA:
1397
1398        # Publisher: request network (from ANY)
1399        p_req_key = autils.request_network(
1400            p_dut, p_dut.droid.wifiAwareCreateNetworkSpecifier(aa_p_id, None))
1401
1402        # Subscriber: request network
1403        s_req_key = autils.request_network(
1404            s_dut,
1405            s_dut.droid.wifiAwareCreateNetworkSpecifier(
1406                aa_s_id, aa_peer_id_on_sub))
1407
1408        # Publisher & Subscriber: wait for network formation
1409        p_net_event = autils.wait_for_event_with_keys(
1410            p_dut, cconsts.EVENT_NETWORK_CALLBACK, autils.EVENT_TIMEOUT,
1411            (cconsts.NETWORK_CB_KEY_EVENT,
1412             cconsts.NETWORK_CB_LINK_PROPERTIES_CHANGED),
1413            (cconsts.NETWORK_CB_KEY_ID, p_req_key))
1414        s_net_event = autils.wait_for_event_with_keys(
1415            s_dut, cconsts.EVENT_NETWORK_CALLBACK, autils.EVENT_TIMEOUT,
1416            (cconsts.NETWORK_CB_KEY_EVENT,
1417             cconsts.NETWORK_CB_LINK_PROPERTIES_CHANGED),
1418            (cconsts.NETWORK_CB_KEY_ID, s_req_key))
1419
1420        p_aware_if = p_net_event["data"][cconsts.NETWORK_CB_KEY_INTERFACE_NAME]
1421        s_aware_if = s_net_event["data"][cconsts.NETWORK_CB_KEY_INTERFACE_NAME]
1422
1423        p_ipv6 = p_dut.droid.connectivityGetLinkLocalIpv6Address(
1424            p_aware_if).split("%")[0]
1425        s_ipv6 = s_dut.droid.connectivityGetLinkLocalIpv6Address(
1426            s_aware_if).split("%")[0]
1427
1428        self.log.info("AA NDP Interface names: P=%s, S=%s", p_aware_if,
1429                      s_aware_if)
1430        self.log.info("AA NDP Interface addresses (IPv6): P=%s, S=%s", p_ipv6,
1431                      s_ipv6)
1432
1433        if self.RANGING_NDP_CONCURRENCY_LIMITATION:
1434            # Expect BB to now discover w/o ranging
1435            event = autils.wait_for_event(
1436                s_dut,
1437                autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1438                                      bb_s_id))
1439            asserts.assert_false(
1440                aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1441                "Discovery with ranging for BB NOT expected!")
1442
1443        # Publishers: EE, FF w/ ranging
1444        ee_p_id = p_dut.droid.wifiAwarePublish(
1445            p_id,
1446            autils.add_ranging_to_pub(
1447                autils.create_discovery_config("EE",
1448                                               aconsts.PUBLISH_TYPE_SOLICITED),
1449                enable_ranging=True), True)
1450        autils.wait_for_event(
1451            p_dut,
1452            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1453                                  ee_p_id))
1454        ff_p_id = p_dut.droid.wifiAwarePublish(
1455            p_id,
1456            autils.add_ranging_to_pub(
1457                autils.create_discovery_config(
1458                    "FF", aconsts.PUBLISH_TYPE_UNSOLICITED),
1459                enable_ranging=True), True)
1460        autils.wait_for_event(
1461            p_dut,
1462            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1463                                  ff_p_id))
1464
1465        # Subscribers: EE out-of-range, FF in-range
1466        ee_s_id = s_dut.droid.wifiAwareSubscribe(
1467            s_id,
1468            autils.add_ranging_to_sub(
1469                autils.create_discovery_config("EE",
1470                                               aconsts.SUBSCRIBE_TYPE_ACTIVE),
1471                min_distance_mm=1000000,
1472                max_distance_mm=1000001), True)
1473        autils.wait_for_event(
1474            s_dut,
1475            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1476                                  ee_s_id))
1477        ff_s_id = s_dut.droid.wifiAwareSubscribe(
1478            s_id,
1479            autils.add_ranging_to_sub(
1480                autils.create_discovery_config("FF",
1481                                               aconsts.SUBSCRIBE_TYPE_PASSIVE),
1482                min_distance_mm=None,
1483                max_distance_mm=1000000), True)
1484        autils.wait_for_event(
1485            s_dut,
1486            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1487                                  ff_s_id))
1488
1489        if self.RANGING_NDP_CONCURRENCY_LIMITATION:
1490            # Expect EE & FF discovery w/o range
1491            event = autils.wait_for_event(
1492                s_dut,
1493                autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1494                                      ee_s_id))
1495            asserts.assert_false(
1496                aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1497                "Discovery with ranging for EE NOT expected!")
1498            event = autils.wait_for_event(
1499                s_dut,
1500                autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1501                                      ff_s_id))
1502            asserts.assert_false(
1503                aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1504                "Discovery with ranging for FF NOT expected!")
1505        else:
1506            event = autils.wait_for_event(
1507                s_dut,
1508                autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1509                                      ff_s_id))
1510            asserts.assert_true(
1511                aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1512                "Discovery with ranging for FF expected!")
1513
1514        # tear down NDP
1515        p_dut.droid.connectivityUnregisterNetworkCallback(p_req_key)
1516        s_dut.droid.connectivityUnregisterNetworkCallback(s_req_key)
1517
1518        time.sleep(5)  # give time for NDP termination to finish
1519
1520        # Subscriber: start CC out-of-range - no discovery expected!
1521        cc_s_id = s_dut.droid.wifiAwareSubscribe(
1522            s_id,
1523            autils.add_ranging_to_sub(
1524                autils.create_discovery_config("CC",
1525                                               aconsts.SUBSCRIBE_TYPE_PASSIVE),
1526                min_distance_mm=1000000,
1527                max_distance_mm=1000001), True)
1528        autils.wait_for_event(
1529            s_dut,
1530            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1531                                  cc_s_id))
1532        autils.fail_on_event(
1533            s_dut,
1534            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1535                                  cc_s_id))
1536
1537        # Subscriber: modify CC to in-range - expect discovery w/ range
1538        s_dut.droid.wifiAwareUpdateSubscribe(
1539            cc_s_id,
1540            autils.add_ranging_to_sub(
1541                autils.create_discovery_config("CC",
1542                                               aconsts.SUBSCRIBE_TYPE_PASSIVE),
1543                min_distance_mm=None,
1544                max_distance_mm=1000001))
1545        autils.wait_for_event(
1546            s_dut,
1547            autils.decorate_event(aconsts.SESSION_CB_ON_SESSION_CONFIG_UPDATED,
1548                                  cc_s_id))
1549        event = autils.wait_for_event(
1550            s_dut,
1551            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1552                                  cc_s_id))
1553        asserts.assert_true(
1554            aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1555            "Discovery with ranging for CC expected!")
1556
1557    @test_tracker_info(uuid="d94dac91-4090-4c03-a867-6dfac6558ba3")
1558    def test_role_concurrency(self):
1559        """Verify the behavior of Wi-Fi Aware Ranging (in the context of discovery)
1560     when the device has concurrency limitations which do not permit concurrent
1561     Initiator and Responder roles on the same device. In such case it is
1562     expected that normal discovery without ranging is executed AND that ranging
1563     is restored whenever the concurrency constraints are removed.
1564
1565     Note: all Subscribers are in-range.
1566
1567     DUT1: start multiple services
1568      Publish AA w/ ranging (unsolicited)
1569      Subscribe BB w/ ranging (active)
1570      Publish CC w/ ranging (unsolicited)
1571      Publish DD w/o ranging (solicited)
1572      Subscribe EE w/ ranging (passive)
1573      Subscribe FF w/ ranging (active)
1574     DUT2: start multiple services
1575      Subscribe AA w/ ranging (passive)
1576      Publish BB w/ ranging (solicited)
1577      Subscribe DD w/o ranging (active)
1578     Expect
1579      DUT2: AA match w/ range information
1580      DUT1: BB match w/o range information (concurrency disables ranging)
1581      DUT2: DD match w/o range information
1582     DUT1: Terminate AA
1583     DUT2:
1584      Terminate AA
1585      Start Publish EE w/ ranging (unsolicited)
1586     DUT1: expect EE w/o ranging
1587     DUT1: Terminate CC
1588     DUT2: Start Publish FF w/ ranging (solicited)
1589     DUT1: expect FF w/ ranging information - should finally be back up
1590     """
1591        dut1 = self.android_devices[0]
1592        dut1.pretty_name = "DUT1"
1593        dut2 = self.android_devices[1]
1594        dut2.pretty_name = "DUT2"
1595
1596        # Publisher+Subscriber: attach and wait for confirmation
1597        dut1_id = dut1.droid.wifiAwareAttach(False)
1598        autils.wait_for_event(dut1, aconsts.EVENT_CB_ON_ATTACHED)
1599        time.sleep(self.device_startup_offset)
1600        dut2_id = dut2.droid.wifiAwareAttach(False)
1601        autils.wait_for_event(dut2, aconsts.EVENT_CB_ON_ATTACHED)
1602
1603        # DUT1: initial service bringup
1604        aa_p_id = dut1.droid.wifiAwarePublish(
1605            dut1_id,
1606            autils.add_ranging_to_pub(
1607                autils.create_discovery_config(
1608                    "AA", aconsts.PUBLISH_TYPE_UNSOLICITED),
1609                enable_ranging=True), True)
1610        autils.wait_for_event(
1611            dut1,
1612            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1613                                  aa_p_id))
1614        bb_s_id = dut1.droid.wifiAwareSubscribe(
1615            dut1_id,
1616            autils.add_ranging_to_sub(
1617                autils.create_discovery_config("BB",
1618                                               aconsts.SUBSCRIBE_TYPE_ACTIVE),
1619                min_distance_mm=None,
1620                max_distance_mm=1000000), True)
1621        autils.wait_for_event(
1622            dut1,
1623            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1624                                  bb_s_id))
1625        cc_p_id = dut1.droid.wifiAwarePublish(
1626            dut1_id,
1627            autils.add_ranging_to_pub(
1628                autils.create_discovery_config(
1629                    "CC", aconsts.PUBLISH_TYPE_UNSOLICITED),
1630                enable_ranging=True), True)
1631        autils.wait_for_event(
1632            dut1,
1633            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1634                                  cc_p_id))
1635        dd_p_id = dut1.droid.wifiAwarePublish(
1636            dut1_id,
1637            autils.create_discovery_config(
1638                "DD", aconsts.PUBLISH_TYPE_SOLICITED), True)
1639        autils.wait_for_event(
1640            dut1,
1641            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1642                                  dd_p_id))
1643        ee_s_id = dut1.droid.wifiAwareSubscribe(
1644            dut1_id,
1645            autils.add_ranging_to_sub(
1646                autils.create_discovery_config("EE",
1647                                               aconsts.SUBSCRIBE_TYPE_PASSIVE),
1648                min_distance_mm=None,
1649                max_distance_mm=1000000), True)
1650        autils.wait_for_event(
1651            dut1,
1652            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1653                                  ee_s_id))
1654        ff_s_id = dut1.droid.wifiAwareSubscribe(
1655            dut1_id,
1656            autils.add_ranging_to_sub(
1657                autils.create_discovery_config("FF",
1658                                               aconsts.SUBSCRIBE_TYPE_ACTIVE),
1659                min_distance_mm=None,
1660                max_distance_mm=1000000), True)
1661        autils.wait_for_event(
1662            dut1,
1663            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1664                                  ff_s_id))
1665
1666        # DUT2: initial service bringup
1667        aa_s_id = dut2.droid.wifiAwareSubscribe(
1668            dut2_id,
1669            autils.add_ranging_to_sub(
1670                autils.create_discovery_config("AA",
1671                                               aconsts.SUBSCRIBE_TYPE_PASSIVE),
1672                min_distance_mm=None,
1673                max_distance_mm=1000000), True)
1674        autils.wait_for_event(
1675            dut2,
1676            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1677                                  aa_s_id))
1678
1679        if (hasattr(self, "ranging_role_concurrency_flexible_models") and
1680         dut2.model in self.ranging_role_concurrency_flexible_models):
1681            time.sleep(3)
1682        bb_p_id = dut2.droid.wifiAwarePublish(
1683            dut2_id,
1684            autils.add_ranging_to_pub(
1685                autils.create_discovery_config("BB",
1686                                               aconsts.PUBLISH_TYPE_SOLICITED),
1687                enable_ranging=True), True)
1688        autils.wait_for_event(
1689            dut2,
1690            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1691                                  bb_p_id))
1692        dd_s_id = dut2.droid.wifiAwareSubscribe(
1693            dut2_id,
1694            autils.create_discovery_config(
1695                "DD", aconsts.SUBSCRIBE_TYPE_ACTIVE), True)
1696        autils.wait_for_event(
1697            dut2,
1698            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1699                                  dd_s_id))
1700
1701        # Initial set of discovery events for AA, BB, and DD (which are up)
1702        event = autils.wait_for_event(
1703            dut2,
1704            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1705                                  aa_s_id))
1706        asserts.assert_true(
1707            aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1708            "Discovery with ranging for AA expected!")
1709        event = autils.wait_for_event(
1710            dut1,
1711            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1712                                  bb_s_id))
1713        if self.RANGING_INITIATOR_RESPONDER_CONCURRENCY_LIMITATION:
1714            asserts.assert_false(
1715                aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1716                "Discovery with ranging for BB NOT expected!")
1717        else:
1718            asserts.assert_true(
1719                aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1720                "Discovery with ranging for BB expected!")
1721        event = autils.wait_for_event(
1722            dut2,
1723            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1724                                  dd_s_id))
1725        asserts.assert_false(
1726            aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1727            "Discovery with ranging for DD NOT expected!")
1728
1729        # DUT1/DUT2: terminate AA
1730        dut1.droid.wifiAwareDestroyDiscoverySession(aa_p_id)
1731        dut2.droid.wifiAwareDestroyDiscoverySession(aa_s_id)
1732
1733        time.sleep(
1734            5)  # guarantee that session terminated (and host recovered?)
1735
1736        # DUT2: try EE service - ranging still disabled
1737        ee_p_id = dut2.droid.wifiAwarePublish(
1738            dut2_id,
1739            autils.add_ranging_to_pub(
1740                autils.create_discovery_config(
1741                    "EE", aconsts.PUBLISH_TYPE_UNSOLICITED),
1742                enable_ranging=True), True)
1743        autils.wait_for_event(
1744            dut2,
1745            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1746                                  ee_p_id))
1747
1748        event = autils.wait_for_event(
1749            dut1,
1750            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1751                                  ee_s_id))
1752        # When device has ranging role concurrency limitation, device could not be initiator
1753        # and responder at the same time. There are two supported schemas:
1754        # 1. Concurrency fixed mode: the role of the device depends on first Publish/Subscribe,
1755        # will keep the same role until the service is terminated
1756        # 2. Concurrency flexible mode: the role of the device changes with the active ranging
1757        # session, when a publish/subscribe session is active but the ranging session for this
1758        # service is terminated, will change the role based on the next publish/subscribe service.
1759        if self.RANGING_INITIATOR_RESPONDER_CONCURRENCY_LIMITATION and \
1760                (not hasattr(self, "ranging_role_concurrency_flexible_models") or
1761                 dut2.model not in self.ranging_role_concurrency_flexible_models):
1762            asserts.assert_false(
1763                aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1764                "Discovery with ranging for EE NOT expected!")
1765        else:
1766            asserts.assert_true(
1767                aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1768                "Discovery with ranging for EE expected!")
1769
1770        # DUT1: terminate CC - last publish w/ ranging on DUT!
1771        dut1.droid.wifiAwareDestroyDiscoverySession(cc_p_id)
1772
1773        time.sleep(
1774            5)  # guarantee that session terminated (and host recovered?)
1775
1776        # DUT2: try FF service - ranging should now function
1777        ff_p_id = dut2.droid.wifiAwarePublish(
1778            dut2_id,
1779            autils.add_ranging_to_pub(
1780                autils.create_discovery_config("FF",
1781                                               aconsts.PUBLISH_TYPE_SOLICITED),
1782                enable_ranging=True), True)
1783        autils.wait_for_event(
1784            dut2,
1785            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1786                                  ff_p_id))
1787
1788        event = autils.wait_for_event(
1789            dut1,
1790            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1791                                  ff_s_id))
1792        asserts.assert_true(
1793            aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1794            "Discovery with ranging for FF expected!")
1795
1796    @test_tracker_info(uuid="6700eab8-a172-43cd-aed3-e6577ce8fd89")
1797    def test_discovery_direct_concurrency(self):
1798        """Verify the behavior of Wi-Fi Aware Ranging used as part of discovery and
1799    as direct ranging to a peer device.
1800
1801    Process:
1802    - Start YYY service with ranging in-range
1803    - Start XXX service with ranging out-of-range
1804    - Start performing direct Ranging
1805    - While above going on update XXX to be in-range
1806    - Keep performing direct Ranging in context of YYY
1807    - Stop direct Ranging and look for XXX to discover
1808    """
1809        dut1 = self.android_devices[0]
1810        dut1.pretty_name = "DUT1"
1811        dut2 = self.android_devices[1]
1812        dut2.pretty_name = "DUT2"
1813
1814        # DUTs: attach and wait for confirmation
1815        dut1_id = dut1.droid.wifiAwareAttach(False)
1816        autils.wait_for_event(dut1, aconsts.EVENT_CB_ON_ATTACHED)
1817        time.sleep(self.device_startup_offset)
1818        dut2_id = dut2.droid.wifiAwareAttach(True)
1819        event = autils.wait_for_event(dut2,
1820                                      aconsts.EVENT_CB_ON_IDENTITY_CHANGED)
1821        dut2_mac = event['data']['mac']
1822
1823        # DUT1: publishers bring-up
1824        xxx_p_id = dut1.droid.wifiAwarePublish(
1825            dut1_id,
1826            autils.add_ranging_to_pub(
1827                autils.create_discovery_config(
1828                    "XXX", aconsts.PUBLISH_TYPE_UNSOLICITED),
1829                enable_ranging=True), True)
1830        autils.wait_for_event(
1831            dut1,
1832            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1833                                  xxx_p_id))
1834        yyy_p_id = dut1.droid.wifiAwarePublish(
1835            dut1_id,
1836            autils.add_ranging_to_pub(
1837                autils.create_discovery_config(
1838                    "YYY", aconsts.PUBLISH_TYPE_UNSOLICITED),
1839                enable_ranging=True), True)
1840        autils.wait_for_event(
1841            dut1,
1842            autils.decorate_event(aconsts.SESSION_CB_ON_PUBLISH_STARTED,
1843                                  yyy_p_id))
1844
1845        # DUT2: subscribers bring-up
1846        xxx_s_id = dut2.droid.wifiAwareSubscribe(
1847            dut2_id,
1848            autils.add_ranging_to_sub(
1849                autils.create_discovery_config("XXX",
1850                                               aconsts.SUBSCRIBE_TYPE_PASSIVE),
1851                min_distance_mm=1000000,
1852                max_distance_mm=1000001), True)
1853        autils.wait_for_event(
1854            dut2,
1855            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1856                                  xxx_s_id))
1857        yyy_s_id = dut2.droid.wifiAwareSubscribe(
1858            dut2_id,
1859            autils.add_ranging_to_sub(
1860                autils.create_discovery_config("YYY",
1861                                               aconsts.SUBSCRIBE_TYPE_PASSIVE),
1862                min_distance_mm=None,
1863                max_distance_mm=1000000), True)
1864        autils.wait_for_event(
1865            dut2,
1866            autils.decorate_event(aconsts.SESSION_CB_ON_SUBSCRIBE_STARTED,
1867                                  yyy_s_id))
1868
1869        # Service discovery: YYY (with range info), but no XXX
1870        event = autils.wait_for_event(
1871            dut2,
1872            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1873                                  yyy_s_id))
1874        asserts.assert_true(
1875            aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"],
1876            "Discovery with ranging for YYY expected!")
1877        yyy_peer_id_on_sub = event['data'][aconsts.SESSION_CB_KEY_PEER_ID]
1878
1879        autils.fail_on_event(
1880            dut2,
1881            autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1882                                  xxx_s_id))
1883
1884        # Direct ranging
1885        results21 = []
1886        for iter in range(10):
1887            id = dut2.droid.wifiRttStartRangingToAwarePeerId(
1888                yyy_peer_id_on_sub)
1889            event = autils.wait_for_event(
1890                dut2,
1891                rutils.decorate_event(rconsts.EVENT_CB_RANGING_ON_RESULT, id))
1892            results21.append(
1893                event["data"][rconsts.EVENT_CB_RANGING_KEY_RESULTS][0])
1894
1895        time.sleep(5)  # while switching roles
1896
1897        results12 = []
1898        for iter in range(10):
1899            id = dut1.droid.wifiRttStartRangingToAwarePeerMac(dut2_mac)
1900            event = autils.wait_for_event(
1901                dut1,
1902                rutils.decorate_event(rconsts.EVENT_CB_RANGING_ON_RESULT, id))
1903            results12.append(
1904                event["data"][rconsts.EVENT_CB_RANGING_KEY_RESULTS][0])
1905
1906        stats = [
1907            rutils.extract_stats(results12, 0, 0, 0),
1908            rutils.extract_stats(results21, 0, 0, 0)
1909        ]
1910
1911        # Update XXX to be within range
1912        dut2.droid.wifiAwareUpdateSubscribe(
1913            xxx_s_id,
1914            autils.add_ranging_to_sub(
1915                autils.create_discovery_config("XXX",
1916                                               aconsts.SUBSCRIBE_TYPE_PASSIVE),
1917                min_distance_mm=None,
1918                max_distance_mm=1000000))
1919        autils.wait_for_event(
1920            dut2,
1921            autils.decorate_event(aconsts.SESSION_CB_ON_SESSION_CONFIG_UPDATED,
1922                                  xxx_s_id))
1923
1924        # Expect discovery on XXX - wait until discovery with ranging:
1925        # - 0 or more: without ranging info (due to concurrency limitations)
1926        # - 1 or more: with ranging (once concurrency limitation relieved)
1927        num_events = 0
1928        while True:
1929            event = autils.wait_for_event(
1930                dut2,
1931                autils.decorate_event(aconsts.SESSION_CB_ON_SERVICE_DISCOVERED,
1932                                      xxx_s_id))
1933            if aconsts.SESSION_CB_KEY_DISTANCE_MM in event["data"]:
1934                break
1935            num_events = num_events + 1
1936            asserts.assert_true(
1937                num_events < 10,  # arbitrary safety valve
1938                "Way too many discovery events without ranging!")
1939
1940        asserts.explicit_pass(
1941            "Discovery/Direct RTT Concurrency Pass", extras={"data": stats})