From 5e12ddd6d02224fd38da641c91d3ccfdaa8129a9 Mon Sep 17 00:00:00 2001 From: Mark Feit Date: Mon, 22 Jul 2024 10:31:39 -0400 Subject: [PATCH] Issue 1441 (#1460) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Fix jsonval test to work with JSONSchema 3 and 4 * Clean out unused Debian versions of PostgreSQL #1441 * Remove iperf3 change that shouldn't be there yet. #1441 * Build iperf3 on u24. 1441 * Enable s3-benchmark for u24+ #1441 * Add iperf3 for u22 #1441 * Build iperf3 on d11; remove conditions in build order. #1441 * Restore conditional iperf3 build; enable force-build on Debuntu #1441 * unibuild-order changes: - Clarifying comments on iperf3 and py-amqp builds. - Simplifying python-jsonschema condition. * Forcing jq version 1.6.something to avoid 1.7.1 from U24, pending #1445 Incrementing package release number and adding changelog entries where needed. * Make all Python regexps raw strings. #1441 * Fix escaping in raw regexp strings. #1441 * Potential TODO for Golan stuff. #1441 * Bump Debian compat files 9 -> 10. #1441 --------- Co-authored-by: Lætitia Delvaux --- drop-in/unibuild-packaging/deb/compat | 2 +- ethr/unibuild-packaging/deb/rules | 4 ++ iperf3/unibuild-packaging/deb/changelog | 7 +++ .../unibuild-packaging/deb/compat-Debian-11 | 1 + .../unibuild-packaging/deb/compat-Ubuntu-22 | 1 + .../unibuild-packaging/deb/compat-Ubuntu-24 | 1 + .../unibuild-packaging/deb/control-Debian-11 | 57 ++++++++++++++++++ .../unibuild-packaging/deb/control-Ubuntu-22 | 51 ++++++++++++++++ .../unibuild-packaging/deb/control-Ubuntu-24 | 51 ++++++++++++++++ iperf3/unibuild-packaging/deb/rules-Debian-11 | 15 +++++ iperf3/unibuild-packaging/deb/rules-Ubuntu-22 | 15 +++++ iperf3/unibuild-packaging/deb/rules-Ubuntu-24 | 15 +++++ jq/unibuild-packaging/deb/changelog | 7 +++ nuttcp/unibuild-packaging/deb/compat | 2 +- .../unibuild-packaging/deb/compat | 2 +- .../unibuild-packaging/deb/changelog | 1 + .../unibuild-packaging/deb/control | 2 +- .../unibuild-packaging/deb/changelog | 1 + .../unibuild-packaging/deb/control | 12 +++- pscheduler-tool-ethr/ethr/run | 2 +- pscheduler-tool-globus/globus/run | 2 +- .../iperf2/iperf2_parser.py | 58 +++++++++---------- pscheduler-tool-nmapreach/nmapreach/run | 2 +- .../nuttcp/nuttcp_parser.py | 8 +-- pscheduler-tool-owping/owping/run | 4 +- .../paris-traceroute/run | 4 +- .../powstream/powstream_utils.py | 2 +- pscheduler-tool-tcpping/tcpping/run | 16 ++--- pscheduler-tool-tracepath/tracepath/run | 14 ++--- pscheduler-tool-traceroute/traceroute/run | 4 +- pscheduler-tool-twping/twping/run | 4 +- .../unibuild-packaging/deb/compat | 2 +- python-ntplib/unibuild-packaging/deb/compat | 2 +- .../pscheduler/pscheduler/jsonval.py | 2 +- .../limitprocessor/identifier/localsubnet.py | 2 +- .../pscheduler/pscheduler/mtu.py | 4 +- .../pscheduler/pscheduler/ping.py | 48 ++++++++------- .../pscheduler/pscheduler/sinumber.py | 2 +- python-pyjq/unibuild-packaging/deb/changelog | 7 +++ .../unibuild-packaging/deb/control-Ubuntu-24 | 1 + scripts/deb/fix-compat | 50 ++++++++++++++++ tcpping/unibuild-packaging/deb/compat | 2 +- unibuild-order | 14 ++--- 43 files changed, 401 insertions(+), 102 deletions(-) create mode 100644 iperf3/unibuild-packaging/deb/compat-Debian-11 create mode 100644 iperf3/unibuild-packaging/deb/compat-Ubuntu-22 create mode 100644 iperf3/unibuild-packaging/deb/compat-Ubuntu-24 create mode 100644 iperf3/unibuild-packaging/deb/control-Debian-11 create mode 100644 iperf3/unibuild-packaging/deb/control-Ubuntu-22 create mode 100644 iperf3/unibuild-packaging/deb/control-Ubuntu-24 create mode 100755 iperf3/unibuild-packaging/deb/rules-Debian-11 create mode 100755 iperf3/unibuild-packaging/deb/rules-Ubuntu-22 create mode 100755 iperf3/unibuild-packaging/deb/rules-Ubuntu-24 create mode 100755 scripts/deb/fix-compat diff --git a/drop-in/unibuild-packaging/deb/compat b/drop-in/unibuild-packaging/deb/compat index ec635144f6..f599e28b8a 100644 --- a/drop-in/unibuild-packaging/deb/compat +++ b/drop-in/unibuild-packaging/deb/compat @@ -1 +1 @@ -9 +10 diff --git a/ethr/unibuild-packaging/deb/rules b/ethr/unibuild-packaging/deb/rules index 476931ed99..8eafc7941c 100755 --- a/ethr/unibuild-packaging/deb/rules +++ b/ethr/unibuild-packaging/deb/rules @@ -7,6 +7,10 @@ export GOPATH=$(CURDIR)/GOPATH export GOBIN=$(GOPATH)/bin export GOCACHE=$(GOPATH)/.cache +# TODO: May need these for U24+ +#export GO111MODULE=on +#export GOPROXY=direct + # main packaging script based on dh7 syntax %: dh $@ diff --git a/iperf3/unibuild-packaging/deb/changelog b/iperf3/unibuild-packaging/deb/changelog index b5a3559ee0..9b0cc698db 100644 --- a/iperf3/unibuild-packaging/deb/changelog +++ b/iperf3/unibuild-packaging/deb/changelog @@ -1,3 +1,10 @@ +iperf3 (3.17.1-2) perfsonar-5.1-staging; urgency=low + + * Building on Ubuntu 20 and Debian 12 + * Port to Debian 11 and 12, Ubuntu 22 and 24 + + -- Lætitia Delvaux Mon, 24 Jun 2024 18:37:14 +0200 + iperf3 (3.17.1-1) perfsonar-5.1-staging; urgency=low * New upstream version diff --git a/iperf3/unibuild-packaging/deb/compat-Debian-11 b/iperf3/unibuild-packaging/deb/compat-Debian-11 new file mode 100644 index 0000000000..b4de394767 --- /dev/null +++ b/iperf3/unibuild-packaging/deb/compat-Debian-11 @@ -0,0 +1 @@ +11 diff --git a/iperf3/unibuild-packaging/deb/compat-Ubuntu-22 b/iperf3/unibuild-packaging/deb/compat-Ubuntu-22 new file mode 100644 index 0000000000..f599e28b8a --- /dev/null +++ b/iperf3/unibuild-packaging/deb/compat-Ubuntu-22 @@ -0,0 +1 @@ +10 diff --git a/iperf3/unibuild-packaging/deb/compat-Ubuntu-24 b/iperf3/unibuild-packaging/deb/compat-Ubuntu-24 new file mode 100644 index 0000000000..f599e28b8a --- /dev/null +++ b/iperf3/unibuild-packaging/deb/compat-Ubuntu-24 @@ -0,0 +1 @@ +10 diff --git a/iperf3/unibuild-packaging/deb/control-Debian-11 b/iperf3/unibuild-packaging/deb/control-Debian-11 new file mode 100644 index 0000000000..ee77c2270d --- /dev/null +++ b/iperf3/unibuild-packaging/deb/control-Debian-11 @@ -0,0 +1,57 @@ +Source: iperf3 +Section: net +Priority: optional +Maintainer: perfSONAR developers +Uploaders: Antoine Delvaux +Build-Depends: debhelper (>= 10), libssl-dev, libsctp-dev [linux-any] +Standards-Version: 3.9.8 +Homepage: http://software.es.net/iperf/ + +Package: iperf3-ssl3 +Provides: iperf3 +Conflicts: iperf3 +Architecture: any +Depends: ${shlibs:Depends}, ${misc:Depends} +Description: Internet Protocol bandwidth measuring tool + Iperf3 is a tool for performing network throughput measurements. It can + test either TCP or UDP throughput. + . + This is a new implementation that shares no code with the original + iperf from NLANR/DAST and also is not backwards compatible. + . + This package contains the command line utility. + +Package: libiperf0-ssl3 +Provides: libiperf0 +Conflicts: libiperf0 +Architecture: any +Section: libs +Multi-Arch: same +Pre-Depends: ${misc:Pre-Depends} +Depends: ${shlibs:Depends}, ${misc:Depends} +Description: Internet Protocol bandwidth measuring tool (runtime files) + Iperf3 is a tool for performing network throughput measurements. It can + test either TCP or UDP throughput. + . + This is a new implementation that shares no code with the original + iperf from NLANR/DAST and also is not backwards compatible. + . + This is the runtime package for programs that use the shared iperf + library. + +Package: libiperf-dev-ssl3 +Provides: libiperf-dev +Conflicts: libiperf-dev +Architecture: any +Section: libdevel +Multi-Arch: same +Depends: libiperf0-ssl3 (= ${binary:Version}), ${misc:Depends} +Description: Internet Protocol bandwidth measuring tool (development files) + Iperf3 is a tool for performing network throughput measurements. It can + test either TCP or UDP throughput. + . + This is a new implementation that shares no code with the original + iperf from NLANR/DAST and also is not backwards compatible. + . + This is the development package which contains headers files and the + static iperf library. diff --git a/iperf3/unibuild-packaging/deb/control-Ubuntu-22 b/iperf3/unibuild-packaging/deb/control-Ubuntu-22 new file mode 100644 index 0000000000..6ee240af85 --- /dev/null +++ b/iperf3/unibuild-packaging/deb/control-Ubuntu-22 @@ -0,0 +1,51 @@ +Source: iperf3 +Section: net +Priority: optional +Maintainer: perfSONAR developers +Uploaders: Antoine Delvaux +Build-Depends: debhelper (>= 10), libssl-dev, libsctp-dev [linux-any] +Standards-Version: 3.9.8 +Homepage: http://software.es.net/iperf/ + +Package: iperf3 +Architecture: any +Depends: ${shlibs:Depends}, ${misc:Depends} +Description: Internet Protocol bandwidth measuring tool + Iperf3 is a tool for performing network throughput measurements. It can + test either TCP or UDP throughput. + . + This is a new implementation that shares no code with the original + iperf from NLANR/DAST and also is not backwards compatible. + . + This package contains the command line utility. + +Package: libiperf0 +Architecture: any +Section: libs +Multi-Arch: same +Pre-Depends: ${misc:Pre-Depends} +Depends: ${shlibs:Depends}, ${misc:Depends} +Description: Internet Protocol bandwidth measuring tool (runtime files) + Iperf3 is a tool for performing network throughput measurements. It can + test either TCP or UDP throughput. + . + This is a new implementation that shares no code with the original + iperf from NLANR/DAST and also is not backwards compatible. + . + This is the runtime package for programs that use the shared iperf + library. + +Package: libiperf-dev +Architecture: any +Section: libdevel +Multi-Arch: same +Depends: libiperf0 (= ${binary:Version}), ${misc:Depends} +Description: Internet Protocol bandwidth measuring tool (development files) + Iperf3 is a tool for performing network throughput measurements. It can + test either TCP or UDP throughput. + . + This is a new implementation that shares no code with the original + iperf from NLANR/DAST and also is not backwards compatible. + . + This is the development package which contains headers files and the + static iperf library. diff --git a/iperf3/unibuild-packaging/deb/control-Ubuntu-24 b/iperf3/unibuild-packaging/deb/control-Ubuntu-24 new file mode 100644 index 0000000000..6ee240af85 --- /dev/null +++ b/iperf3/unibuild-packaging/deb/control-Ubuntu-24 @@ -0,0 +1,51 @@ +Source: iperf3 +Section: net +Priority: optional +Maintainer: perfSONAR developers +Uploaders: Antoine Delvaux +Build-Depends: debhelper (>= 10), libssl-dev, libsctp-dev [linux-any] +Standards-Version: 3.9.8 +Homepage: http://software.es.net/iperf/ + +Package: iperf3 +Architecture: any +Depends: ${shlibs:Depends}, ${misc:Depends} +Description: Internet Protocol bandwidth measuring tool + Iperf3 is a tool for performing network throughput measurements. It can + test either TCP or UDP throughput. + . + This is a new implementation that shares no code with the original + iperf from NLANR/DAST and also is not backwards compatible. + . + This package contains the command line utility. + +Package: libiperf0 +Architecture: any +Section: libs +Multi-Arch: same +Pre-Depends: ${misc:Pre-Depends} +Depends: ${shlibs:Depends}, ${misc:Depends} +Description: Internet Protocol bandwidth measuring tool (runtime files) + Iperf3 is a tool for performing network throughput measurements. It can + test either TCP or UDP throughput. + . + This is a new implementation that shares no code with the original + iperf from NLANR/DAST and also is not backwards compatible. + . + This is the runtime package for programs that use the shared iperf + library. + +Package: libiperf-dev +Architecture: any +Section: libdevel +Multi-Arch: same +Depends: libiperf0 (= ${binary:Version}), ${misc:Depends} +Description: Internet Protocol bandwidth measuring tool (development files) + Iperf3 is a tool for performing network throughput measurements. It can + test either TCP or UDP throughput. + . + This is a new implementation that shares no code with the original + iperf from NLANR/DAST and also is not backwards compatible. + . + This is the development package which contains headers files and the + static iperf library. diff --git a/iperf3/unibuild-packaging/deb/rules-Debian-11 b/iperf3/unibuild-packaging/deb/rules-Debian-11 new file mode 100755 index 0000000000..e19bd949d5 --- /dev/null +++ b/iperf3/unibuild-packaging/deb/rules-Debian-11 @@ -0,0 +1,15 @@ +#!/usr/bin/make -f + +export DH_OPTIONS + +export DEB_BUILD_MAINT_OPTIONS = hardening=+all + +override_dh_installchangelogs: + dh_installchangelogs RELNOTES.md + +%: + dh $@ + +# Ubuntu dbgsym.ddeb are currently not supported by reprepro +override_dh_strip: + dh_strip --no-automatic-dbgsym diff --git a/iperf3/unibuild-packaging/deb/rules-Ubuntu-22 b/iperf3/unibuild-packaging/deb/rules-Ubuntu-22 new file mode 100755 index 0000000000..e19bd949d5 --- /dev/null +++ b/iperf3/unibuild-packaging/deb/rules-Ubuntu-22 @@ -0,0 +1,15 @@ +#!/usr/bin/make -f + +export DH_OPTIONS + +export DEB_BUILD_MAINT_OPTIONS = hardening=+all + +override_dh_installchangelogs: + dh_installchangelogs RELNOTES.md + +%: + dh $@ + +# Ubuntu dbgsym.ddeb are currently not supported by reprepro +override_dh_strip: + dh_strip --no-automatic-dbgsym diff --git a/iperf3/unibuild-packaging/deb/rules-Ubuntu-24 b/iperf3/unibuild-packaging/deb/rules-Ubuntu-24 new file mode 100755 index 0000000000..e19bd949d5 --- /dev/null +++ b/iperf3/unibuild-packaging/deb/rules-Ubuntu-24 @@ -0,0 +1,15 @@ +#!/usr/bin/make -f + +export DH_OPTIONS + +export DEB_BUILD_MAINT_OPTIONS = hardening=+all + +override_dh_installchangelogs: + dh_installchangelogs RELNOTES.md + +%: + dh $@ + +# Ubuntu dbgsym.ddeb are currently not supported by reprepro +override_dh_strip: + dh_strip --no-automatic-dbgsym diff --git a/jq/unibuild-packaging/deb/changelog b/jq/unibuild-packaging/deb/changelog index f15aba6942..42f946eb2b 100644 --- a/jq/unibuild-packaging/deb/changelog +++ b/jq/unibuild-packaging/deb/changelog @@ -3,6 +3,13 @@ jq (1.7.1-1~bpo8+3) perfsonar-5.2-staging; urgency=medium * New upstream version -- Lætitia Delvaux Tue, 23 Apr 2024 01:02:58 +0200 + >>>>>>> 5.2.0 + +jq (1.6.0-1~bpo8+4) perfsonar-5.1-staging; urgency=medium + + * Port to Ubuntu 24 + + -- Lætitia Delvaux Mon, 24 Jun 2024 18:31:02 +0200 jq (1.6.0-1~bpo8+3) perfsonar-5.1-staging; urgency=medium diff --git a/nuttcp/unibuild-packaging/deb/compat b/nuttcp/unibuild-packaging/deb/compat index ec635144f6..f599e28b8a 100644 --- a/nuttcp/unibuild-packaging/deb/compat +++ b/nuttcp/unibuild-packaging/deb/compat @@ -1 +1 @@ -9 +10 diff --git a/pscheduler-account/unibuild-packaging/deb/compat b/pscheduler-account/unibuild-packaging/deb/compat index ec635144f6..f599e28b8a 100644 --- a/pscheduler-account/unibuild-packaging/deb/compat +++ b/pscheduler-account/unibuild-packaging/deb/compat @@ -1 +1 @@ -9 +10 diff --git a/pscheduler-jq-library/pscheduler-jq-library/unibuild-packaging/deb/changelog b/pscheduler-jq-library/pscheduler-jq-library/unibuild-packaging/deb/changelog index 586f5dbe4c..0221ecac28 100644 --- a/pscheduler-jq-library/pscheduler-jq-library/unibuild-packaging/deb/changelog +++ b/pscheduler-jq-library/pscheduler-jq-library/unibuild-packaging/deb/changelog @@ -1,6 +1,7 @@ pscheduler-jq-library (5.2.0~a1.0-1) perfsonar-5.2-snapshot; urgency=low * New upstream version. + * Forcing jq version 1.6.something only. -- perfSONAR developers Tue, 11 Jun 2024 18:29:36 +0200 diff --git a/pscheduler-jq-library/pscheduler-jq-library/unibuild-packaging/deb/control b/pscheduler-jq-library/pscheduler-jq-library/unibuild-packaging/deb/control index 17cd7b8bd7..c343c21200 100644 --- a/pscheduler-jq-library/pscheduler-jq-library/unibuild-packaging/deb/control +++ b/pscheduler-jq-library/pscheduler-jq-library/unibuild-packaging/deb/control @@ -10,6 +10,6 @@ Vcs-Browser: https://github.com/perfsonar/pscheduler Package: pscheduler-jq-library Architecture: all -Depends: ${misc:Depends}, jq +Depends: ${misc:Depends}, jq (>=1.6~), jq (<<1.7), Description: Library of JQ functions for pScheduler A library of JQ functions to use pScheduler internals. diff --git a/pscheduler-server/pscheduler-server/unibuild-packaging/deb/changelog b/pscheduler-server/pscheduler-server/unibuild-packaging/deb/changelog index 2c1d9e6078..b76f1ed799 100644 --- a/pscheduler-server/pscheduler-server/unibuild-packaging/deb/changelog +++ b/pscheduler-server/pscheduler-server/unibuild-packaging/deb/changelog @@ -1,6 +1,7 @@ pscheduler-server (5.2.0~a1.0-1) perfsonar-5.2-snapshot; urgency=low * New upstream version. + * Depends on PostgreSQL 16 for Ubuntu 24. -- perfSONAR developers Tue, 11 Jun 2024 18:29:36 +0200 diff --git a/pscheduler-server/pscheduler-server/unibuild-packaging/deb/control b/pscheduler-server/pscheduler-server/unibuild-packaging/deb/control index 426682eea0..8ebb006fb9 100644 --- a/pscheduler-server/pscheduler-server/unibuild-packaging/deb/control +++ b/pscheduler-server/pscheduler-server/unibuild-packaging/deb/control @@ -16,8 +16,16 @@ Depends: ${misc:Depends}, python3, curl, python3-pscheduler (>= 5.1.0~), pscheduler-core, pscheduler-account, apache2, libapache2-mod-wsgi-py3, logrotate, psmisc, dbconfig-common, postgresql (>= 10), - postgresql-15 | postgresql-14 | postgresql-13 | postgresql-12 | postgresql-11 | postgresql-10, - postgresql-plpython3-15 | postgresql-plpython3-14 | postgresql-plpython3-13 | postgresql-plpython3-12 | postgresql-plpython3-11 | postgresql-plpython3-10, + postgresql-16 + | postgresql-15 + | postgresql-14 + | postgresql-13 + | postgresql-12, + postgresql-plpython3-16 + | postgresql-plpython3-15 + | postgresql-plpython3-14 + | postgresql-plpython3-13 + | postgresql-plpython3-12, postgresql-contrib Description: pScheduler server components The pScheduler database, daemons and API web server diff --git a/pscheduler-tool-ethr/ethr/run b/pscheduler-tool-ethr/ethr/run index 557801f0fa..bf2546bd98 100755 --- a/pscheduler-tool-ethr/ethr/run +++ b/pscheduler-tool-ethr/ethr/run @@ -167,7 +167,7 @@ def run_client(): # Make the result and return it - matcher = re.compile('^\[([^]]+)\]\s+(TCP|UDP)\s+([^\s]+)-([^\s]+)\s+[^\s]+\s*([^\s]+)$') + matcher = re.compile(r'^\[([^]]+)\]\s+(TCP|UDP)\s+([^\s]+)-([^\s]+)\s+[^\s]+\s*([^\s]+)$') def group_block(stream, start, end, bps): diff --git a/pscheduler-tool-globus/globus/run b/pscheduler-tool-globus/globus/run index 4cf47c6f42..bfcff81994 100755 --- a/pscheduler-tool-globus/globus/run +++ b/pscheduler-tool-globus/globus/run @@ -78,7 +78,7 @@ if True: for line in lines: logger.debug("searching line: {0}".format(line)) #make sure you grab the last one because each screen update its own line - test = re.search('\s*(\d+) bytes\s+(\S+) ([A-za-z])B/sec avg\s+\S+ [A-za-z]B/sec inst$', line) + test = re.search(r'\s*(\d+) bytes\s+(\S+) ([A-za-z])B/sec avg\s+\S+ [A-za-z]B/sec inst$', line) if test: logger.debug("looks like a performance metric line") bytes_sent = int(test.group(1)) diff --git a/pscheduler-tool-iperf2/iperf2/iperf2_parser.py b/pscheduler-tool-iperf2/iperf2/iperf2_parser.py index 4bb1090a99..14c920fd70 100644 --- a/pscheduler-tool-iperf2/iperf2/iperf2_parser.py +++ b/pscheduler-tool-iperf2/iperf2/iperf2_parser.py @@ -71,7 +71,7 @@ def parse_output(lines, expect_udp=False, logger=None): # Bogus numbers - if re.match('\(nan%\)', line): + if re.match(r'\(nan%\)', line): return { 'succeeded': False, 'error': 'Found NaN result' @@ -79,7 +79,7 @@ def parse_output(lines, expect_udp=False, logger=None): # Connection failures - if re.match('read failed: Connection refused', line): + if re.match(r'read failed: Connection refused', line): return { 'succeeded': False, 'error': 'Connection refused' @@ -91,7 +91,7 @@ def parse_output(lines, expect_udp=False, logger=None): # Client connecting to localhost, TCP port 5001 with pid 119661 (1 flows) # Client connecting to localhost, UDP port 5001 with pid 119686 (1 flows) - test = re.match('^Client connecting to .*, (TCP|UDP) port', line) + test = re.match(r'^Client connecting to .*, (TCP|UDP) port', line) if test: protocol = test.group(1) if (protocol == 'TCP' and expect_udp) or (protocol == 'UDP' and not expect_udp): @@ -108,7 +108,7 @@ def parse_output(lines, expect_udp=False, logger=None): # TCP window size: 2626560 Byte (default) # TCP window size: 425984 Byte (WARNING: requested 1000000 Byte) - test = re.match('^TCP window size:\s+(\d+) Byte (\(WARNING: requested (\d+) Byte\))?', line) + test = re.match(r'^TCP window size:\s+(\d+) Byte (\(WARNING: requested (\d+) Byte\))?', line) if test: assert not expect_udp results['tcp-window-size'] = int(test.group(1)) @@ -126,7 +126,7 @@ def parse_output(lines, expect_udp=False, logger=None): # stream. This shouldn't matter because, in theory, they # should all be the same. - test = re.match('^\[\s*\d+\].*\(icwnd/mss/irtt=\d+/(\d+)/\d+\)', line) + test = re.match(r'^\[\s*\d+\].*\(icwnd/mss/irtt=\d+/(\d+)/\d+\)', line) if test: assert not expect_udp results['mss'] = int(test.group(1)) @@ -134,7 +134,7 @@ def parse_output(lines, expect_udp=False, logger=None): # If we start seeing server reports, we've seen everything # from the client side. Treat it as EOF. - if re.match('^\[\s*(\d+|SUM) Server Report:', line): + if re.match(r'^\[\s*(\d+|SUM) Server Report:', line): break # Interval @@ -151,14 +151,14 @@ def parse_output(lines, expect_udp=False, logger=None): # [ 1] 4.00-6.00 sec 263130 Bytes 1052520 bits/sec 179/0 89 pps test = re.match( - '^\[\s*(\d+|SUM)\]' # 1 - Stream ID - '\s+(\d+\.\d+)' # 2 - Interval start - '-(\d+\.\d+) sec' # 3 - Interval end - '\s+(\d+) Bytes' # 4 - Bytes transferred - '\s+(\d+) bits/sec' # 5 - Bandwidth - '\s+(\d+)' # 6 - Writes - '/(\d+)' # 7 - Errors - '\s+(\d+) pps$' # 8 - Packets per second + r'^\[\s*(\d+|SUM)\]' # 1 - Stream ID + r'\s+(\d+\.\d+)' # 2 - Interval start + r'-(\d+\.\d+) sec' # 3 - Interval end + r'\s+(\d+) Bytes' # 4 - Bytes transferred + r'\s+(\d+) bits/sec' # 5 - Bandwidth + r'\s+(\d+)' # 6 - Writes + r'/(\d+)' # 7 - Errors + r'\s+(\d+) pps$' # 8 - Packets per second , line) if not test: @@ -184,21 +184,21 @@ def parse_output(lines, expect_udp=False, logger=None): # [ 1] 2.00-4.00 sec 11173888000 Bytes 44695552000 bits/sec 85250/0 10 1470K/33(4) us 169301333 test = re.match( - '^\[\s*(\d+|SUM)\]' # 1 - Stream ID - '\s+(\d+\.\d+)' # 2 - Interval start - '-(\d+\.\d+) sec' # 3 - Interval end - '\s+(\d+) Bytes' # 4 - Bytes transferred - '\s+(\d+) bits/sec' # 5 - Bandwidth - '\s+(\d+)' # 6 - Writes - '/(\d+)' # 7 - Errors - '\s+(\d+)' # 8 - Retransmits - '(' # 9 - Begin optional stuff - '\s+(\d+K)' # 10 - Window size in SI units - '/(\d+)' # 11 - RTT - '\((\d+)\) us' # 12 - RTT Variance(?) - '\s*(\d+)' # 13 - Net Power (Experimental) - ')?' - '\s*$' + r'^\[\s*(\d+|SUM)\]' # 1 - Stream ID + r'\s+(\d+\.\d+)' # 2 - Interval start + r'-(\d+\.\d+) sec' # 3 - Interval end + r'\s+(\d+) Bytes' # 4 - Bytes transferred + r'\s+(\d+) bits/sec' # 5 - Bandwidth + r'\s+(\d+)' # 6 - Writes + r'/(\d+)' # 7 - Errors + r'\s+(\d+)' # 8 - Retransmits + r'(' # 9 - Begin optional stuff + r'\s+(\d+K)' # 10 - Window size in SI units + r'/(\d+)' # 11 - RTT + r'\((\d+)\) us' # 12 - RTT Variance(?) + r'\s*(\d+)' # 13 - Net Power (Experimental) + r')?' + r'\s*$' , line) if not test: diff --git a/pscheduler-tool-nmapreach/nmapreach/run b/pscheduler-tool-nmapreach/nmapreach/run index 08077756fe..1a2f251f0a 100755 --- a/pscheduler-tool-nmapreach/nmapreach/run +++ b/pscheduler-tool-nmapreach/nmapreach/run @@ -140,7 +140,7 @@ nmap_first_args = [ 'nmap', '-n', '-sP', '-oG', '-', '--host-timeout', str(timeo # The lines we want look like this: # Host: 192.168.1.1 () Status: Up -nmap_output_matcher = re.compile("^Host:\s*([^\s]+)\s.*Status:\s*Up") +nmap_output_matcher = re.compile(r'^Host:\s*([^\s]+)\s.*Status:\s*Up') nmap_timeout = timeout * 1.5 diff --git a/pscheduler-tool-nuttcp/nuttcp/nuttcp_parser.py b/pscheduler-tool-nuttcp/nuttcp/nuttcp_parser.py index 5da9ec6314..42a14d3821 100644 --- a/pscheduler-tool-nuttcp/nuttcp/nuttcp_parser.py +++ b/pscheduler-tool-nuttcp/nuttcp/nuttcp_parser.py @@ -20,7 +20,7 @@ def parse_output(lines): # Example line: # 216.8125 MB / 1.00 sec = 1817.8571 Mbps 45 retrans 206 KB-cwnd - test = re.match('^.* (\d+)\.\d+ sec \=\s*(\d+(\.\d+)?) (\S)bps\s*(\d+) retrans(\s*(\d+)\s*(\S)\S\-cwnd)?', line) + test = re.match(r'^.* (\d+)\.\d+ sec \=\s*(\d+(\.\d+)?) (\S)bps\s*(\d+) retrans(\s*(\d+)\s*(\S)\S\-cwnd)?', line) if test: spacing = int(test.group(1)) value = test.group(2) @@ -52,7 +52,7 @@ def parse_output(lines): # Example UDP line # 25.1572 MB / 1.00 sec = 211.0065 Mbps 62 / 25823 ~drop/pkt 0.24 ~%loss 4.8672 msMaxJitter - test = re.match('^.* (\d+)\.\d+ sec \=\s*(\d+(\.\d+)?) (\S)bps\s*(\d+) / (\d+) ~drop/pkt\s*(\d+\.\d+) ~%loss\s*(\d+\.\d+) msMaxJitter', line) + test = re.match(r'^.* (\d+)\.\d+ sec \=\s*(\d+(\.\d+)?) (\S)bps\s*(\d+) / (\d+) ~drop/pkt\s*(\d+\.\d+) ~%loss\s*(\d+\.\d+) msMaxJitter', line) if test: spacing = int(test.group(1)) value = test.group(2) @@ -84,7 +84,7 @@ def parse_output(lines): # Example summary line: # 2197.0657 MB / 10.00 sec = 1842.3790 Mbps 8 %TX 90 %RX 90 retrans 237 KB-cwnd 0.50 msRTT - test = re.match('^.* (\d+)\.\d+ sec =\s*(\d+(\.\d+)?) (\S)bps \d+ %TX \d+ %RX (\d+) retrans(\s*(\d+)\s*(\S)\S\-cwnd)?', line) + test = re.match(r'^.* (\d+)\.\d+ sec =\s*(\d+(\.\d+)?) (\S)bps \d+ %TX \d+ %RX (\d+) retrans(\s*(\d+)\s*(\S)\S\-cwnd)?', line) if test: duration = int(test.group(1)) value = test.group(2) @@ -108,7 +108,7 @@ def parse_output(lines): # Example UDP summary line # 252.0586 MB / 10.00 sec = 211.4462 Mbps 99 %TX 50 %RX 1485 / 259593 drop/pkt 0.57 %loss 37.2012 msMaxJitter - test = re.match('^.* (\d+)\.\d+ sec \=\s*(\d+(\.\d+)?) (\S)bps\s*(\d+) %TX (\d+) %RX (\d+) / (\d+) drop/pkt\s*(\d+\.\d+) %loss\s*(\d+\.\d+) msMaxJitter', line) + test = re.match(r'^.* (\d+)\.\d+ sec \=\s*(\d+(\.\d+)?) (\S)bps\s*(\d+) %TX (\d+) %RX (\d+) / (\d+) drop/pkt\s*(\d+\.\d+) %loss\s*(\d+\.\d+) msMaxJitter', line) if test: duration = int(test.group(1)) value = test.group(2) diff --git a/pscheduler-tool-owping/owping/run b/pscheduler-tool-owping/owping/run index 4800020d21..fb94f6962f 100755 --- a/pscheduler-tool-owping/owping/run +++ b/pscheduler-tool-owping/owping/run @@ -167,7 +167,7 @@ if role == CLIENT_ROLE: pscheduler.succeed_json(results) #Parse output - owping_regex = re.compile('^(\d+) (\d+) (\d) ([-.0-9e+]*) (\d+) (\d) ([-.0-9e+]*) (\d+)$') + owping_regex = re.compile(r'^(\d+) (\d+) (\d) ([-.0-9e+]*) (\d+) (\d) ([-.0-9e+]*) (\d+)$') results['packets-sent'] = 0 results['packets-received'] = 0 results['packets-duplicated'] = 0 @@ -285,7 +285,7 @@ elif role == SERVER_ROLE: # pscheduler.fail("Control port must be an integer") # # #data-port-range must be in form N-M where N < M and both are integers -# range_match = re.compile("(\d+)-(\d+)").match(recv_participant_data['data-port-range']) +# range_match = re.compile(r'(\d+)-(\d+)').match(recv_participant_data['data-port-range']) # if not range_match: # pscheduler.fail("Data port range is not a valid range. Must be in form N-M where N < M and both are integers") # elif range_match.group(1) >= range_match.group(2): diff --git a/pscheduler-tool-paris-traceroute/paris-traceroute/run b/pscheduler-tool-paris-traceroute/paris-traceroute/run index 75c7783c87..49dc2f995b 100755 --- a/pscheduler-tool-paris-traceroute/paris-traceroute/run +++ b/pscheduler-tool-paris-traceroute/paris-traceroute/run @@ -230,10 +230,10 @@ ips = [] last_hop = 0 for line in stdout.split('\n'): - line = re.sub('\s+', ' ', line).strip() + line = re.sub(r'\s+', ' ', line).strip() - matches = re.match('^(\d*)\s+(.*)$', line) + matches = re.match(r'^(\d*)\s+(.*)$', line) if matches is None: log.debug("Discarding: %s", line) continue diff --git a/pscheduler-tool-powstream/powstream/powstream_utils.py b/pscheduler-tool-powstream/powstream/powstream_utils.py index c5f0540636..7199f5bc02 100644 --- a/pscheduler-tool-powstream/powstream/powstream_utils.py +++ b/pscheduler-tool-powstream/powstream/powstream_utils.py @@ -157,7 +157,7 @@ def parse_raw_owamp_output(file, raw_output=False, bucket_width=TIME_SCALE): 'schema': LATENCY_SCHEMA_VERSION, 'succeeded': False } - powstream_regex = re.compile('^(\d+) (\d+) (\d) ([-.0-9e+]*) (\d+) (\d) ([-.0-9e+]*) (\d+)$') + powstream_regex = re.compile(r'^(\d+) (\d+) (\d) ([-.0-9e+]*) (\d+) (\d) ([-.0-9e+]*) (\d+)$') results['packets-sent'] = 0 results['packets-received'] = 0 results['packets-duplicated'] = 0 diff --git a/pscheduler-tool-tcpping/tcpping/run b/pscheduler-tool-tcpping/tcpping/run index 6685f05c9c..9f75e714dd 100755 --- a/pscheduler-tool-tcpping/tcpping/run +++ b/pscheduler-tool-tcpping/tcpping/run @@ -184,18 +184,18 @@ result = { # TCP Ping Results: Connections (Total/Pass/Fail): [3/3/0] (Failed: 0%) -CONNECTED = re.compile('^Connected to\\s*[^\\s]+' - '\\s+\\(([^)]+)\)' - '\\s+.*:' - '\\s+tcp_seq=([0-9]+)' - '\\s+time=([0-9.]+) ms$') +CONNECTED = re.compile(r'^Connected to\s*[^\s]+' + r'\s+\(([^)]+)\)' + r'\s+.*:' + r'\s+tcp_seq=([0-9]+)' + r'\s+time=([0-9.]+) ms$') # TCP Ping Results: Connections (Total/Pass/Fail): [3/3/0] (Failed: 0%) -COUNTED = re.compile('^TCP Ping Results: Connections \\(Total/Pass/Fail\\): \\[([0-9]+)/([0-9]+)/([0-9]+)\\]') +COUNTED = re.compile(r'^TCP Ping Results: Connections \(Total/Pass/Fail\): \[([0-9]+)/([0-9]+)/([0-9]+)\]') # rtt min/avg/max/mdev = 32.660/32.827/33.150/0.280 ms -STATS = re.compile('^rtt min/avg/max/mdev\\s+=\\s+' - '([0-9.]+)/([0-9.]+)/([0-9.]+)/([0-9.]+)\\s+ms') +STATS = re.compile(r'^rtt min/avg/max/mdev\s+=\s+' + r'([0-9.]+)/([0-9.]+)/([0-9.]+)/([0-9.]+)\s+ms') diff --git a/pscheduler-tool-tracepath/tracepath/run b/pscheduler-tool-tracepath/tracepath/run index 908601cafe..278552f7c2 100755 --- a/pscheduler-tool-tracepath/tracepath/run +++ b/pscheduler-tool-tracepath/tracepath/run @@ -151,15 +151,15 @@ traced_hops = [] ips = [] last_hop = 0 -ttl_re = re.compile('^(\d*)\??:'); -no_reply_re = re.compile('no reply'); -reached_re = re.compile('reached'); -rtt_re = re.compile('([0-9]+\.[0-9]+)ms'); -mtu_re = re.compile('pmtu ([0-9]+)'); -error_re = re.compile('!(\w+)$'); +ttl_re = re.compile(r'^(\d*)\??:'); +no_reply_re = re.compile(r'no reply'); +reached_re = re.compile(r'reached'); +rtt_re = re.compile(r'([0-9]+\.[0-9]+)ms'); +mtu_re = re.compile(r'pmtu ([0-9]+)'); +error_re = re.compile(r'!(\w+)$'); path_mtu = None for line in stdout.split('\n'): - line = re.sub('\s+', ' ', line).strip() + line = re.sub(r'\s+', ' ', line).strip() matches = ttl_re.match(line) if matches is None: continue diff --git a/pscheduler-tool-traceroute/traceroute/run b/pscheduler-tool-traceroute/traceroute/run index e9fd5a594b..c5efb7cbbf 100755 --- a/pscheduler-tool-traceroute/traceroute/run +++ b/pscheduler-tool-traceroute/traceroute/run @@ -326,10 +326,10 @@ ips = [] last_hop = 0 for line in stdout.split('\n'): - line = re.sub('\s+', ' ', line).strip() + line = re.sub(r'\s+', ' ', line).strip() - matches = re.match('^(\d*)\s+(.*)$', line) + matches = re.match(r'^(\d*)\s+(.*)$', line) if matches is None: log.debug("Discarding: %s", line) continue diff --git a/pscheduler-tool-twping/twping/run b/pscheduler-tool-twping/twping/run index 20a29e0dc5..00893d8559 100755 --- a/pscheduler-tool-twping/twping/run +++ b/pscheduler-tool-twping/twping/run @@ -237,7 +237,7 @@ if role == CLIENT_ROLE: # RS recv synchronized boolean unsigned # RERR recv err estimate float (%g) # RTTL reflected ttl unsigned short - twping_regex = re.compile('^(\d+) (\d+) (\d) ([-.0-9e+]*) (\d+) (\d) ([-.0-9e+]*) (\d+) (\d+) (\d+) (\d) ([-.0-9e+]*) (\d+) (\d) ([-.0-9e+]*) (\d+)$') + twping_regex = re.compile(r'^(\d+) (\d+) (\d) ([-.0-9e+]*) (\d+) (\d) ([-.0-9e+]*) (\d+) (\d+) (\d+) (\d) ([-.0-9e+]*) (\d+) (\d) ([-.0-9e+]*) (\d+)$') results['packets-sent'] = 0 results['packets-received'] = 0 results['packets-duplicated'] = 0 @@ -416,7 +416,7 @@ elif role == SERVER_ROLE: # pscheduler.fail("Control port must be an integer") # # #data-port-range must be in form N-M where N < M and both are integers -# range_match = re.compile("(\d+)-(\d+)").match(recv_participant_data['data-port-range']) +# range_match = re.compile(r'(\d+)-(\d+)').match(recv_participant_data['data-port-range']) # if not range_match: # pscheduler.fail("Data port range is not a valid range. Must be in form N-M where N < M and both are integers") # elif range_match.group(1) >= range_match.group(2): diff --git a/python-jsonschema/unibuild-packaging/deb/compat b/python-jsonschema/unibuild-packaging/deb/compat index ec635144f6..f599e28b8a 100644 --- a/python-jsonschema/unibuild-packaging/deb/compat +++ b/python-jsonschema/unibuild-packaging/deb/compat @@ -1 +1 @@ -9 +10 diff --git a/python-ntplib/unibuild-packaging/deb/compat b/python-ntplib/unibuild-packaging/deb/compat index ec635144f6..f599e28b8a 100644 --- a/python-ntplib/unibuild-packaging/deb/compat +++ b/python-ntplib/unibuild-packaging/deb/compat @@ -1 +1 @@ -9 +10 diff --git a/python-pscheduler/pscheduler/pscheduler/jsonval.py b/python-pscheduler/pscheduler/pscheduler/jsonval.py index 7171086679..99df63007d 100644 --- a/python-pscheduler/pscheduler/pscheduler/jsonval.py +++ b/python-pscheduler/pscheduler/pscheduler/jsonval.py @@ -350,7 +350,7 @@ "oneOf": [ { "type": "string", - "pattern": "^[0-9]+(\\.[0-9]+)?(\\s*[KkMmGgTtPpEeZzYy][Ii]?)?$" + "pattern": r'^[0-9]+(\.[0-9]+)?(\s*[KkMmGgTtPpEeZzYy][Ii]?)?$' }, { "type": "integer" diff --git a/python-pscheduler/pscheduler/pscheduler/limitprocessor/identifier/localsubnet.py b/python-pscheduler/pscheduler/pscheduler/limitprocessor/identifier/localsubnet.py index 5eb7a3ab6a..e50588da2e 100644 --- a/python-pscheduler/pscheduler/pscheduler/limitprocessor/identifier/localsubnet.py +++ b/python-pscheduler/pscheduler/pscheduler/limitprocessor/identifier/localsubnet.py @@ -20,7 +20,7 @@ def data_is_valid(data): # These are for ue by ipv6_netmask_size() -ipv6_netmask_re = re.compile("^([f]*)([ec80]?)0*$") +ipv6_netmask_re = re.compile(r'^([f]*)([ec80]?)0*$') ipv6_digit_bits = { "e": 3, diff --git a/python-pscheduler/pscheduler/pscheduler/mtu.py b/python-pscheduler/pscheduler/pscheduler/mtu.py index cd59e0e8b3..2d11fbb2e5 100644 --- a/python-pscheduler/pscheduler/pscheduler/mtu.py +++ b/python-pscheduler/pscheduler/pscheduler/mtu.py @@ -9,8 +9,8 @@ from .ipaddr import ip_addr_version from .program import run_program -mtu_match = re.compile("^.*pmtu ([0-9]+)") -hop_match = re.compile("^\s*[0-9]+\??:") +mtu_match = re.compile(r'^.*pmtu ([0-9]+)') +hop_match = re.compile(r'^\s*[0-9]+\??:') def mtu_path_is_safe(host, ipversion=None): diff --git a/python-pscheduler/pscheduler/pscheduler/ping.py b/python-pscheduler/pscheduler/pscheduler/ping.py index 51a446db2b..ce720c8cb9 100644 --- a/python-pscheduler/pscheduler/pscheduler/ping.py +++ b/python-pscheduler/pscheduler/pscheduler/ping.py @@ -20,20 +20,24 @@ def parse_ping(output, count): # Matchers for output lines we care about # - PACKET_RETURNED = re.compile("^([0-9]+) bytes" - "\s+from (.*):" - "\s+icmp_[rs]eq=([0-9]+)" - "\s+ttl=([0-9]+)" - "\s+time=([0-9.]+) ms" - "$") + PACKET_RETURNED = re.compile( + r'^([0-9]+) bytes' + r'\s+from (.*):' + r'\s+icmp_[rs]eq=([0-9]+)' + r'\s+ttl=([0-9]+)' + r'\s+time=([0-9.]+) ms' + r'$' + ) # Error: From 5.6.7.8 icmp_seq=7 Destination Net Unreachable - ERROR_RETURNED = re.compile("^From" - "\s+([^\s]+)" - "\s+icmp_seq=([0-9]+)" - "\s+(.*)" - "$") + ERROR_RETURNED = re.compile( + r'^From' + r'\s+([^\s]+)' + r'\s+icmp_seq=([0-9]+)' + r'\s+(.*)' + r'$' + ) # Error messages known to be output by ping ERROR_STRINGS = { @@ -47,24 +51,26 @@ def parse_ping(output, count): # Same, but require regexps to match ERROR_MATCHES = [ - ( re.compile("^Frag needed and DF set"), 'fragmentation-needed-and-df-set' ) + ( re.compile(r'^Frag needed and DF set'), 'fragmentation-needed-and-df-set' ) ] # Sent/received/loss statistics: # 5 packets transmitted, 5 received, 0% packet loss, time 4131ms LOSS_STATS = re.compile( - '^([0-9]+) packets transmitted,' - ' ([0-9]+) received,' - ' ([0-9.]+)% packet loss') + r'^([0-9]+) packets transmitted,' + r' ([0-9]+) received,' + r' ([0-9.]+)% packet loss') # Times: rtt min/avg/max/mdev = 19.631/24.191/29.874/4.262 ms - TIMES_RETURNED = re.compile("^rtt min/avg/max/mdev\s*=\s*" - "([0-9.]+)" - "/([0-9.]+)" - "/([0-9.]+)" - "/([0-9.]+)" - "\s+ms$") + TIMES_RETURNED = re.compile( + r'^rtt min/avg/max/mdev\s*=\s*' + r'([0-9.]+)' + r'/([0-9.]+)' + r'/([0-9.]+)' + r'/([0-9.]+)' + r'\s+ms$' + ) roundtrips = [] ips = [] diff --git a/python-pscheduler/pscheduler/pscheduler/sinumber.py b/python-pscheduler/pscheduler/pscheduler/sinumber.py index d13bffd40d..582c56af93 100644 --- a/python-pscheduler/pscheduler/pscheduler/sinumber.py +++ b/python-pscheduler/pscheduler/pscheduler/sinumber.py @@ -27,7 +27,7 @@ 'yi': 1024 ** 8 } -si_regex = re.compile('^(-?[0-9]+(\.[0-9]+)?)\s*([kmgtpezy][i]?)?$') +si_regex = re.compile(r'^(-?[0-9]+(\.[0-9]+)?)\s*([kmgtpezy][i]?)?$') def si_as_number(text): diff --git a/python-pyjq/unibuild-packaging/deb/changelog b/python-pyjq/unibuild-packaging/deb/changelog index 34a346739e..e69fbf10dd 100644 --- a/python-pyjq/unibuild-packaging/deb/changelog +++ b/python-pyjq/unibuild-packaging/deb/changelog @@ -1,3 +1,10 @@ +pyjq (2.4.0-3~bpo10+3) perfsonar-5.1-staging; urgency=low + + * Port to Ubuntu 24. + * Forcing jq version 1.6.something only. + + -- Lætitia Delvaux Mon, 24 Jun 2024 18:32:33 +0200 + pyjq (2.4.0-3~bpo10+2) perfsonar-5.1-staging; urgency=low * Building on Ubuntu 20. diff --git a/python-pyjq/unibuild-packaging/deb/control-Ubuntu-24 b/python-pyjq/unibuild-packaging/deb/control-Ubuntu-24 index b0c86477d1..84c108bd25 100644 --- a/python-pyjq/unibuild-packaging/deb/control-Ubuntu-24 +++ b/python-pyjq/unibuild-packaging/deb/control-Ubuntu-24 @@ -14,6 +14,7 @@ Build-Depends: python3-mock, cython3, libjq-dev (>=1.6~), + libjq-dev (<<1.7), libonig-dev (>=5.9), libpython3-dev Standards-Version: 3.9.8 diff --git a/scripts/deb/fix-compat b/scripts/deb/fix-compat new file mode 100755 index 0000000000..111c144f53 --- /dev/null +++ b/scripts/deb/fix-compat @@ -0,0 +1,50 @@ +#!/bin/sh +# +# Find and adjust all compat levels +# +# Usage: fix-compat LEVEL [ DIR ] +# +# Where: +# +# LEVEL is the lowest desired compatibility level +# DIR is the directory where the search should start (default .) +# + +die() +{ + echo "$@" 1>&2 + exit 1 +} + +[ $# -gt 0 -a $# -lt 3 ] \ + || die 'Usage: fix-compat LEVEL [ DIR ]' + +MIN_LEVEL=$1 +if ! echo "${MIN_LEVEL}" | egrep -qe '^[0-9]+$' +then + die "Invalid compatibility level." +fi + +DIR=${2:-.} +[ -d "${DIR}" ] \ + || die "${DIR} is not a directory" + + +find "${DIR}" -type f -name "compat" \ + | ( + while read FILE + do + egrep -qe '^[0-9]+$' "${FILE}" \ + || die "${FILE}: Invalid compatibility level '$(cat ${FILE})'" + + LEVEL=$(cat "${FILE}") + if [ "${LEVEL}" -lt "${MIN_LEVEL}" ] + then + echo "${FILE}: ${LEVEL} -> ${MIN_LEVEL}" + echo "${MIN_LEVEL}" > "${FILE}" + elif [ "${LEVEL}" -gt "${MIN_LEVEL}" ] + then + echo "${FILE}: ${LEVEL} > ${MIN_LEVEL} (Left alone)" + fi + done +) diff --git a/tcpping/unibuild-packaging/deb/compat b/tcpping/unibuild-packaging/deb/compat index ec635144f6..f599e28b8a 100644 --- a/tcpping/unibuild-packaging/deb/compat +++ b/tcpping/unibuild-packaging/deb/compat @@ -1 +1 @@ -9 +10 diff --git a/unibuild-order b/unibuild-order index 2b65555609..b141d69940 100755 --- a/unibuild-order +++ b/unibuild-order @@ -20,6 +20,10 @@ changecom()dnl # GENERAL-PURPOSE MACROS +# Setting this to 1 forces builds of all packages on Debian systems. +# See commentary surrounding iperf3. +define(BUILD_ALL_DEB,1) + # Setting this to zero removes all tools that depend on OWAMP, which # is built in a separate repository. The only time you'd want to do # this is when doing unrelated development. @@ -69,10 +73,7 @@ ifelse(DISTRO/eval(MAJOR > 19),Ubuntu/1,, # Ubuntu 20 has a newer version of th FAMILY/eval(MAJOR >= 9),RedHat/1,, # And EL9+ python-pyrsistent) python-nmap3 -ifelse(DISTRO/eval(MAJOR > 19),Ubuntu/1,, # Ubuntu 20 has a newer version of this. - DISTRO/eval(MAJOR > 10),Debian/1,, # As does Debian 11. - FAMILY/eval(MAJOR > 8),RedHat/1,, # As does EL9+ - python-jsonschema) +ifelse(FAMILY/eval(MAJOR <= 8),RedHat/1,python-jsonschema) # Only build on EL8 and lower python-kafka python-nmap3 @@ -82,7 +83,7 @@ ifelse(FAMILY/eval(MAJOR >= 9),RedHat/1,python-nose) ifelse(FAMILY/eval(MAJOR >= 9),RedHat/1,python-ntplib) python-parse-crontab python-vine -ifelse(DISTRO/eval(MAJOR > 21),Ubuntu/1,, # Ubuntu 22 has a newer version of this. +ifelse(DISTRO/eval(MAJOR > 21),Ubuntu/1,, # Ubuntu 22 and up have a newer version of this. DISTRO/eval(MAJOR > 11),Debian/1,, # As does Debian 12. python-py-amqp) python-py-radix @@ -167,8 +168,7 @@ pscheduler-test-throughput # This has not been released. See also pscheduler-tool-nmapscan # pscheduler-test-openports --bundle extras pscheduler-test-rtt -#ifelse(HAVE_S3_BENCHMARK,1,pscheduler-test-s3throughput) -pscheduler-test-s3throughput +ifelse(HAVE_S3_BENCHMARK,1,pscheduler-test-s3throughput) pscheduler-test-simplestream pscheduler-test-snmpget --bundle snmp pscheduler-test-snmpgetbgm --bundle snmp