-
Notifications
You must be signed in to change notification settings - Fork 375
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Enable unit tests for Python 2.6 & 3.4 on Github Actions (#3296)
* Use Ubuntu 24 for unit tests runs [Python 2.6 & 3.4] --------- Co-authored-by: narrieta@microsoft <narrieta>
- Loading branch information
Showing
10 changed files
with
181 additions
and
69 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
This directory contains a DevOps Azure Pipeline to execute the unit tests for Python 2.6 and 3.4. | ||
|
||
Currently those tests are executed using Github Actions, using .github/workflows/ci_pr.yml. The | ||
setup done by ci_pr.yml is practically identical to the setup done by this Dockerfile, with minor | ||
differences to account for the behavior of Github Actions and Azure Pipelines. | ||
|
||
NOTE: ci_pr.yml also depends on the patch_python_venv.sh script. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
#!/usr/bin/env bash | ||
# | ||
# The python 2.6 and 3.4 virtual environments have hard dependencies on some of the shared libraries in Open SSL 1.0 (e.g libssl.so.1.0.0), which is not available beyond Ubuntu 16. | ||
# Modules like hashlib and ssl will fail to import on more recent versions of Ubuntu. The Agent uses classes HTTPSConnection and HTTPS, which depend on the ssl module. Those classes | ||
# are added conditionally on the import of ssl on httplib.py and http/client.py with code similar to: | ||
# | ||
# try: | ||
# import ssl | ||
# except ImportError: | ||
# pass | ||
# else: | ||
# class HTTPSConnection(HTTPConnection):... | ||
# class HTTPS(HTTP):... | ||
# def FakeSocket (sock, sslobj):... | ||
# | ||
# Since the import fails, the classes will be undefined. To work around that, we define dummy items that raise NotImplementedError. The unit tests mock those classes anyway, so the | ||
# actual implementation does not really matter. | ||
# | ||
set -euo pipefail | ||
|
||
if [[ "$#" -ne 1 || ! "$1" =~ ^2\.6|3\.4$ ]]; then | ||
echo "Usage: patch_python_venv.sh 2.6|3.4" | ||
exit 1 | ||
fi | ||
|
||
PYTHON_VERSION=$1 | ||
|
||
if [[ "${PYTHON_VERSION}" == "2.6" ]]; then | ||
cat >> /opt/python/2.6.9/lib/python2.6/httplib.py << ... | ||
# Added by WALinuxAgent dev team to work around the lack of OpenSSL 1.0 shared libraries | ||
class HTTPSConnection(HTTPConnection): | ||
default_port = HTTPS_PORT | ||
def __init__(self, host, port=None, key_file=None, cert_file=None, strict=None, timeout=socket._GLOBAL_DEFAULT_TIMEOUT): | ||
raise NotImplementedError() | ||
def connect(self): | ||
raise NotImplementedError() | ||
__all__.append("HTTPSConnection") | ||
class HTTPS(HTTP): | ||
_connection_class = HTTPSConnection | ||
def __init__(self, host='', port=None, key_file=None, cert_file=None, strict=None): | ||
raise NotImplementedError() | ||
def FakeSocket (sock, sslobj): | ||
raise NotImplementedError() | ||
... | ||
|
||
elif [[ "${PYTHON_VERSION}" == "3.4" ]]; then | ||
cat >> /opt/python/3.4.8/lib/python3.4/http/client.py << ... | ||
# Added by WALinuxAgent dev team to work around the lack of OpenSSL 1.0 shared libraries | ||
class HTTPSConnection(HTTPConnection): | ||
default_port = HTTPS_PORT | ||
def __init__(self, host, port=None, key_file=None, cert_file=None, timeout=socket._GLOBAL_DEFAULT_TIMEOUT, source_address=None, *, context=None, check_hostname=None): | ||
raise NotImplementedError() | ||
def connect(self): | ||
raise NotImplementedError() | ||
__all__.append("HTTPSConnection") | ||
... | ||
fi |