============
Introduction
============
pymgclient is a `Memgraph `_ database adapter for
Python language compliant with the DB-API 2.0 specification described by
:pep:`249`.
:py:mod:`mgclient` module is the current implementation of the adapter. It is
implemented in C as a wrapper around `mgclient`_, the official Memgraph client
library. As a C extension, it is only compatible with CPython implementation of
the Python programming language.
:py:mod:`mgclient` only works with Python 3.
#############
Installation
#############
pymgclient has prebuilt binary packages for
* macOS Catalina (version 10.15) and newer on x86_64 with `Python
`_ 3.7+
* macOS Monterey (version 12) and newer on arm64 with `Python
`_ 3.7+
* Windows 10 x86_64 with `Python `_ 3.7+
To intall pymgclient binaries on these platforms see `Install binaries`_
section or check `Install from source`_ for other platforms.
Install binaries
################
On macOS run::
$ pip3 install --user pymgclient
On Windows run::
$ py -3 -m pip install --user pymgclient
Alternatively on Windows, if the launcher is not installed, just run::
$ pip install --user pymgclient
Install from source
###################
pymgclient can be installed from source on:
* all platforms that have prebuilt binaries
* on various Linux distributions, including:
* Ubuntu 18.04+
* Debian 10+
* CentOS 8+
*******************
Build prerequisites
*******************
pymgclient is a C wrapper around the `mgclient`_ Memgraph client library. To
build it from you will need:
* Python 3.6 or newer
* Python 3.6 or newer header files
* A C compiler supporting C11 standard
* A C++ compiler (it is not used directly, but necessary for CMake to work)
* Preqrequisites of `mgclient`_:
* CMake 3.8 or newer
* OpenSSL 1.0.2 or newer (but not OpenSSL 3.0) and its header files
Building on Linux
*****************
First install the prerequisites:
* On Debian/Ubuntu::
$ sudo apt install python3-dev cmake make gcc g++ libssl-dev
* On CentOS::
$ sudo yum install -y python3-devel cmake3 make gcc gcc-c++ openssl-devel
After the prerequisites are installed pymgclient can be installed via pip::
$ pip3 install --user pymgclient
This will download the source package of pymgclient and build the binary
package before installing it. Alternatively pymgclient can be installed by
using :file:`setup.py`::
$ python3 setup.py install
Building on macOS
*****************
To install the C/C++ compiler, run::
$ xcode-select --install
The rest of the build prerequisites can be installed easily via `brew`_::
$ brew install python3 openssl@1.1 cmake
It is important to mention that on M1/ARM machines pymgclient cannot be built
with the default installed Python version, thus Python needs to be installed via
brew. If you are interested in the technical details, you can find more details
in the technical notes below.
After the prerequisites are installed pymgclient can be installed via pip::
$ pip3 install --user pymgclient --no-binary :all:
This will download the source package of pymgclient and build the binary
package before installing it. Alternatively pymgclient can be installed by
using :file:`setup.py`::
$ python3 setup.py install
Technical note for arm64 machines
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
The default installed Python is in the so called `Universal Binary 2
`_ format. That
means all of the packages that are built with this Python version have to be
built also as a universal binary. Though pymgclient builds on both x86_64 and
arm64 architectures, the brew installed OpenSSL version only contains the arm64
binaries. As a consequence, during building the x86_64 part of the universal
binary of pymgclient, the linker fails, because it cannot find the OpenSSL
binaries in x86_64 binary format.
Building on Windows
*******************
Building pymgclient on Windows is only advised for advanced users, therefore
the following description assumes technical knowledge about Windows,
compiling C/C++ applications and Python package.
To build pymgclient on Windows, the `MSYS2 `_
environment is needed. Once it is installed, run "MSYS2 MSYS" from Start menu
and install the necessary packages::
$ pacman -Su
$ pacman -S --needed base-devel mingw-w64-x86_64-toolchain \
mingw-w64-x86_64-cmake mingw-w64-x86_64-openssl
After installation, add the :file:`/mingw64/bin` (by default this
is :file:`C:/msys64/mingw64/bin`) to the :envvar:`PATH` environment variable to
make the installed applications accessible from the default Windows command
prompt. Once it is done, start the Windows command prompt and make sure the
applications are available, e.g. checking the version of gcc::
$ gcc --version
When the environment is done, start the Windows command prompt and install
pymgclient can be installed via pip::
$ pip install --user pymgclient --no-binary :all:
Alternatively pymgclient can be installed by using :file:`setup.py`::
$ python setup.py install
######################
Running the test suite
######################
If pymgclient is installed from downloaded source, you can run the test suite
to verify it is working correctly. From the source directory, you can run::
$ python3 -m pytest
To run the tests, you will need to have Memgraph, pytest and pyopenssl
installed on your machine. The tests will try to start the Memgraph binary from
the standard installation path (usually :file:`/usr/lib/memgraph/memgraph`)
listening on port 7687. You can configure a different path or port by setting
the following environment variables:
* :envvar:`MEMGRAPH_PATH`
* :envvar:`MEMGRAPH_PORT`
Alternatively you can also run the tests with an already running Memgraph
by configuring the host and port by setting the following environment
variables:
* :envvar:`MEMGRAPH_HOST`
* :envvar:`MEMGRAPH_PORT`
When an already running Memgraph is used, then some of the tests might get
skipped if Memgraph hasn't been started with a suitable configuration. The
:envvar:`MEMGRAPH_STARTED_WITH_SSL` environment variable can be used to
indicate whether Memgraph is started using SSL or not. If the environment
variable is defined (regardless its value), then the tests connect via secure
Bolt connection, otherwise they connect with regular Bolt connection.
The **tests insert data into Memgraph**, so they shouldn't be used with
a Memgraph running in "production" environment.
.. _mgclient: https://github.com/memgraph/mgclient
.. _brew: https://brew.sh