Newer
Older
[](https://travis-ci.org/Nheko-Reborn/mtxclient)
[](https://ci.appveyor.com/project/redsky17/mtxclient/branch/master)
[](https://codecov.io/gh/Nheko-Reborn/mtxclient)
[](http://github.com/badges/stability-badges)
[](https://nheko-reborn.pages.nheko.im/mtxclient/index.html)
- CMake 3.15 or greater (lower versions can work, but not all build system options may work.)
If you are missing some or all of those above dependencies, you can add `-DHUNTER_ENABLED=ON` to the cmake configure command to use bundled dependencies. You can finetune them with the following variables. They default to ON, if Hunter is enabled and to OFF otherwise.
| cmake flag | description |
|---------------------|-------------|
| USE_BUNDLED_COEURL | Use the bundled version of coeurl. |
| USE_BUNDLED_LIBEVENT| Use the bundled version of libevent (coeurl dependency). |
| USE_BUNDLED_LIBCURL | Use the bundled version of curl (coeurl dependency). |
| USE_BUNDLED_COEURL | Use the bundled version of coeurl. |
| USE_BUNDLED_SPDLOG | Use the bundled version of spdlog. |
| USE_BUNDLED_OLM | Use the bundled version of libolm. |
| USE_BUNDLED_GTEST | Use the bundled version of Google Test. |
| USE_BUNDLED_JSON | Use the bundled version of nlohmann json. |
| USE_BUNDLED_OPENSSL | Use the bundled version of OpenSSL. |
| USE_BUNDLED_RE2 | Use the bundled version of re2. |
Below is an example which will build the library along with the tests & examples.
cmake -S. -Bbuild -DCMAKE_BUILD_TYPE=Debug
cmake --build build
```
#### macOS
You will need to pass as argument (`-DOPENSSL_ROOT_DIR`) the installation root of openssl.
cmake -S. -Bbuild -DCMAKE_BUILD_TYPE=Debug -DOPENSSL_ROOT_DIR=/usr/local/opt/openssl
cmake --build build
```
You can toggle off the tests & examples by passing `-DBUILD_LIB_TESTS=OFF` &
`-DBUILD_LIB_EXAMPLES=OFF` respectively.
## Running the tests
In order to run the integration tests you'll need a local synapse instance. You
can start an instance with docker by running the following
```bash
make synapse
```
then run the test suite
```bash
make test
```