Universal cheminformatics toolkit, utilities and database search tools
Copyright © 2009-2022 EPAM Systems, Inc.
Licensed under the Apache License version 2.0
This repository includes:
Detailed documentation is available at http://lifescience.opensource.epam.com
Changelog could be found in CHANGELOG.md.
https://lifescience.opensource.epam.com/download/indigo.html
Main directory structure layout:
api
: Indigo API sourcesbingo
: Bingo sourcescore
: Core algorithms and data structures sourcesthird_party
: sources for third-party librariesutils
: utilities sourcesEach project is placed in the corresponding directory with CMakeList.txt configuration
file, that does not include other projects. In order to build the whole project with the
correct references you need to use CMake configurations from the build_scripts directory.
To build the project from the sources, the following tools should be installed:
Required:
Required to build all targets:
Required to build Indigo-WASM:
Python
python -m pip install wheel
python -m pip install setuptools==68.0.0
python -m pip install waitress
python -m pip install flasgger
python -m pip install psycopg2
python -m pip install sqlalchemy
python -m pip install numpy
python -m pip install celery
python -m pip install marshmallow
python -m pip install redis
python -m pip install flask_httpauth
python -m pip install pyparsing
python -m pip install requests
On Linux use python3 insted of python. Using virtual environment might be required as well.
On Windows use cmd to run the commands.
Create build folder
mkdir build
Move to build folder
cd build
Run CMake to configure the project with desired options. For instance:
cmake .. -DBUILD_INDIGO=ON -DBUILD_INDIGO_WRAPPERS=ON -DBUILD_INDIGO_UTILS=ON
Build Indigo from console:
cmake --build . --config Release --target <target name>
Replace <target name> with any of the following targets you need:
Build results could be collected from Indigo/dist folder.
‘indigo-python’ target is commonly used.
Befor running any test you have to build and install indigo-python
--target indigo-python
or --target ALL_BUILD
(on Windows) or --target all
(on Linux). See Build instruction above.
- On Windows the package should be in ‘Indigo/api/python/dist’ folder
- On Linux it is located in ‘Indigo\dist’ folder
Package will be named like ‘epam.indigo-<version-arch>.whl’. For instance: epam.indigo-1.29.0.dev2-py3-none-win_amd64.whl
Install package using pip
- If Indigo package has been already installed, uninstall it with the following command:
python -m pip uninstall <path-to-.whl-file> -y
python -m pip install <path-to-.whl-file>
Replace <path-to-.whl-file> with the right path to .whl package. For instance:
python -m pip install ../api/python/dist/epam.indigo-1.29.0.dev2-py3-none-win_amd64.whl
Run integration test
to run all test
python api/tests/integration/test.py -t 1
to run tests by mask use
test_name
python api/tests/integration/test.py -t 1 -p test_name
Build and install indigo-python
Set environment variable by running this command:
for Linux
export INDIGO_SERVICE_URL=http://localhost:5000/v2
for Windows in PowerShell
$env:INDIGO_SERVICE_URL="http://localhost:5000/v2"
Run backend service :
cd utils/indigo-service/backend/service
cp v2/common/config.py .
waitress-serve --listen="127.0.0.1:5000 [::1]:5000" app:app
you may use any port instead of 5000
Run backend API test:
python utils/indigo-service/backend/service/tests/api/indigo_test.py`
use
-k test_name
to run test by pattern.
Make sure git is running from path:
>git --version
git version 2.26.2.windows.1
Make sure python is running from path:
>python --version
Python 3.9.0
Make sure cmake is running from path:
>cmake --version
cmake version 3.18.4
Download corresponding ninja-xxx.zip and unpack to folder on path.
Make sure it’s running from path:
>ninja --version
1.10.2
git clone https://github.com/emscripten-core/emsdk.git
cd emsdk
./emsdk install latest
./emsdk activate latest
source ./emsdk_env.sh
Note: On Windows, run emsdk
instead of ./emsdk
, and emsdk_env.bat
instead of source ./emsdk_env.sh
, use cmd
instead of powershell
.
Clone (or checkout) Indigo repository
>git clone https://github.com/epam/Indigo.git
For each new session, set environment anew:
>cd emsdk
>./emsdk activate latest
If fresh build:
>mkdir build
>cd build
Now build:
>emcmake cmake .. -DCMAKE_BUILD_TYPE=Debug -G Ninja
>ninja indigo-ketcher-js-test