From efad944afe0597e34f04e3e7fc71d3e309bc1cac Mon Sep 17 00:00:00 2001 From: Espen Hagen <2492641+espenhgn@users.noreply.github.com> Date: Mon, 5 Feb 2024 15:13:33 +0100 Subject: [PATCH] `gwas.sif`: Add samtools, bedtools, liftOver, upgrade others (#222) * Include samtools package in gwas.sif Fixes #219 * Include samtools package in gwas.sif Fixes #219 * `gwas.sif`: Include samtools, bedtools, liftOver; upgrade others Fixes #219 * rebuilt r.sif container * updated changelog * fix * bump version file * install GWAMA using apt * rebuilt gwas.sif * updated changelog --- CHANGELOG.md | 34 ++++++++++++++++++++++++++ docker/Makefile | 8 +++--- docker/README.md | 29 ++++++++++++---------- docker/dockerfiles/gwas/Dockerfile | 35 ++++++++++++++++++++------- docker/scripts/apt_get_essential.sh | 7 ++++-- docker/scripts/build_docker.sh | 13 ++++++---- docker/scripts/install_bcftools.sh | 4 +-- docker/scripts/install_bedtools.sh | 10 ++++++++ docker/scripts/install_bgenix.sh | 26 ++++---------------- docker/scripts/install_bolt.sh | 4 +-- docker/scripts/install_gcta.sh | 8 +++--- docker/scripts/install_gctb.sh | 9 ++++--- docker/scripts/install_gwama.sh | 11 ++++----- docker/scripts/install_htslib.sh | 2 +- docker/scripts/install_king.sh | 7 +++--- docker/scripts/install_liftover.sh | 6 +++++ docker/scripts/install_minimac4.sh | 3 ++- docker/scripts/install_plink.sh | 6 ++--- docker/scripts/install_plink2.sh | 6 ++--- docker/scripts/install_plink2_avx2.sh | 6 ++--- docker/scripts/install_prsice.sh | 4 +-- docker/scripts/install_qctools.sh | 35 +++++++++++++-------------- docker/scripts/install_regenie.sh | 20 +++++++++++---- docker/scripts/install_samtools.sh | 17 +++++++++++++ docker/scripts/install_vcftools.sh | 2 +- singularity/gwas.sif | 4 +-- tests/test_gwas.py | 21 ++++++++++++++++ version/version.py | 4 +-- 28 files changed, 225 insertions(+), 116 deletions(-) create mode 100644 docker/scripts/install_bedtools.sh create mode 100644 docker/scripts/install_liftover.sh create mode 100644 docker/scripts/install_samtools.sh diff --git a/CHANGELOG.md b/CHANGELOG.md index 372e8ad2..ca2c3c19 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -39,6 +39,40 @@ If MD5 sum is not listed for a certain release then it means that the container * Miscellaneous goes here +## [1.7.0] - 2024-02-02 + +### Added + +* Added `samtools 1.19.2`, `bedtools 2.31.1`, `liftOver (latest)` to `gwas.sif` container +* Added corresponding unit tests + +### Updated + +* Updated the following binaries (not listing apt package updates) in gwas.sif built + * bcftools to 1.19 + * bolt to 2.4.1 + * gcta to 1.94.1 + * gctb to 2.04.3 + * htslib to 1.19.1 + * king to 2.3.2 + * minimac4 to 4.1.6 + * plink to v1.90b7.2 64-bit (11 Dec 2023) + * plink2 to v2.00a5.10LM 64-bit Intel (5 Jan 2024) + * plink2_avx2 to v2.00a5.10LM AVX2 Intel (5 Jan 2024) + * PRSice_linux to 2.3.5 + * regenie to 3.4.1 + * vcftools to git SHA: d511f469e87c2ac9779bcdc3670b2b51667935fe (0.1.17dev) +* Rebuilt `gwas.sif` w. md5sum checksum: + + ``` + a775f4216b15b731471821d0c2a0da43 singularity/gwas.sif + ``` +* updated installer scripts + +### Fixed + +* Broken `docker/scripts/build_docker.sh` script + ## [1.6.0] - 2023-12-12 ### Added diff --git a/docker/Makefile b/docker/Makefile index b420bc75..3e823212 100644 --- a/docker/Makefile +++ b/docker/Makefile @@ -8,13 +8,13 @@ all: hello.sif gwas.sif python3.sif r.sif saige.sif # Example commands executed by this make file # # Run "make hello.sif" will trigger this: -# docker build -t hello -f dockerfiles/hello/Dockerfile . && \ # build docker container +# docker scripts/build_docker.sh hello && \ # build docker image # scripts/convert_docker_image_to_singularity.sh hello && \ # produces hello.sif # scripts/move_singularity_file.sh hello # moves hello.sif to ../singularity/. # # Run "make gwas.sif" will trigger this: -# docker build -t gwas -f dockerfiles/gwas/Dockerfile . && \ -# scripts/convert_docker_image_to_singularity.sh gwas && \ # produces gwas.sif -# scripts/move_singularity_file.sh gwas # moves gwas.sif to ../singularity/. +# docker scripts/build_docker.sh gwas && \ # build docker image +# scripts/convert_docker_image_to_singularity.sh gwas && \ # produces gwas.sif +# scripts/move_singularity_file.sh gwas # moves gwas.sif to ../singularity/. # # Build logs are stored in the ./logs/ directory \ No newline at end of file diff --git a/docker/README.md b/docker/README.md index 4f0a1614..5039ac33 100644 --- a/docker/README.md +++ b/docker/README.md @@ -37,29 +37,32 @@ The detailed description of the available container [files](https://github.com/c | hello.sif | ubuntu | 20.04 | [Creative Commons CC-BY-SA version 3.0 UK licence](https://ubuntu.com/legal/intellectual-property-policy) | hello.sif | plink | v1.90b6.18 64-bit (16 Jun 2020) | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) | gwas.sif | ubuntu | 20.04 | [Creative Commons CC-BY-SA version 3.0 UK licence](https://ubuntu.com/legal/intellectual-property-policy) - | gwas.sif | bcftools | 1.12 (using htslib 1.12) | [MIT/Expat/GPLv3](https://github.com/samtools/bcftools/blob/develop/LICENSE) + | gwas.sif | bcftools | 1.19 | [MIT/Expat/GPLv3](https://github.com/samtools/bcftools/blob/develop/LICENSE) + | gwas.sif | bedtools | 2.31.1 | [MIT](https://opensource.org/licenses/MIT) | gwas.sif | beagle | 22Jul22.46e | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) | gwas.sif | bgenix | 1.1.7 | [Boost](https://www.boost.org/LICENSE_1_0.txt) - | gwas.sif | bolt | v2.4 July 22, 2022 | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) + | gwas.sif | bolt | v2.4.1 | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) | gwas.sif | cat-bgen | same version as bgenix | [Boost](https://www.boost.org/LICENSE_1_0.txt) | gwas.sif | duohmm | 95bd395 | [MIT](https://opensource.org/licenses/MIT) | gwas.sif | eagle | v2.4.1 | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) | gwas.sif | edit-bgen | same version as bgenix | [Boost](https://www.boost.org/LICENSE_1_0.txt) | gwas.sif | flashpca_x86-64 | 2.0 | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) - | gwas.sif | gcta64 | version 1.93.3 beta 2 Linux | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) - | gwas.sif | gctb | 2.02 | [MIT](https://opensource.org/licenses/MIT) + | gwas.sif | gcta64 | 1.94.1 | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) + | gwas.sif | gctb | 2.04.3 | [MIT](https://opensource.org/licenses/MIT) | gwas.sif | qctool | 2.2.2, revision e5723df2c0c85959 | [Boost](https://www.boost.org/LICENSE_1_0.txt) | gwas.sif | GWAMA | 2.2.2 | [BSD-3-Clause](https://opensource.org/licenses/BSD-3-Clause) - | gwas.sif | HTSlib | 1.12 | [MIT/Expat/Modified-BSD](https://github.com/samtools/htslib/blob/develop/LICENSE) - | gwas.sif | king | 2.2.9 - (c) | [permissive](https://www.kingrelatedness.com/Download.shtml) + | gwas.sif | HTSlib | 1.19.1 | [MIT/Expat/Modified-BSD](https://github.com/samtools/htslib/blob/develop/LICENSE) + | gwas.sif | king | 2.3.2 | [permissive](https://www.kingrelatedness.com/Download.shtml) + | gwas.sif | liftOver | latest | [permissive](https://genome-store.ucsc.edu) | gwas.sif | ldak | 5.2 | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) | gwas.sif | metal | 2020-05-05 | - - | gwas.sif | minimac4 | v4.1.0 | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) - | gwas.sif | plink | v1.90b6.18 64-bit (16 Jun 2020) | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) - | gwas.sif | plink2 | v2.00a3.6LM 64-bit Intel (14 Aug 2022) | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) - | gwas.sif | plink2_avx2 | v2.00a3.6LM AVX2 Intel (24 Jan 2020) | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) - | gwas.sif | PRSice_linux | 2.3.3 (2020-08-05) | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) - | gwas.sif | regenie | v3.2.8 | [MIT/Boost](https://github.com/rgcgithub/regenie/blob/master/LICENSE) + | gwas.sif | minimac4 | v4.1.6 | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) + | gwas.sif | plink | v1.90b7.2 64-bit (11 Dec 2023) | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) + | gwas.sif | plink2 | v2.00a5.10LM 64-bit Intel (5 Jan 2024) | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) + | gwas.sif | plink2_avx2 | v2.00a5.10LM AVX2 Intel (5 Jan 2024) | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) + | gwas.sif | PRSice_linux | 2.3.5 | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) + | gwas.sif | regenie | v3.4 | [MIT/Boost](https://github.com/rgcgithub/regenie/blob/master/LICENSE) + | gwas.sif | samtools | v1.19.2 | [MIT/ExpatD](https://github.com/samtools/samtools/blob/develop/LICENSE) | gwas.sif | shapeit4.2 | v4.2.2 | [MIT](https://opensource.org/licenses/MIT) | gwas.sif | shapeit5 phase_rare | v5.1.1 | [MIT](https://opensource.org/licenses/MIT) | gwas.sif | shapeit5 phase_common | v5.1.1 | [MIT](https://opensource.org/licenses/MIT) @@ -69,7 +72,7 @@ The detailed description of the available container [files](https://github.com/c | gwas.sif | simu_linux | v0.9.4 | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) | gwas.sif | snptest | v2.5.6 | [permissive](https://www.chg.ox.ac.uk/~gav/snptest/#download) | gwas.sif | switchError | 6e688b1 | [MIT](https://opensource.org/licenses/MIT) - | gwas.sif | vcftools | 0.1.17 | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) + | gwas.sif | vcftools | 0.1.17 (git SHA: d511f469e) | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) | python3.sif | ubuntu | 20.04 (LTS) | [Creative Commons CC-BY-SA version 3.0 UK licence](https://ubuntu.com/legal/intellectual-property-policy) | python3.sif | LDpred | 1.0.11 | [MIT](https://opensource.org/licenses/MIT) | python3.sif | plink | v1.90b6.18 64-bit (16 Jun 2020) | [GPLv3](https://www.gnu.org/licenses/gpl-3.0.html) diff --git a/docker/dockerfiles/gwas/Dockerfile b/docker/dockerfiles/gwas/Dockerfile index 9387a222..276cd849 100644 --- a/docker/dockerfiles/gwas/Dockerfile +++ b/docker/dockerfiles/gwas/Dockerfile @@ -113,14 +113,6 @@ COPY /scripts/install_flashpca.sh /tmp/flashpca/ RUN bash /tmp/flashpca/install_flashpca.sh && \ rm -rf /tmp/flashpca -# regenie -WORKDIR /tmp/regenie -COPY /scripts/install_regenie.sh /tmp/regenie/ -RUN bash /tmp/regenie/install_regenie.sh && \ - rm -rf /tmp/regenie -# https://github.com/potree/PotreeConverter/issues/281 -ENV LC_ALL="C" - # gwama WORKDIR /tmp/gwama COPY /scripts/install_gwama.sh /tmp/gwama/ @@ -139,6 +131,14 @@ COPY /scripts/install_bgenix.sh /tmp/bgenix/ RUN bash /tmp/bgenix/install_bgenix.sh && \ rm -rf /tmp/bgenix +# regenie (install after bgenix) +WORKDIR /tmp/regenie +COPY /scripts/install_regenie.sh /tmp/regenie/ +RUN bash /tmp/regenie/install_regenie.sh && \ + rm -rf /tmp/regenie +# https://github.com/potree/PotreeConverter/issues/281 +ENV LC_ALL="C" + # shapeit4 WORKDIR /tmp/shapeit4 COPY /scripts/install_shapeit4.sh /tmp/shapeit4/ @@ -175,11 +175,28 @@ COPY /scripts/stub.sh /tmp/beagle/ RUN bash /tmp/beagle/install_beagle.sh && \ rm -rf /tmp/beagle - # duohmm WORKDIR /tmp/duohmm COPY /scripts/install_duohmm.sh /tmp/duohmm/ RUN bash /tmp/duohmm/install_duohmm.sh && \ rm -rf /tmp/duohmm +# samtools +WORKDIR /tmp/samtools +COPY /scripts/install_samtools.sh /tmp/samtools/ +RUN bash /tmp/samtools/install_samtools.sh && \ + rm -rf /tmp/samtools + +# bedtools +WORKDIR /tmp/bedtools +COPY /scripts/install_bedtools.sh /tmp/bedtools/ +RUN bash /tmp/bedtools/install_bedtools.sh && \ + rm -rf /tmp/bedtools + +# liftOver +WORKDIR /tmp/liftover +COPY /scripts/install_liftover.sh /tmp/liftover/ +RUN bash /tmp/liftover/install_liftover.sh && \ + rm -rf /tmp/liftover + WORKDIR /tools diff --git a/docker/scripts/apt_get_essential.sh b/docker/scripts/apt_get_essential.sh index 62997405..266f2dd3 100644 --- a/docker/scripts/apt_get_essential.sh +++ b/docker/scripts/apt_get_essential.sh @@ -30,13 +30,16 @@ apt-get update && apt-get install -y --no-install-recommends \ parallel=20161222-1.1 \ perl=5.30.0-9ubuntu0.5 \ pkg-config=0.29.1-0ubuntu4 \ + python3=3.8.2-0ubuntu2 \ tar=1.30+dfsg-7ubuntu0.20.04.4 \ tofrodos=1.7.13+ds-4 \ unzip=6.0-25ubuntu1.1 \ - vim=2:8.1.2269-1ubuntu5.20 \ + vim=2:8.1.2269-1ubuntu5.21 \ wget=1.20.3-1ubuntu2 \ zlib1g-dev=1:1.2.11.dfsg-2ubuntu1.5 \ && \ apt-get clean && \ rm -rf /var/lib/apt/lists/* - \ No newline at end of file + +# /usr/bin/python must exist for bgenix, qctool +update-alternatives --install /usr/bin/python python /usr/bin/python3 10 diff --git a/docker/scripts/build_docker.sh b/docker/scripts/build_docker.sh index 0697b934..6c542f43 100755 --- a/docker/scripts/build_docker.sh +++ b/docker/scripts/build_docker.sh @@ -13,15 +13,18 @@ fi # exit on errors trap 'exit' ERR -# need env variable GITHUB_PAT set in /root/.bash_profile of host for r.sif to build. +# need env variable GITHUB_PAT set in /root/.bashrc of host for r.sif to build. # this is a personal access token from github with read:packages scope and will have # to be updated every 30 days. -if [ $1 == "r" ]; then - source ~/.bash_profile +if [ $1 == "r.sif" ]; then + source ~/.bashrc if [ -z "$GITHUB_PAT" ]; then echo "GITHUB_PAT not set" exit 1 fi + # build docker image + docker build --build-arg GITHUB_PAT="${GITHUB_PAT}" -t $1 -f dockerfiles/$1/Dockerfile . +else + # build docker image + docker build -t $1 -f dockerfiles/$1/Dockerfile . fi -# build docker image -docker build --build-arg GITHUB_PAT=$GITHUB_PAT -t $1 -f dockerfiles/$1/Dockerfile . \ No newline at end of file diff --git a/docker/scripts/install_bcftools.sh b/docker/scripts/install_bcftools.sh index 42835aab..d9ae14f9 100644 --- a/docker/scripts/install_bcftools.sh +++ b/docker/scripts/install_bcftools.sh @@ -9,8 +9,8 @@ apt-get update && apt-get install -y --no-install-recommends \ apt-get clean && \ rm -rf /var/lib/apt/lists/* -# bcfools -git clone --recurse-submodules --depth 1 -b 1.12 https://github.com/samtools/bcftools.git && \ +# bcftools +git clone --recurse-submodules --depth 1 -b 1.19 https://github.com/samtools/bcftools.git && \ cd bcftools && \ autoheader && autoconf && ./configure --enable-libgsl --enable-perl-filters --with-htslib=/usr/ && \ make -j12 && \ diff --git a/docker/scripts/install_bedtools.sh b/docker/scripts/install_bedtools.sh new file mode 100644 index 00000000..10d4fe36 --- /dev/null +++ b/docker/scripts/install_bedtools.sh @@ -0,0 +1,10 @@ +#!/bin/bash +set -euo pipefail + +VERSION="2.31.1" +wget https://github.com/arq5x/bedtools2/releases/download/v$VERSION/bedtools-$VERSION.tar.gz +tar -zxvf bedtools-$VERSION.tar.gz +cd bedtools2 +make -j4 +cp bin/* /bin + diff --git a/docker/scripts/install_bgenix.sh b/docker/scripts/install_bgenix.sh index bb68dfc5..c7dc9583 100644 --- a/docker/scripts/install_bgenix.sh +++ b/docker/scripts/install_bgenix.sh @@ -1,25 +1,9 @@ #!/bin/sh set -euo pipefail -# python appears to be a build time dependency -apt-get update && apt-get install -y --no-install-recommends python3=3.8.2-0ubuntu2 && \ - apt-get clean && \ - rm -rf /var/lib/apt/lists/* - -# /usr/bin/python must exist -update-alternatives --install /usr/bin/python python /usr/bin/python3 10 - # build bgen -wget http://code.enkre.net/bgen/tarball/release/bgen.tgz && \ - tar -xvzf bgen.tgz && mv bgen.tgz/* . && \ - ./waf configure && \ - ./waf -v -# copy binaries -cp build/apps/bgenix /bin && \ - cp build/apps/cat-bgen /bin && \ - cp build/apps/edit-bgen /bin - -# remove python -apt-get purge \ - python3 -y && \ - apt-get autoremove --purge -y +VERSION="1.1.7" +wget http://code.enkre.net/bgen/tarball/release/v$VERSION.tgz && \ + tar -xvzf v$VERSION.tgz && mv v$VERSION/* . && \ + ./waf configure --prefix=/usr && \ + ./waf install diff --git a/docker/scripts/install_bolt.sh b/docker/scripts/install_bolt.sh index b9ff87c5..39f449d2 100644 --- a/docker/scripts/install_bolt.sh +++ b/docker/scripts/install_bolt.sh @@ -1,9 +1,9 @@ #!/bin/sh set -euo pipefail -export VERSION="v2.3.5" +export VERSION="v2.4.1" -wget --no-check-certificate https://storage.googleapis.com/broad-alkesgroup-public/BOLT-LMM/downloads/old/BOLT-LMM_$VERSION.tar.gz +wget --no-check-certificate https://storage.googleapis.com/broad-alkesgroup-public/BOLT-LMM/downloads/BOLT-LMM_$VERSION.tar.gz tar -xvzf BOLT-LMM_$VERSION.tar.gz rm -rf BOLT-LMM_$VERSION.tar.gz mv BOLT-LMM_$VERSION/* . diff --git a/docker/scripts/install_gcta.sh b/docker/scripts/install_gcta.sh index a519b171..363479e0 100644 --- a/docker/scripts/install_gcta.sh +++ b/docker/scripts/install_gcta.sh @@ -2,8 +2,8 @@ set -euo pipefail # gcta -curl -O -J -L https://github.com/jianyangqt/gcta/releases/download/v1.93.3beta2/gcta_1.93.3beta2.zip && \ - unzip -j gcta_1.93.3beta2.zip && \ - rm -rf gcta_1.93.3beta2.zip +VERSION="1.94.1" +curl -O -J -L https://github.com/jianyangqt/gcta/releases/download/v$VERSION/gcta-$VERSION-linux-x86_64-static && \ + mv gcta-$VERSION-linux-x86_64-static /bin/gcta64 && \ + chmod +x /bin/gcta64 -cp gcta64 /bin diff --git a/docker/scripts/install_gctb.sh b/docker/scripts/install_gctb.sh index aacef104..ea3a09ba 100644 --- a/docker/scripts/install_gctb.sh +++ b/docker/scripts/install_gctb.sh @@ -2,11 +2,12 @@ set -euo pipefail # gctb -wget --no-check-certificate https://cnsgenomics.com/software/gctb/download/gctb_2.02_Linux.zip && \ - unzip gctb_2.02_Linux.zip && \ - rm -rf gctb_2.02_Linux.zip +VERSION="2.04.3" +wget --no-check-certificate https://cnsgenomics.com/software/gctb/download/gctb_${VERSION}_Linux.zip && \ + unzip gctb_${VERSION}_Linux.zip && \ + rm -rf gctb_${VERSION}_Linux.zip -mv gctb_2.02_Linux/* . +mv gctb_${VERSION}_Linux/* . cp gctb /bin chmod 755 /bin/gctb diff --git a/docker/scripts/install_gwama.sh b/docker/scripts/install_gwama.sh index 90453027..988b9834 100644 --- a/docker/scripts/install_gwama.sh +++ b/docker/scripts/install_gwama.sh @@ -1,9 +1,8 @@ #!/bin/sh set -euo pipefail -wget --no-check-certificate http://www.geenivaramu.ee/tools/GWAMA_v2.2.2.zip && \ - unzip GWAMA_v2.2.2.zip && \ - make && \ - chmod +x GWAMA && \ - cp GWAMA /bin - +apt-get update && apt-get install -y --no-install-recommends \ + gwama=2.2.2+dfsg-2build1 \ + && \ + apt-get clean && \ + rm -rf /var/lib/apt/lists/* diff --git a/docker/scripts/install_htslib.sh b/docker/scripts/install_htslib.sh index 2d7d5191..eccb1af1 100644 --- a/docker/scripts/install_htslib.sh +++ b/docker/scripts/install_htslib.sh @@ -11,7 +11,7 @@ apt-get update && apt-get install --no-install-recommends \ rm -rf /var/lib/apt/lists/* # build and install HTSlib -git clone --depth 1 -b 1.12 https://github.com/samtools/htslib.git --recurse-submodules && \ +git clone --depth 1 -b 1.19.1 https://github.com/samtools/htslib.git --recurse-submodules && \ cd htslib && \ autoreconf -i && \ ./configure --prefix=/usr/ && \ diff --git a/docker/scripts/install_king.sh b/docker/scripts/install_king.sh index d829838f..2f20f67a 100644 --- a/docker/scripts/install_king.sh +++ b/docker/scripts/install_king.sh @@ -9,9 +9,10 @@ apt-get update && apt-get install --no-install-recommends \ rm -rf /var/lib/apt/lists/* # king -wget --no-check-certificate https://www.kingrelatedness.com/executables/Linux-king229.tar.gz && \ - tar -xvzf Linux-king229.tar.gz && \ - rm -rf Linux-king229.tar.gz +VERSION="232" +wget --no-check-certificate https://www.kingrelatedness.com/executables/Linux-king$VERSION.tar.gz && \ + tar -xvzf Linux-king$VERSION.tar.gz && \ + rm -rf Linux-king$VERSION.tar.gz cp king /bin diff --git a/docker/scripts/install_liftover.sh b/docker/scripts/install_liftover.sh new file mode 100644 index 00000000..829749a6 --- /dev/null +++ b/docker/scripts/install_liftover.sh @@ -0,0 +1,6 @@ +#!/bin/sh +set -euo pipefail + +wget https://hgdownload.soe.ucsc.edu/admin/exe/linux.x86_64/liftOver +chmod +x liftOver +mv liftOver /bin diff --git a/docker/scripts/install_minimac4.sh b/docker/scripts/install_minimac4.sh index 657b5f67..67aa3d62 100644 --- a/docker/scripts/install_minimac4.sh +++ b/docker/scripts/install_minimac4.sh @@ -15,7 +15,8 @@ apt-get update && \ pip3 install --no-cache-dir cget==0.2.0 # install Minimac4 -git clone --depth 1 -b v4.1.0 https://github.com/statgen/Minimac4.git && \ +VERSION="v4.1.6" +git clone --depth 1 -b $VERSION https://github.com/statgen/Minimac4.git && \ cd Minimac4 && \ cget install -f ./requirements.txt && \ mkdir build && cd build && \ diff --git a/docker/scripts/install_plink.sh b/docker/scripts/install_plink.sh index db8b219d..15e984f5 100644 --- a/docker/scripts/install_plink.sh +++ b/docker/scripts/install_plink.sh @@ -2,7 +2,7 @@ set -euo pipefail # plink -wget --no-check-certificate https://s3.amazonaws.com/plink1-assets/plink_linux_x86_64_20200616.zip && \ - unzip -j plink_linux_x86_64_20200616.zip && \ - rm -rf plink_linux_x86_64_20200616.zip +wget --no-check-certificate https://s3.amazonaws.com/plink1-assets/plink_linux_x86_64_20231211.zip && \ + unzip -j plink_linux_x86_64_20231211.zip && \ + rm -rf plink_linux_x86_64_20231211.zip cp plink /bin diff --git a/docker/scripts/install_plink2.sh b/docker/scripts/install_plink2.sh index 0f34cbea..570b09b7 100644 --- a/docker/scripts/install_plink2.sh +++ b/docker/scripts/install_plink2.sh @@ -1,8 +1,8 @@ #!/bin/sh set -euo pipefail -wget --no-check-certificate https://s3.amazonaws.com/plink2-assets/alpha3/plink2_linux_x86_64_20220814.zip && \ - unzip -j plink2_linux_x86_64_20220814.zip && \ - rm -rf plink2_linux_x86_64_20220814.zip +wget --no-check-certificate https://s3.amazonaws.com/plink2-assets/alpha5/plink2_linux_x86_64_20240105.zip && \ + unzip -j plink2_linux_x86_64_20240105.zip && \ + rm -rf plink2_linux_x86_64_20240105.zip cp plink2 /bin diff --git a/docker/scripts/install_plink2_avx2.sh b/docker/scripts/install_plink2_avx2.sh index 2d199da2..3295383a 100644 --- a/docker/scripts/install_plink2_avx2.sh +++ b/docker/scripts/install_plink2_avx2.sh @@ -1,9 +1,9 @@ #!/bin/sh set -euo pipefail -wget --no-check-certificate https://s3.amazonaws.com/plink2-assets/alpha3/plink2_linux_avx2_20220814.zip && \ - unzip -j plink2_linux_avx2_20220814.zip && \ - rm -rf plink2_linux_avx2_20220814.zip +wget --no-check-certificate https://s3.amazonaws.com/plink2-assets/alpha5/plink2_linux_avx2_20240105.zip && \ + unzip -j plink2_linux_avx2_20240105.zip && \ + rm -rf plink2_linux_avx2_20240105.zip # we install non-avx plink2 so that default plink runs on any CPU architecture diff --git a/docker/scripts/install_prsice.sh b/docker/scripts/install_prsice.sh index 42c52aa7..f6328a46 100644 --- a/docker/scripts/install_prsice.sh +++ b/docker/scripts/install_prsice.sh @@ -2,9 +2,9 @@ set -euo pipefail # Prsice - wget --no-check-certificate https://github.com/choishingwan/PRSice/releases/download/2.3.3/PRSice_linux.zip && \ + wget --no-check-certificate https://github.com/choishingwan/PRSice/releases/download/2.3.5/PRSice_linux.zip && \ unzip PRSice_linux.zip && \ rm -rf PRSice_linux.zip cp PRSice_linux /bin -#cp PRSice.R / +chmod +x /bin/PRSice_linux diff --git a/docker/scripts/install_qctools.sh b/docker/scripts/install_qctools.sh index 639919ad..3838f4f8 100644 --- a/docker/scripts/install_qctools.sh +++ b/docker/scripts/install_qctools.sh @@ -1,29 +1,28 @@ #!/bin/sh set -euo pipefail -# python appears to be a build time dependency -apt-get update && apt-get install -y --no-install-recommends python3=3.8.2-0ubuntu2 && \ +# install some deps for installing cget +apt-get update && \ + apt-get install --no-install-recommends \ + fossil=1:2.10-1 \ + -y && \ apt-get clean && \ rm -rf /var/lib/apt/lists/* -# /usr/bin/python must exist -update-alternatives --install /usr/bin/python python /usr/bin/python3 10 - # qctools -wget --no-check-certificate https://code.enkre.net/qctool/zip/e5723df2c0c85959/qctool.zip -unzip qctool.zip -cd qctool -./waf configure -./waf +fossil clone https://code.enkre.net/qctool qctool.fossil -A root +fossil open qctool.fossil +fossil checkout e5723df2c0c85959 # 2.2.2 -# copy binaries to /bin -cp build/release/apps/inthinnerator_v2.2.2 /bin/inthinnerator -cp build/release/apps/hptest_v2.2.2 /bin/hptest -cp build/release/apps/ldbird_v2.2.2 /bin/ldbird -cp build/release/apps/qctool_v2.2.2 /bin/qctool -cp build/release/apps/selfmap_v2.2.2 /bin/selfmap +./waf configure --prefix=/usr/ +./waf install +mv /usr/bin/hptest_v2.2.2 /usr/bin/hptest +mv /usr/bin/inthinnerator_v2.2.2 /usr/bin/inthinnerator +mv /usr/bin/ldbird_v2.2.2 /usr/bin/ldbird +mv /usr/bin/qctool_v2.2.2 /usr/bin/qctool +mv /usr/bin/selfmap_v2.2.2 /usr/bin/selfmap -# remove python +# remove fossil used to build qctools apt-get purge \ - python3 -y && \ + fossil -y && \ apt-get autoremove --purge -y diff --git a/docker/scripts/install_regenie.sh b/docker/scripts/install_regenie.sh index 7de593fb..f34c2862 100644 --- a/docker/scripts/install_regenie.sh +++ b/docker/scripts/install_regenie.sh @@ -1,8 +1,18 @@ #!/bin/sh set -euo pipefail -wget --no-check-certificate https://github.com/rgcgithub/regenie/releases/download/v3.2.8/regenie_v3.2.8.gz_x86_64_Linux_mkl.zip && \ - unzip -j regenie_v3.2.8.gz_x86_64_Linux_mkl.zip && \ - rm -rf regenie_v3.2.8.gz_x86_64_Linux_mkl.zip && \ - mv regenie_v3.2.8.gz_x86_64_Linux_mkl regenie -cp regenie /bin +# required for building regenie (doesn't find bgen otherwise) +VERSION="1.1.7" +wget http://code.enkre.net/bgen/tarball/release/v$VERSION.tgz && \ + tar -xvzf v$VERSION.tgz && cd v$VERSION && \ + ./waf configure && \ + ./waf && \ + cd .. + +# build regenie +git clone --depth 1 --branch v3.4.1 https://github.com/rgcgithub/regenie.git +cd regenie +BGEN_PATH=../v$VERSION cmake . +make + +cp regenie /bin \ No newline at end of file diff --git a/docker/scripts/install_samtools.sh b/docker/scripts/install_samtools.sh new file mode 100644 index 00000000..5cd27e2b --- /dev/null +++ b/docker/scripts/install_samtools.sh @@ -0,0 +1,17 @@ +#!/bin/sh +set -euo pipefail + +apt-get update && apt-get install -y --no-install-recommends \ + libncurses-dev=6.2-0ubuntu2.1 \ + && \ + apt-get clean && \ + rm -rf /var/lib/apt/lists/* + +# samtools +git clone --depth 1 -b 1.19.2 https://github.com/samtools/samtools.git && \ +cd samtools && \ + autoheader && \ + autoconf -Wno-syntax && \ + ./configure --with-htslib=/usr/ && \ + make -j12 && \ + make install diff --git a/docker/scripts/install_vcftools.sh b/docker/scripts/install_vcftools.sh index 0fd28b21..40e1ff9e 100644 --- a/docker/scripts/install_vcftools.sh +++ b/docker/scripts/install_vcftools.sh @@ -4,7 +4,7 @@ set -euo pipefail # vcfools git clone https://github.com/vcftools/vcftools.git && \ cd vcftools && \ - git reset --hard 581c231991cb4db017b92eabc573e17128541ab5 && \ + git reset --hard d511f469e87c2ac9779bcdc3670b2b51667935fe && \ ./autogen.sh && \ ./configure && \ make -j6 && \ diff --git a/singularity/gwas.sif b/singularity/gwas.sif index 0ff66e96..4fd3f984 100644 --- a/singularity/gwas.sif +++ b/singularity/gwas.sif @@ -1,3 +1,3 @@ version https://git-lfs.github.com/spec/v1 -oid sha256:f4b569b3d39fb8d9a0b903966fa0e13be2addd8fec84011c0d2dffe3c275e7b6 -size 560619520 +oid sha256:055a4de800df9792ceb3c3d0095ba22d97151f51f70b0d8b08ecf6008fd66552 +size 602701824 diff --git a/tests/test_gwas.py b/tests/test_gwas.py index 974f8de2..5a6cbdd2 100644 --- a/tests/test_gwas.py +++ b/tests/test_gwas.py @@ -27,6 +27,13 @@ def test_gwas_beagle(): assert out.returncode == 0 +def test_gwas_bedtools(): + """test bedtools""" + call = f'singularity run {pth} bedtools --version' + out = subprocess.run(call.split(' '), check=False) + assert out.returncode == 0 + + def test_gwas_bgenix(): """test bgenix, cat-bgen, edit-bgen binaries""" for binary in ['bgenix', 'cat-bgen', 'edit-bgen']: @@ -108,6 +115,13 @@ def test_gwas_ldak(): assert out.returncode == 0 +def test_gwas_liftover(): + """test liftOver""" + call = f'singularity run {pth} liftOver -errorHelp' + out = subprocess.run(call.split(' '), capture_output=True, check=False) + assert out.stdout.decode('utf-8').lower().rfind('error') <= 0 + + def test_gwas_metal(): """test metal""" cwd = os.getcwd() @@ -177,6 +191,13 @@ def test_gwas_regenie(): assert out.returncode == 0 +def test_gwas_samtools(): + """test samtools""" + call = f'singularity run {pth} samtools --help' + out = subprocess.run(call.split(' '), check=False) + assert out.returncode == 0 + + def test_gwas_shapeit4(): """test shapeit4""" call = f'singularity run {pth} shapeit4.2 --help' diff --git a/version/version.py b/version/version.py index 4857ae45..70f1171c 100644 --- a/version/version.py +++ b/version/version.py @@ -1,8 +1,8 @@ _MAJOR = "1" -_MINOR = "5" +_MINOR = "7" # On main and in a nightly release the patch should be one ahead of the last # released build. -_PATCH = "1" +_PATCH = "0" # This is mainly for nightly builds which have the suffix ".dev$DATE". See # https://semver.org/#is-v123-a-semantic-version for the semantics. _SUFFIX = ""