diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index 25ea73d..7eba4e7 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -3,7 +3,7 @@ name: Publish cgat-daisy wheels to PyPI and TestPyPI on: push: branches: - - v[0-9]+.[0-9]+.x + - v[0-9]+.[0-9]+* tags: - v* release: @@ -11,13 +11,12 @@ on: - published jobs: - build_wheels: + build: name: Build wheels on ${{ matrix.os }} runs-on: ${{ matrix.os }} strategy: matrix: - os: [ubuntu-latest, macos-latest] - cibw_archs: ["auto"] + os: [ubuntu-latest] steps: - name: Checkout cgat-daisy @@ -30,41 +29,18 @@ jobs: - name: Run image uses: abatilo/actions-poetry@v2.0.0 - - - name: Poetry install - run: poetry install - + - name: Poetry install run: poetry build --format=sdist - - - name: Build wheels for linux - if: runner.os == 'Linux' - uses: pypa/cibuildwheel@v2.2.2 - env: - CIBW_BUILD: cp36-* cp37-* cp38-* cp39-* cp310-* - CIBW_SKIP: "*musllinux*" - CIBW_ARCHS: ${{ matrix.cibw_archs }} - - # - name: Build wheels for macos - # if: runner.os != 'Linux' - # uses: pypa/cibuildwheel@v2.2.2 - # env: - # CIBW_BUILD: cp36-* cp37-* cp38-* cp39-* cp310-* - # CIBW_BEFORE_BUILD: pip install cython - # CIBW_ARCHS: ${{ matrix.cibw_archs }} - - uses: actions/upload-artifact@v2 - with: - path: dist/*.tar.gz - + - name: Upload artifacts uses: actions/upload-artifact@v2 with: - path: ./wheelhouse/*.whl + path: dist/* - upload_pypi: - needs: [build_wheels, build_sdist] + needs: [build] runs-on: ubuntu-latest steps: @@ -75,17 +51,19 @@ jobs: path: dist - name: Publish distribution to Test PyPI - if: github.event_name == 'push' && startsWith(github.event.ref, 'refs/tags/v') + if: github.event_name == 'push' uses: pypa/gh-action-pypi-publish@master with: + verbose: true user: __token__ password: ${{ secrets.TEST_PYPI_API_TOKEN }} repository_url: https://test.pypi.org/legacy/ - # - name: Publish distribution to PyPI - # if: github.event_name == 'release' && github.event.action == 'published' - # uses: pypa/gh-action-pypi-publish@master - # with: - # user: __token__ - # password: ${{ secrets.PYPI_API_TOKEN }} + - name: Publish distribution to PyPI + if: github.event_name == 'release' && github.event.action == 'published' + uses: pypa/gh-action-pypi-publish@master + with: + verbose: true + user: __token__ + password: ${{ secrets.PYPI_API_TOKEN }} diff --git a/.travis.yml b/.travis.yml deleted file mode 100644 index bc9ffee..0000000 --- a/.travis.yml +++ /dev/null @@ -1,36 +0,0 @@ -# https://docs.travis-ci.com/user/multi-os/ -os: - - osx - - linux - -# use container-based infrastructure on Travis -# http://docs.travis-ci.com/user/workers/container-based-infrastructure/ -# http://blog.travis-ci.com/2014-12-17-faster-builds-with-container-based-infrastructure/ -#sudo: false - -# use VM infrastructure on Travis -# exit code 137 indicates that your build is now taking more memory -# or rather it's running alongside other builds requiring a lot of memory. -# This can happen because your builds are running on container-based infrastructure and they will share the host's 4 GB memory. -# To mitigate this situation, run your builds on our sudo-enabled Precise infrastructure. -# Over there, your builds will run on a fully independent VM with 7.5 GB of (unshared) memory. -sudo: required - -# http://mailchi.mp/travis-ci/ubuntu-trusty-update-2017q4-and-new-ltslatest-process?e=073d892e7f -group: edge - -language: generic - -env: - - TEST_ALL=1 - -# Using xvfb to Run Tests That Require a GUI -# NOTE: The "before_script" section below does not work properly, but right now is not required -# Linux: https://docs.travis-ci.com/user/gui-and-headless-browsers/#Using-xvfb-to-Run-Tests-That-Require-a-GUI -# OS X:https://github.com/travis-ci/travis-ci/issues/7313#issuecomment-279914149 -# before_script: -# - if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then export DISPLAY=:99.0 && sh -e /etc/init.d/xvfb start && sleep 3 ; fi -# - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then ( sudo Xvfb :99 -ac -screen 0 1024x768x8 && echo ok )& ; fi - -script: - - travis_wait 30 ./install.sh --travis diff --git a/README.md b/README.md new file mode 100644 index 0000000..c8fb6ac --- /dev/null +++ b/README.md @@ -0,0 +1,33 @@ +# Daisy/CGAT Bench + +Daisy is a system to design and execute benchmarking tasks. + +After installation, use the ``daisy`` command to see how to use them. + +For questions, please open a discussion on the GitHub +`issue page `_. + +Installation +============ + +daisy is available via pypi: + +``` +pip install cgat-daisy +``` + +or in conda: + +``` +conda install cgat-daisy +``` + +Usage +===== + +Run the ``daisy --help`` for the tools that are available. + +Documentation +============= + +Full documentation is on RTD (WIP) diff --git a/README.rst b/README.rst deleted file mode 100644 index 606d7ce..0000000 --- a/README.rst +++ /dev/null @@ -1,63 +0,0 @@ -.. image:: https://travis-ci.org/cgat-developers/cgat-daisy.svg?branch=master - :target: https://travis-ci.org/cgat-developers/cgat-daisy - -================ -Daisy/CGAT Bench -================ - -Daisy is a system to design and execute benchmarking tasks. - -After installation, use the ``daisy`` command to see how to use them. - -For questions, please open a discussion on the GitHub -`issue page `_. - -Installation -============ - -Install using Conda -------------------- - -The preferred method to install Daisy is using the installation script, which uses -`Conda `_. - -Here are the steps:: - - # download installation script: - curl -O https://raw.githubusercontent.com/cgat-developers/cgat-daisy/master/install-CGAT-tools.sh - - # see help: - bash install-CGAT-tools.sh - - # install the development version (recommended, no production version yet): - bash install-CGAT-tools.sh --devel [--location ] - - # the code is downloaded in zip format by default. If you want to get a git clone, use: - --git # for an HTTPS clone - --git-ssh # for a SSH clone (you need to be a cgat-developer contributor on GitHub to do this) - - # enable the conda environment as requested by the installation script - # NB: you probably want to automate this by adding the instructions below to your .bashrc - source /conda-install/etc/profile.d/conda.sh - conda activate base - conda activate cgat-a - - # finally, please run the cgatflow command-line tool to check the installation: - cgat --help - -The installation script will put everything under the specified location. The aim is to provide a portable -installation that does not interfere with the existing software. As a result, you will get a conda environment -working with CGAT Apps which can be enabled on demand according to your needs. - -Usage -===== - -Run the ``daisy --help`` for the tools that are available. - -Documentation -============= - -Full documentation is on RTD (WIP) - - -.. _cgat-core: https://github.com/cgat-developers/cgat-core diff --git a/conda/environments/bench-devel.yml b/conda/environments/bench-devel.yml deleted file mode 100644 index f4c9c47..0000000 --- a/conda/environments/bench-devel.yml +++ /dev/null @@ -1,15 +0,0 @@ -name: cgat-b - -channels: -- bioconda -- conda-forge -- defaults - -dependencies: -- cgatcore -- pandas -- sqlalchemy -- ruffus -- ruamel_yaml -- pytest -- pysam diff --git a/install.sh b/install.sh deleted file mode 100755 index 60c674e..0000000 --- a/install.sh +++ /dev/null @@ -1,886 +0,0 @@ -#!/usr/bin/env bash - -# References -# http://kvz.io/blog/2013/11/21/bash-best-practices/ -# http://jvns.ca/blog/2017/03/26/bash-quirks/ - -# exit when a command fails -set -o errexit - -# exit if any pipe commands fail -set -o pipefail - -# exit when your script tries to use undeclared variables -#set -o nounset - -# trace what gets executed -set -o xtrace - -# Bash traps -# http://aplawrence.com/Basics/trapping_errors.html -# https://stelfox.net/blog/2013/11/fail-fast-in-bash-scripts/ - -set -o errtrace - -SCRIPT_NAME="$0" -SCRIPT_PARAMS="$@" - -error_handler() { - echo - echo " ########################################################## " - echo - echo " An error occurred in:" - echo - echo " - line number: ${1}" - shift - echo " - exit status: ${1}" - shift - echo " - command: ${@}" - echo - echo " The script will abort now. User input was: " - echo - echo " ${SCRIPT_NAME} ${SCRIPT_PARAMS}" - echo - echo " Please copy and paste this error and report it via Git Hub: " - echo " https://github.com/cgat-developers/cgat-flow/issues " - print_env_vars - echo " ########################################################## " -} - -trap 'error_handler ${LINENO} $? ${BASH_COMMAND}' ERR INT TERM - -# log installation information -log() { - echo "# install.sh log | `hostname` | `date` | $1 " -} - -# report error and exit -report_error() { - echo - echo $1 - echo - echo "Aborting." - echo - exit 1 -} - -# detect CGAT installation -detect_cgat_installation() { - - if [[ -z "$CGAT_HOME" ]] ; then - - if [[ -d "$HOME/cgat-install/conda-install" ]] ; then - UNINSTALL_DIR="$HOME/cgat-install" - fi - - else - - if [[ -d "$CGAT_HOME/conda-install" ]] ; then - UNINSTALL_DIR="$CGAT_HOME" - fi - - fi - -} # detect_cgat_installation - - -# configure environment variables -# set: CGAT_HOME, CONDA_INSTALL_DIR, CONDA_INSTALL_TYPE_CORE -get_cgat_env() { - - if [[ $TRAVIS_INSTALL ]] ; then - - CGAT_HOME=$TRAVIS_BUILD_DIR - CONDA_INSTALL_TYPE_BENCH="bench-devel.yml" - CONDA_INSTALL_TYPE_CORE="core-production.yml" - - elif [[ $JENKINS_INSTALL ]] ; then - - CGAT_HOME=$WORKSPACE - CONDA_INSTALL_TYPE_BENCH="bench-devel.yml" - CONDA_INSTALL_TYPE_CORE="core-production.yml" - - else - - if [[ -z $CGAT_HOME ]] ; then - CGAT_HOME=$HOME/cgat-install - fi - - if [[ $INSTALL_PRODUCTION ]] ; then - CONDA_INSTALL_TYPE_BENCH="bench-production.yml" - CONDA_INSTALL_TYPE_CORE="core-production.yml" - elif [[ $INSTALL_DEVEL ]] ; then - CONDA_INSTALL_TYPE_BENCH="bench-devel.yml" - CONDA_INSTALL_TYPE_CORE="core-devel.yml" - elif [[ $INSTALL_TEST ]] || [[ $INSTALL_UPDATE ]] ; then - if [[ -d $CGAT_HOME/conda-install ]] ; then - AUX=`find $CGAT_HOME/conda-install/envs/cgat-* -maxdepth 0` - else - echo - echo " The location of the CGAT code was not found (function: get_cgat_env). " - echo " Please install it first or use --location option with full path to your installation. " - echo - exit 1 - fi - else - echo - echo " Wrong installation type! " - echo " Installation aborted. " - echo - exit 1 - fi # if install type - - fi # if travis install - - # set installation folder - CONDA_INSTALL_DIR=$CGAT_HOME/conda-install - - # set conda environment name - [[ ${CONDA_INSTALL_ENV} ]] || CONDA_INSTALL_ENV="cgat-f" - -} # get_cgat_env - - -# setup environment variables -setup_env_vars() { - - export CFLAGS=$CFLAGS" -I$CONDA_INSTALL_DIR/envs/$CONDA_INSTALL_ENV/include -L$CONDA_INSTALL_DIR/envs/$CONDA_INSTALL_ENV/lib" - export CPATH=$CPATH" -I$CONDA_INSTALL_DIR/envs/$CONDA_INSTALL_ENV/include -L$CONDA_INSTALL_DIR/envs/$CONDA_INSTALL_ENV/lib" - export C_INCLUDE_PATH=$C_INCLUDE_PATH:$CONDA_INSTALL_DIR/envs/$CONDA_INSTALL_ENV/include - export CPLUS_INCLUDE_PATH=$CPLUS_INCLUDE_PATH:$CONDA_INSTALL_DIR/envs/$CONDA_INSTALL_ENV/include - export LIBRARY_PATH=$LIBRARY_PATH:$CONDA_INSTALL_DIR/envs/$CONDA_INSTALL_ENV/lib - export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$CONDA_INSTALL_DIR/envs/$CONDA_INSTALL_ENV/lib:$CONDA_INSTALL_DIR/envs/$CONDA_INSTALL_ENV/lib/R/lib - -} # setup_env_vars - -# print related environment variables -print_env_vars() { - - echo - echo " Debugging: " - echo " CFLAGS: "$CFLAGS - echo " CPATH: "$CPATH - echo " C_INCLUDE_PATH: "$C_INCLUDE_PATH - echo " CPLUS_INCLUDE_PATH: "$CPLUS_INCLUDE_PATH - echo " LIBRARY_PATH: "$LIBRARY_PATH - echo " LD_LIBRARY_PATH: "$LD_LIBRARY_PATH - echo " CGAT_HOME: "$CGAT_HOME - echo " CONDA_INSTALL_DIR: "$CONDA_INSTALL_DIR - echo " CONDA_INSTALL_TYPE_CORE:"$CONDA_INSTALL_TYPE_CORE - echo " CONDA_INSTALL_TYPE_BENCH: "$CONDA_INSTALL_TYPE_BENCH - echo " CONDA_INSTALL_ENV: "$CONDA_INSTALL_ENV - echo " PYTHONPATH: "$PYTHONPATH - [[ ! $INSTALL_TEST ]] && echo " INSTALL_BRANCH: "$INSTALL_BRANCH - [[ ! $INSTALL_TEST ]] && echo " CORE_BRANCH: "$CORE_BRANCH - [[ ! $INSTALL_TEST ]] && echo " RELEASE: "$RELEASE - echo " CODE_DOWNLOAD_TYPE: "$CODE_DOWNLOAD_TYPE - echo " CLUSTER: "$CLUSTER - echo - -} # print_env_vars - -# Travis installations are running out of RAM -# with large conda installations. Issue has been submitted here: -# https://github.com/conda/conda/issues/1197 -# While we wait for a response, we'll try to clean up the conda -# installation folder as much as possible -conda_cleanup() { - conda clean --index-cache - conda clean --lock - conda clean --tarballs -y - conda clean --packages -y -} - - -# proceed with conda installation -conda_install() { - - log "installing conda" - - detect_cgat_installation - - if [[ -n "$UNINSTALL_DIR" ]] ; then - - echo - echo " An installation of the CGAT code was found in: $UNINSTALL_DIR" - echo " Please use --location to install CGAT code in a different location " - echo " or uninstall the current version before proceeding." - echo - echo " Installation is aborted." - echo - exit 1 - - fi - - # get environment variables: CGAT_HOME, CONDA_INSTALL_DIR - get_cgat_env - - mkdir -p $CGAT_HOME - cd $CGAT_HOME - - # select Miniconda bootstrap script depending on Operating System - MINICONDA= - - if [[ `uname` == "Linux" ]] ; then - - # Conda 4.4 breaks everything again! - # Conda 4.5 looks better - MINICONDA="Miniconda3-latest-Linux-x86_64.sh" - #MINICONDA="Miniconda3-4.3.31-Linux-x86_64.sh" - - elif [[ `uname` == "Darwin" ]] ; then - - # Conda 4.4 breaks everything again! - # Conda 4.5 looks better - MINICONDA="Miniconda3-latest-MacOSX-x86_64.sh" - #MINICONDA="Miniconda3-4.3.31-MacOSX-x86_64.sh" - - else - - echo - echo " Unsupported operating system detected. " - echo - echo " Aborting installation... " - echo - exit 1 - - fi - - log "downloading miniconda" - # download and install conda - curl -O https://repo.anaconda.com/miniconda/${MINICONDA} - - log "installing miniconda" - bash ${MINICONDA} -b -p $CONDA_INSTALL_DIR - source ${CONDA_INSTALL_DIR}/bin/activate - hash -r - - # install cgat environment - # Conda 4.4 breaks everything again! - # Conda 4.5 looks better - #conda install --quiet --yes 'conda=4.3.33' - conda update --all --yes - conda info -a - - log "installing conda CGAT environment" - - # Now using conda environment files: - # https://conda.io/docs/using/envs.html#use-environment-from-file - - [[ -z ${TRAVIS_BRANCH} ]] && TRAVIS_BRANCH=${INSTALL_BRANCH} - - curl -o env-bench.yml -O https://raw.githubusercontent.com/cgat-developers/cgat-bench/${TRAVIS_BRANCH}/conda/environments/${CONDA_INSTALL_TYPE_BENCH} - - curl -o env-core.yml -O https://raw.githubusercontent.com/cgat-developers/cgat-core/${CORE_BRANCH}/conda/environments/${CONDA_INSTALL_TYPE_CORE} - - conda env update --quiet --name ${CONDA_INSTALL_ENV} --file env-bench.yml - conda env update --quiet --name ${CONDA_INSTALL_ENV} --file env-core.yml - - # activate cgat environment - source $CONDA_INSTALL_DIR/bin/activate $CONDA_INSTALL_ENV - - log "installing CGAT code into conda environment" - # if installation is 'devel' (outside of travis), checkout latest version from github - if [[ -z ${TRAVIS_INSTALL} ]] ; then - - DEV_RESULT=0 - - if [[ $INSTALL_DEVEL ]] || [[ $INSTALL_PRODUCTION ]] || [[ $JENKINS_INSTALL ]] ; then - - # download the code out of jenkins - if [[ -z ${JENKINS_INSTALL} ]] ; then - - # make sure you are in the CGAT_HOME folder - cd $CGAT_HOME - - if [[ $CODE_DOWNLOAD_TYPE -eq 0 ]] ; then - # get the latest version from Git Hub in zip format - curl -LOk https://github.com/cgat-developers/cgat-bench/archive/$INSTALL_BRANCH.zip - unzip $INSTALL_BRANCH.zip - rm $INSTALL_BRANCH.zip - if [[ ${RELEASE} ]] ; then - NEW_NAME=`echo $INSTALL_BRANCH | sed 's/^v//g'` - mv cgat-bench-$NEW_NAME/ cgat-bench/ - else - mv cgat-bench-$INSTALL_BRANCH/ cgat-bench/ - fi - elif [[ $CODE_DOWNLOAD_TYPE -eq 1 ]] ; then - # get latest version from Git Hub with git clone - git clone --branch=$INSTALL_BRANCH https://github.com/cgat-developers/cgat-bench.git - elif [[ $CODE_DOWNLOAD_TYPE -eq 2 ]] ; then - # get latest version from Git Hub with git clone - git clone --branch=$INSTALL_BRANCH git@github.com:cgat-developers/cgat-bench.git - else - report_error " Unknown download type for CGAT code... " - fi - - # make sure you are in the CGAT_HOME/cgat-bench folder - cd $CGAT_HOME/cgat-bench - - fi - - # Set up other environment variables - setup_env_vars - - # brute force: modify console_scripts variable/entry point for cgat command - # sed -i'' -e 's/CGATScripts/scripts/g' setup.py - - # Python preparation - python setup.py develop - - if [[ $? -ne 0 ]] ; then - echo - echo " There was a problem doing: 'python setup.py develop' " - echo " Installation did not finish properly. " - echo - echo " Please submit this issue via Git Hub: " - echo " https://github.com/cgat-developers/cgat-flow/issues " - echo - - print_env_vars - - fi # if-$? - - # revert setup.py if downloaded with git - [[ $CODE_DOWNLOAD_TYPE -ge 1 ]] && git checkout -- setup.py - - # environment pinning - # python scripts/conda.py - - fi # if INSTALL_DEVEL - - # check whether conda create went fine - if [[ $DEV_RESULT -ne 0 ]] ; then - echo - echo " There was a problem installing the code with conda. " - echo " Installation did not finish properly. " - echo - echo " Please submit this issue via Git Hub: " - echo " https://github.com/cgat-developers/cgat-flow/issues " - echo - - print_env_vars - - else - clear - echo - echo " The code successfully installed!" - echo - echo " To activate the CGAT environment type: " - echo " $ source $CONDA_INSTALL_DIR/etc/profile.d/conda.sh" - echo " $ conda activate base" - echo " $ conda activate $CONDA_INSTALL_ENV" - [[ $INSTALL_PRODUCTION ]] && echo " cgatflow --help" - echo - echo " To deactivate the environment, use:" - echo " $ conda deactivate" - echo - fi # if-$ conda create - - else # if travis install - log "performing travis install" - - log "installing daisy" - cd $CGAT_HOME - python setup.py develop - fi - - # smoke-test, check if daisy-command is available - log 'checking if daisy is on the path' - which daisy - log 'checking if daisy is executable' - daisy - -} # conda install - - -# test code with conda install -conda_test() { - - log "starting conda_test" - - # get environment variables: CGAT_HOME, CONDA_INSTALL_DIR, CONDA_INSTALL_TYPE_CORE - get_cgat_env - - setup_env_vars - - # enable Conda env - log "activating CGAT conda environment" - source $CONDA_INSTALL_DIR/bin/activate $CONDA_INSTALL_ENV - - # show conda environment used for testing - conda env export - - cd $CGAT_HOME - - log "starting tests" - pytest tests - -} # conda_test - - -# update conda installation -conda_update() { - - # get environment variables: CGAT_HOME, CONDA_INSTALL_DIR, CONDA_INSTALL_TYPE_CORE - get_cgat_env - - source $CONDA_INSTALL_DIR/bin/activate $CONDA_INSTALL_ENV - conda update --all - - if [[ ! $? -eq 0 ]] ; then - - echo - echo " There was a problem updating the installation. " - echo - echo " Please submit this issue via Git Hub: " - echo " https://github.com/cgat-developers/cgat-flow/issues " - echo - - else - - echo - echo " All packages were succesfully updated. " - echo - - fi - -} # conda_update - - -# unistall CGAT code collection -uninstall() { - - detect_cgat_installation - - if [[ -z "$UNINSTALL_DIR" ]] ; then - - echo - echo " The location of the CGAT code was not found. " - echo " Please uninstall manually." - echo - exit 1 - - else - - rm -rf $UNINSTALL_DIR - if [[ $? -eq 0 ]] ; then - echo - echo " CGAT code successfully uninstalled." - echo - exit 0 - else - echo - echo " There was a problem uninstalling the CGAT code." - echo " Please uninstall manually." - echo - exit 1 - fi - fi - -} - - -# test whether --git and --git-ssh download is doable -test_git() { - git --version >& /dev/null || GIT_AVAIL=$? - if [[ $GIT_AVAIL -ne 0 ]] ; then - echo - echo " Git is not available but --git or --git-ssh option was given." - echo " Please rerun this script on a computer with git installed " - echo " or try again without --git or --git-ssh" - report_error " " - fi -} - - -# test whether --git-ssh download is doable -test_git_ssh() { - ssh-add -L >& /dev/null || SSH_KEYS_LOADED=$? - if [[ $SSH_KEYS_LOADED -ne 0 ]] ; then - echo - echo " Please load your ssh keys for GitHub before proceeding!" - echo - echo " Try: " - echo " 1. eval \$(ssh-agent)" - echo " 2. ssh-add ~/.ssh/id_rsa # or the file where your private key is" - report_error " and run this script again. " - fi -} - - -# don't mix branch and release options together -test_mix_branch_release() { - # don't mix branch and release options together - if [[ $RELEASE ]] ; then - if [[ "$INSTALL_BRANCH" != "master" ]] || [[ $CORE_BRANCH != "master" ]] ; then - echo - echo " You cannot mix git branches and releases for the installation." - echo - echo " Your input was: "$SCRIPT_PARAMS - report_error " Please either use branches or releases but not both." - fi - fi -} - - -# test whether a branch exists in the cgat-core repository -# https://stackoverflow.com/questions/12199059/how-to-check-if-an-url-exists-with-the-shell-and-probably-curl -test_core_branch() { - RELEASE_TEST=0 - curl --output /dev/null --silent --head --fail https://raw.githubusercontent.com/cgat-developers/cgat-core/${CORE_BRANCH}/README.rst || RELEASE_TEST=$? - if [[ ${RELEASE_TEST} -ne 0 ]] ; then - echo - echo " The branch provided for cgat-core does not exist: ${CORE_BRANCH}" - echo - echo " Please have a look at valid branches here: " - echo " https://github.com/cgat-developers/cgat-core/branches" - echo - report_error " Please use a valid branch and try again." - fi -} - - -# test whether a release exists or not -# https://stackoverflow.com/questions/12199059/how-to-check-if-an-url-exists-with-the-shell-and-probably-curl -test_release() { - RELEASE_PIPELINES=0 - # check pipelines - curl --output /dev/null \ - --silent --head --fail \ - https://raw.githubusercontent.com/cgat-developers/cgat-flow/${RELEASE}/README.rst || RELEASE_PIPELINES=$? - - if [[ ${RELEASE_PIPELINES} -ne 0 ]] ; then - echo - echo " The release number provided for the pipelines does not exist: ${RELEASE}" - echo - echo " Please have a look at valid releases here: " - echo " https://github.com/cgat-developers/cgat-flow/releases" - echo - echo " An example of valid release is: --release v0.4.0" - report_error " Please use a valid release and try again." - fi - - RELEASE_SCRIPTS=0 - # check scripts - curl --output /dev/null \ - --silent --head --fail \ - https://raw.githubusercontent.com/cgat-developers/cgat-bench/${RELEASE}/README.rst || RELEASE_SCRIPTS=$? - - if [[ ${RELEASE_SCRIPTS} -ne 0 ]] ; then - echo - echo " The release number provided for the scripts does not exist: ${RELEASE}" - echo - echo " Please have a look at valid releases here: " - echo " https://github.com/cgat-developers/cgat-bench/releases" - echo - echo " An example of valid release is: --release v0.4.0" - report_error " Please use a valid release and try again." - fi -} - - -# clean up environment -# deliberately use brute force -cleanup_env() { - set +e - source deactivate >& /dev/null || true - source deactivate >& /dev/null || true - unset -f conda || true - unset PYTHONPATH || true - # Next actions disabled. Please see: - # https://github.com/cgat-developers/cgat-core/issues/44 - #module purge >& /dev/null || true - #mymodule purge >& /dev/null || true - set -e -} - - -# function to display help message -help_message() { - echo - echo " This script uses Conda to install cgat-flow. To proceed, please type:" - echo " ./install.sh --devel [--location ]" - echo - echo " The default install folder will be: $HOME/cgat-install" - echo - echo " It is also possible to install/test a specific branch of the code on GitHub:" - echo " ./install.sh --devel --pipelines-branch --scripts-branch --core-branch " - echo - echo " This will create an isolated Conda environment with both the pipelines and the scripts from:" - echo " https://github.com/cgat-developers/cgat-bench" - echo - echo " The default name of the newly created conda environment is cgat-f, but you can change it with:" - echo " --env-name name" - echo - echo " The code is downloaded in zip format by default. If you want to get a git clone, use:" - echo " --git # for an HTTPS clone" - echo " --git-ssh # for a SSH clone (you need to be a CGATOXford contributor on GitHub to do this)" - echo - echo " The pipelines are intended to run on a cluster using the DRMAA API. If that's not your case, please use:" - echo " --no-cluster" - echo - echo " If you want to download and install IDEs like Spyder or RStudio with this installation, please use:" - echo " --ide" - echo - echo " To test the installation:" - echo " ./install.sh --test [--location ]" - echo - echo " To update the Conda packages:" - echo " ./install.sh --update [--location ]" - echo - echo " To uninstall the CGAT code:" - echo " ./install.sh --uninstall [--location ]" - echo - echo " Please submit any issues via Git Hub:" - echo " https://github.com/cgat-developers/cgat-flow/issues" - echo - exit 1 -} # help_message - -# the script starts here - -cleanup_env - -if [[ $# -eq 0 ]] ; then - - help_message - -fi - -# travis execution -TRAVIS_INSTALL= -# jenkins testing -JENKINS_INSTALL= -# conda installation type -INSTALL_PRODUCTION= -INSTALL_DEVEL= -# test current installation -INSTALL_TEST= -# update current installation -INSTALL_UPDATE= -# uninstall CGAT code -UNINSTALL= -UNINSTALL_DIR= -# where to install CGAT code -# default value is in HOME -CGAT_HOME=$HOME/cgat-install -# how to download CGAT code: -# 0 = as zip (default) -# 1 = git clone with https -# 2 = git clone with ssh -CODE_DOWNLOAD_TYPE=0 -# which github branch to use (default: master) -INSTALL_BRANCH="master" -# which github branch to use for cgat-core (default: master) -CORE_BRANCH="master" -# type of installation -CONDA_INSTALL_TYPE_BENCH= -CONDA_INSTALL_TYPE_CORE= -# rename conda environment -CONDA_INSTALL_ENV= -# install additional IDEs? -# 0 = no (default) -# 1 = yes -INSTALL_IDE=0 -# Use cluster? -# 0 = no -# 1 = yes (default) -CLUSTER=1 -# Install a released version? -RELEASE= - -# parse input parameters -# https://stackoverflow.com/questions/402377/using-getopts-in-bash-shell-script-to-get-long-and-short-command-line-options -# https://stackoverflow.com/questions/192249/how-do-i-parse-command-line-arguments-in-bash - -while [[ $# -gt 0 ]] -do - key="$1" - - case $key in - - --help) - help_message - ;; - - --travis) - TRAVIS_INSTALL=1 - shift # past argument - ;; - - --jenkins) - JENKINS_INSTALL=1 - shift # past argument - ;; - - --zip) - CODE_DOWNLOAD_TYPE=0 - shift - ;; - - --git) - CODE_DOWNLOAD_TYPE=1 - shift - test_git - ;; - - --git-ssh) - CODE_DOWNLOAD_TYPE=2 - shift - test_git - test_git_ssh - ;; - - --production) - INSTALL_PRODUCTION=1 - shift - ;; - - --devel) - INSTALL_DEVEL=1 - shift - ;; - - --test) - INSTALL_TEST=1 - shift - ;; - - --update) - INSTALL_UPDATE=1 - shift - ;; - - --uninstall) - UNINSTALL=1 - shift - ;; - - --location) - CGAT_HOME="$2" - shift 2 - ;; - - --bench-branch) - BENCH_BRANCH="$2" - test_mix_branch_release - shift 2 - ;; - - --core-branch) - CORE_BRANCH="$2" - test_core_branch - shift 2 - ;; - - --ide) - INSTALL_IDE=1 - shift - ;; - - --no-cluster) - CLUSTER=0 - shift - ;; - - --release) - RELEASE="$2" - test_mix_branch_release - test_release - CORE_BRANCH="$2" - BENCH_BRANCH="$2" - shift 2 - ;; - - --env-name) - CONDA_INSTALL_ENV="$2" - shift 2 - ;; - - --branch) - INSTALL_BRANCH="$2" - test_mix_branch_release - shift 2 - ;; - - --core-branch) - CORE_BRANCH="$2" - test_core_branch - shift 2 - ;; - - --release) - RELEASE="$2" - test_mix_branch_release - test_release - INSTALL_BRANCH="$2" - shift 2 - ;; - - *) - echo - echo - echo " Wrong input: ${SCRIPT_NAME} ${SCRIPT_PARAMS}" - echo " Offending key is ${key} " - echo - help_message - ;; - - esac -done - -# sanity check 1: don't mix production and development installs -if [[ $INSTALL_PRODUCTION ]] && [[ $INSTALL_DEVEL ]] ; then - - report_error " Incorrect input arguments: mixing --production and --devel is not permitted. " - -fi - -# sanity check 2: make sure one installation option is selected -if [[ -z $INSTALL_TEST ]] && \ - [[ -z $INSTALL_PRODUCTION ]] && \ - [[ -z $INSTALL_DEVEL ]] && \ - [[ -z $TRAVIS_INSTALL ]] && \ - [[ -z $JENKINS_INSTALL ]] ; then - - report_error " You need to select either --devel or --production. " - -fi - -# sanity check 3: make sure there is space available in the destination folder (20 GB) in 512-byte blocks -[[ -z ${TRAVIS_INSTALL} ]] && \ - mkdir -p ${CGAT_HOME} && \ - [[ `df -P ${CGAT_HOME} | awk '/\// {print $4}'` -lt 41943040 ]] && \ - report_error " Not enough disk space available on the installation folder: "$CGAT_HOME - -# perform actions according to the input parameters processed -if [[ $TRAVIS_INSTALL ]] || [[ $JENKINS_INSTALL ]] ; then - - conda_install - conda_test - -else - - if [[ $OS_PKGS ]] ; then - install_os_packages - fi - - if [[ $INSTALL_PRODUCTION ]] || [[ $INSTALL_DEVEL ]] ; then - conda_install - fi - - if [[ $INSTALL_TEST ]] ; then - conda_test - fi - - if [[ $INSTALL_UPDATE ]] ; then - conda_update - fi - - if [[ $UNINSTALL ]] ; then - uninstall - fi - -fi # if-variables - diff --git a/pyproject.toml b/pyproject.toml index 756cc89..c4d3703 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,7 +1,7 @@ [tool.poetry] name = "cgat-daisy" version = "0.1.10" -description = "" +description = "A benchmarking framework" authors = ["Andreas Heger "] packages = [ { include = "daisy", from = "src" }, diff --git a/scripts/conda.py b/scripts/conda.py deleted file mode 100644 index 9fc559e..0000000 --- a/scripts/conda.py +++ /dev/null @@ -1,71 +0,0 @@ -#!/usr/bin/env python -''' - - Script to interact with the existing conda installation. - - It assumes that a conda environment is active, and will - run conda commands to: - - * Get the install folder for conda - * Get a list of the existing environment - * Pin all packages in all conda environments - - References: - * https://conda.io/docs/user-guide/tasks/manage-pkgs.html#preventing-packages-from-updating-pinning - * https://github.com/conda/conda/issues/7375 - -''' - -import os -import subprocess -import json - - -def run_command(statement): - os.environ.update({'BASH_ENV': os.path.join(os.environ['HOME'],'.bashrc')}) - process = subprocess.Popen(statement, - cwd=os.getcwd(), - shell=True, - executable='/bin/bash', - stdin=subprocess.PIPE, - stdout=subprocess.PIPE, - stderr=subprocess.PIPE, - env=os.environ.copy()) - - (out, err) = process.communicate() - - if len(err) > 0: - issue = (' Problem running command: {}\n' - ' Stderr was: {}\n' - .format(statement, err)) - raise Exception(issue) - - return out, err - - -statement = "conda info --json" -(out, err) = run_command(statement) -cmd_out = json.loads(out) -install_folder = cmd_out['conda_prefix'] -#print(install_folder) - -statement = "conda env list --json" -(out, err) = run_command(statement) -cmd_out = json.loads(out) -envs = cmd_out['envs'] -#print(envs) - -for env_folder in envs: - if env_folder.startswith(install_folder) and \ - env_folder != install_folder: - env_name = os.path.basename(env_folder) - statement = "source activate {} && ".format(env_name) - statement+= "conda list --json" - (out, err) = run_command(statement) - cmd_out = json.loads(out) - conda_meta = install_folder + '/envs/' + env_name + '/conda-meta/pinned' - with open(conda_meta, 'w') as outf: - for pkg in cmd_out: - outf.write(pkg['name'] + ' ==' + pkg['version'] + '\n') - - diff --git a/src/setup.py b/src/setup.py deleted file mode 100644 index 9064879..0000000 --- a/src/setup.py +++ /dev/null @@ -1,53 +0,0 @@ -import sys -import setuptools -from setuptools import setup, find_packages - -from distutils.version import LooseVersion -if LooseVersion(setuptools.__version__) < LooseVersion('1.1'): - print("Version detected:", LooseVersion(setuptools.__version__)) - raise ImportError( - "the CGAT code collection requires setuptools 1.1 higher") - -# collect version -sys.path.insert(0, "daisy") -from version import __version__ as daisy_version - -daisy_packages = find_packages() -daisy_package_dirs = {'daisy': 'daisy'} - -# Classifiers -classifiers = """ -Development Status :: 3 - Alpha -Intended Audience :: Science/Research -Intended Audience :: Developers -License :: OSI Approved -Programming Language :: Python -Topic :: Software Development -Topic :: Scientific/Engineering -Operating System :: POSIX -Operating System :: Unix -Operating System :: MacOS -""" - -setup( - # package information - name='cgat-daisy', - version=daisy_version, - description='daisy : data i-something system', - author='Andreas Heger', - author_email='andreas.heger@gmail.com', - license="MIT", - platforms=["any"], - keywords="computational genomics", - long_description='daisy : data ', - classifiers=[_f for _f in classifiers.split("\n") if _f], - url="http://www.cgat.org/cgat/Tools/", - packages=daisy_packages, - package_dir=daisy_package_dirs, - package_data={"daisy": ["tasks/*.yml"]}, - entry_points={ - 'console_scripts': ['daisy = daisy.tools.cli:main'], - }, - zip_safe=False, - test_suite="tests", -)