Skip to content

Update CI to use newer python versions #743

Update CI to use newer python versions

Update CI to use newer python versions #743

Workflow file for this run

name: CI
concurrency:
group: ${{ github.head_ref || github.sha }}
cancel-in-progress: true
on:
pull_request:
workflow_dispatch:
# schedule:
# - cron: "0 1 * * *"
jobs:
build_and_test_linux:
strategy:
matrix:
include:
- {platform: 'ubuntu-22.04', python_version: '3.10', mgversion: 'latest'}
- {platform: 'ubuntu-24.04', python_version: '3.10', mgversion: 'latest'}
- {platform: 'ubuntu-24.04', python_version: '3.11', mgversion: 'latest'}
- {platform: 'ubuntu-24.04', python_version: '3.12', mgversion: 'latest'}
- {platform: 'ubuntu-24.04', python_version: '3.13', mgversion: 'latest'}
- {platform: 'fedora-41', python_version: '3.13', mgversion: 'latest'}
runs-on: ["self-hosted", "X64"]
steps:
- name: Checkout repository and submodules
uses: actions/checkout@v4
with:
fetch-depth: 0
submodules: recursive
- name: Set Memgraph Version
run: |
if [[ "${{ matrix.mgversion }}" == "latest" ]]; then
mgversion=$(curl -s https://api.github.com/repos/memgraph/memgraph/releases/latest | jq -r .tag_name)
mgversion=${mgversion#v}
else
mgversion="${{ matrix.mgversion }}"
fi
echo "MGVERSION=$mgversion" >> $GITHUB_ENV
- name: Download Memgraph
run: |
if [[ "${{ matrix.platform }}" == "fedora-41" ]]; then
MEMGRAPH_PACKAGE_NAME="memgraph-${{ env.MGVERSION }}_1-1.x86_64.rpm"
LOCAL_PACKAGE_NAME=memgraph.rpm
else
MEMGRAPH_PACKAGE_NAME="memgraph_${{ env.MGVERSION }}-1_amd64.deb"
LOCAL_PACKAGE_NAME=memgraph.deb
fi
curl -L "https://download.memgraph.com/memgraph/v${{ env.MGVERSION }}/${{ matrix.platform }}/${MEMGRAPH_PACKAGE_NAME}" > "${LOCAL_PACKAGE_NAME}"
echo "LOCAL_PACKAGE_NAME=$LOCAL_PACKAGE_NAME" >> $GITHUB_ENV
- name: Set up Docker Buildx
id: buildx
uses: docker/setup-buildx-action@v3
- name: Log in to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Launch Docker Container
run: |
platform="${{ matrix.platform }}"
tag=${platform//-/:}
docker run -d --rm --name testcontainer "$tag" sleep infinity
- name: Install system dependencies
run: |
docker cp $LOCAL_PACKAGE_NAME testcontainer:/$LOCAL_PACKAGE_NAME
if [[ "${{ matrix.platform }}" == "fedora-41" ]]; then
docker exec -i testcontainer \
bash -c "dnf install -y python${{ matrix.python_version }} python3-pip python3-setuptools python3-devel cmake g++ openssl-devel nmap-ncat"
docker exec -i testcontainer \
bash -c "pip3 install --upgrade networkx pytest pyopenssl sphinx"
docker exec -i testcontainer \
bash -c "mkdir -p /etc/systemd/system && ln -s /dev/null /etc/systemd/system/memgraph.service" # Prevents Memgraph from starting.
docker exec -i testcontainer \
bash -c "dnf install -y /$LOCAL_PACKAGE_NAME"
else
if [[ "${{ matrix.platform }}" == "ubuntu-22.04" ]]; then
curl_package=libcurl4
else
curl_package=libcurl4t64
fi
docker exec -i testcontainer \
bash -c "apt update && apt install -y software-properties-common && add-apt-repository ppa:deadsnakes/ppa"
docker exec -i testcontainer \
bash -c "apt update && apt install -y libpython${{ matrix.python_version }} python3-pip python3-setuptools $curl_package cmake libssl-dev netcat-traditional"
docker exec -i testcontainer \
bash -c "pip3 install --upgrade networkx pytest pyopenssl sphinx --break-system-packages"
docker exec -i testcontainer \
bash -c "mkdir -p /etc/systemd/system && ln -s /dev/null /etc/systemd/system/memgraph.service" # Prevents Memgraph from starting.
docker exec -i testcontainer \
bash -c "dpkg -i /$LOCAL_PACKAGE_NAME"
fi
rm -v $LOCAL_PACKAGE_NAME
- name: Copy Repo Into Container
run: |
docker cp . testcontainer:/pymgclient
- name: Build source distribution
run: |
docker exec -i testcontainer \
bash -c "cd /pymgclient && python3 setup.py sdist"
- name: Install pymgclient
run: |
break_packages=""
static_ssl=""
if [[ "${{ matrix.platform }}" == ubuntu* ]]; then
break_packages="--break-system-packages"
elif [[ "${{ matrix.platform }}" == fedora* ]]; then
static_ssl="--no-build-isolation --global-option=build_ext --global-option '--static-openssl=False'"
fi
docker exec -i testcontainer \
bash -c "python3 -m pip install --upgrade pip setuptools wheel ${break_packages}"
docker exec -i testcontainer \
bash -c "python3 -m pip install ${static_ssl} ./pymgclient/dist/pymgclient-* ${break_packages}"
- name: Import mgclient to validate installation
run: |
docker exec -i testcontainer \
bash -c "python3 -c 'import mgclient'"
- name: Run tests
run: |
MEMGRAPH_PORT=10000 # what's this for?
docker exec -i testcontainer \
bash -c "cd /pymgclient && python3 -m pytest -v"
- name: Build docs
run: |
docker exec -i testcontainer \
bash -c "cd /pymgclient/docs && make html"
- name: Copy Package
run: |
docker cp testcontainer:/pymgclient/dist .
- name: Save source distribution package
uses: actions/upload-artifact@v4
with:
name: pymgclient
path: dist/
- name: Cleanup
if: always()
run: |
docker stop testcontainer || echo "Container does not exist"
docker wait testcontainer || echo "Container does not exist"
docker rmi ${{ env.MGVERSION }} || echo "Image does not exist"
build_and_test_windows:
if: ${{ github.event_name == 'workflow_dispatch' }}
runs-on: windows-2019
strategy:
matrix:
arch:
- { mingw: "64", msys: x86_64, python: "x64" }
python_version:
- '3.7'
- '3.13'
env:
# TODO(gitbuda): Fix "The file cannot be accessed by the system... rocksdb_durability"
MG_VERSION: 2.8.0
steps:
- uses: actions/checkout@v2
with:
submodules: true
- name: Setup python
uses: actions/setup-python@v2.2.2
with:
python-version: ${{ matrix.python_version }}
architecture: ${{ matrix.arch.python }}
- uses: msys2/setup-msys2@v2
with:
msystem: MINGW${{ matrix.arch.mingw }}
update: true
release: false
install: git mingw-w64-${{ matrix.arch.msys }}-toolchain mingw-w64-${{ matrix.arch.msys }}-cmake mingw-w64-${{ matrix.arch.msys }}-openssl
- name: Add mingw${{ matrix.arch.mingw }} to PATH
run: |
# First make sure python would resolve to the windows native python, not mingw one
echo "C:\msys64\mingw${{ matrix.arch.mingw }}\bin" | Out-File -Append -FilePath $env:GITHUB_PATH -Encoding utf8
echo "${{ env.pythonLocation }}" | Out-File -Append -FilePath $env:GITHUB_PATH -Encoding utf8
- name: Print OpenSSL version
shell: msys2 {0}
run: |
openssl version -a
- uses: Vampire/setup-wsl@v1
with:
distribution: Ubuntu-20.04
- name: Download, install and run Memgraph under WSL
shell: wsl-bash {0} # root shell
run: |
mkdir ~/memgraph
curl -L https://download.memgraph.com/memgraph/v${{ env.MG_VERSION }}/ubuntu-20.04/memgraph_${{ env.MG_VERSION }}-1_amd64.deb --output ~/memgraph/memgraph.deb
dpkg -i ~/memgraph/memgraph.deb
openssl req -x509 -newkey rsa:4096 -days 3650 -nodes -keyout key.pem -out cert.pem -subj "/C=GB/ST=London/L=London/O=Testing Corp./CN=PymgclientTest"
nohup /usr/lib/memgraph/memgraph --bolt-port 7687 --bolt-cert-file="cert.pem" --bolt-key-file="key.pem" --data-directory="~/memgraph/data" --storage-properties-on-edges=true --storage-snapshot-interval-sec=0 --storage-wal-enabled=false --storage-recover-on-startup=false --storage-snapshot-on-exit=false --telemetry-enabled=false --log-file='' &
sleep 1 # Wait for Memgraph a bit.
- run: python -m pip install -U pip wheel setuptools pytest pyopenssl
- name: Build pymgclient
run: python setup.py bdist_wheel
- name: Install pymgclient
run: python -m pip install --verbose -f dist --no-index pymgclient
env:
VERBOSE: 1
- name: Run tests
run: |
python3 -m pytest -v
env:
MEMGRAPH_HOST: "localhost"
MEMGRAPH_STARTED_WITH_SSL:
- name: Save wheel package
uses: actions/upload-artifact@v2
with:
name: pymgclient-win${{ matrix.arch.mingw }}-${{ matrix.python_version }}
path: dist/
build_macos:
if: ${{ github.event_name == 'workflow_dispatch' }}
strategy:
fail-fast: false
matrix:
platform: [macos-15, macos-14]
python_version:
- '3.8'
- '3.13'
include:
- {platform: [macOS-15, ARM64, self-hosted], python_version: '3.13'}
- {platform: [macOS-15, ARM64, self-hosted], python_version: '3.8'}
runs-on: ${{ matrix.platform }}
steps:
- uses: actions/checkout@v2
with:
submodules: true
- name: Install python and OpenSSL
run: |
brew install python@${{ matrix.python_version }} openssl@1.1
brew link --force --overwrite openssl@1.1
openssl version -a
- name: Manage OpenSSL 3 on ARM machines
if: ${{ contains(matrix.platform, 'ARM64') }}
run: |
brew install openssl@3
brew link --force --overwrite openssl@3
openssl version -a
- name: Make used python version default
run: |
brew unlink python@3 && brew link --force python@${{ matrix.python_version }}
python${{ matrix.python_version }} --version
- name: Install pytest and pyopenssl
run: python${{ matrix.python_version }} -m pip install pyopenssl pytest
- name: Build pymgclient
run: python${{ matrix.python_version }} setup.py bdist_wheel
- name: Install pymgclient
run: python${{ matrix.python_version }} -m pip install -f dist --no-index pymgclient
- name: Import mgclient to validate installation
run: python${{ matrix.python_version }} -c "import mgclient"
- name: Save artifact name on x86 machines
if: ${{ !contains(matrix.platform, 'ARM64') }}
run: echo "OS_TYPE=${{ matrix.platform }}" >> $GITHUB_ENV
- name: Save artifact name on ARM64 machines
if: ${{ contains(matrix.platform, 'ARM64') }}
# Convert macOS-11.6-ARM64 to macos-11.6-arm64 to be consistent with full lowercase naming
run: echo OS_TYPE=`echo "${{ matrix.platform[0] }}-${{ matrix.platform[1] }}" | tr "[:upper:]" "[:lower:]"` >> $GITHUB_ENV
- name: Save wheel package
uses: actions/upload-artifact@v2
with:
name: pymgclient-${{ env.OS_TYPE }}-${{ matrix.python_version }}
path: dist/