<p>Jenkins2 <strong>merged</strong> this change.</p><p><a href="https://gerrit.asterisk.org/8866">View Change</a></p><div style="white-space:pre-wrap">Approvals:
Corey Farrell: Looks good to me, but someone else must approve
George Joseph: Looks good to me, approved
Jenkins2: Approved for Submit
</div><pre style="font-family: monospace,monospace; white-space: pre-wrap;">utils_socket: range of random ports searched only once<br><br>If a range (greater than 1) of random ports was asked for, and if a port in<br>range was not available an exception was thrown stating the port in range<br>was not free.<br><br>This patch makes it so the exception is caught and a new random port range is<br>tried again (up to "attempts" tries) before quitting.<br><br>Change-Id: I96affa9df38acf569f5d3c0965ac7b78d865455d<br>---<br>M lib/python/asterisk/utils_socket.py<br>1 file changed, 16 insertions(+), 5 deletions(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;">diff --git a/lib/python/asterisk/utils_socket.py b/lib/python/asterisk/utils_socket.py<br>index 2a11c97..1f62f13 100644<br>--- a/lib/python/asterisk/utils_socket.py<br>+++ b/lib/python/asterisk/utils_socket.py<br>@@ -195,6 +195,9 @@<br> if not isinstance(ports, list):<br> ports = list(ports)<br> <br>+ LOGGER.debug("Checking the following {0}/{1} ports for availability: "<br>+ "{2}".format(socket_type(socktype), socket_family(family), ports))<br>+<br> res = []<br> for port in ports:<br> for attempt in range(attempts):<br>@@ -238,11 +241,19 @@<br> <br> # Need a random port first<br> port = self.get_avail(host, 0, socktype, family)<br>- ports = self.get_avail(<br>- host, range(port[0] + step, port[0] + num, step),<br>- socktype, family, attempts)<br>- if ports:<br>- return port + ports<br>+<br>+ if abs(num) <= 1:<br>+ return port<br>+<br>+ try:<br>+ ports = self.get_avail(<br>+ host, range(port[0] + step, port[0] + num, step),<br>+ socktype, family, attempts)<br>+ except PortError:<br>+ # At least one port not free, try again<br>+ continue<br>+<br>+ return port + ports<br> <br> raise PortError(socktype, family, attempts=attempts)<br> <br></pre><p>To view, visit <a href="https://gerrit.asterisk.org/8866">change 8866</a>. To unsubscribe, visit <a href="https://gerrit.asterisk.org/settings">settings</a>.</p><div itemscope itemtype="http://schema.org/EmailMessage"><div itemscope itemprop="action" itemtype="http://schema.org/ViewAction"><link itemprop="url" href="https://gerrit.asterisk.org/8866"/><meta itemprop="name" content="View Change"/></div></div>
<div style="display:none"> Gerrit-Project: testsuite </div>
<div style="display:none"> Gerrit-Branch: master </div>
<div style="display:none"> Gerrit-MessageType: merged </div>
<div style="display:none"> Gerrit-Change-Id: I96affa9df38acf569f5d3c0965ac7b78d865455d </div>
<div style="display:none"> Gerrit-Change-Number: 8866 </div>
<div style="display:none"> Gerrit-PatchSet: 3 </div>
<div style="display:none"> Gerrit-Owner: Kevin Harwell <kharwell@digium.com> </div>
<div style="display:none"> Gerrit-Reviewer: Benjamin Keith Ford <bford@digium.com> </div>
<div style="display:none"> Gerrit-Reviewer: Corey Farrell <git@cfware.com> </div>
<div style="display:none"> Gerrit-Reviewer: George Joseph <gjoseph@digium.com> </div>
<div style="display:none"> Gerrit-Reviewer: Jenkins2 </div>
<div style="display:none"> Gerrit-Reviewer: Joshua Colp <jcolp@digium.com> </div>
<div style="display:none"> Gerrit-Reviewer: Kevin Harwell <kharwell@digium.com> </div>