Skip to content

Commit

Permalink
Merge pull request #1 from nilearn/master
Browse files Browse the repository at this point in the history
Updating Fork
  • Loading branch information
SRSteinkamp authored Nov 25, 2019
2 parents 901a627 + 3edd555 commit 7758445
Show file tree
Hide file tree
Showing 178 changed files with 5,903 additions and 2,088 deletions.
1 change: 0 additions & 1 deletion .circleci/auto-cache-timestamp

This file was deleted.

6 changes: 3 additions & 3 deletions .circleci/clean-cache.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@


def update_cache_timestamp(timestamp_filename):
""" Updates the contents of the manual-cache-timestamp file
""" Updates the contents of the docs-cache-timestamp file
with current timestamp.
Returns
Expand All @@ -22,5 +22,5 @@ def update_cache_timestamp(timestamp_filename):


if __name__ == '__main__':
update_cache_timestamp('manual-cache-timestamp')
update_cache_timestamp('auto-cache-timestamp')
update_cache_timestamp('docs-cache-timestamp')
update_cache_timestamp('packages-cache-timestamp')
167 changes: 95 additions & 72 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,41 +3,46 @@
# It doesn't operate on master branch. New branches are always built from scratch.
# full-build always rebuilds from scratch, without any cache. Only for changes in master branch.

version: 2
version: 2.1

jobs:
quick-build:
docker:
- image: circleci/python:3.6
environment:
DISTRIB: "conda"
PYTHON_VERSION: "3.6"
NUMPY_VERSION: "*"
SCIPY_VERSION: "*"
SCIKIT_LEARN_VERSION: "*"
MATPLOTLIB_VERSION: "*"
commands:

preinstall:
description: "Cleans up unused packages; Updates system packages"
steps:
- checkout
# Get rid of existing virtualenvs on circle ci as they conflict with conda.
# Trick found here:
# https://discuss.circleci.com/t/disable-autodetection-of-project-or-application-of-python-venv/235/10
- run: cd && rm -rf ~/.pyenv && rm -rf ~/virtualenvs
# We need to remove conflicting texlive packages.
- run: sudo -E apt-get -yq remove texlive-binaries --purge
# Installing required packages for `make -C doc check command` to work.
- run: sudo -E apt-get -yq update
- run: sudo -E apt-get -yq --no-install-suggests --no-install-recommends --force-yes install dvipng texlive-latex-base texlive-latex-extra
- run:
name: Today & Week # Saving today's date and current week of the year in files to generate daily & weekly new cache key respectively.
name: Remove conflicting packages
command: |
# Get rid of existing virtualenvs on circle ci as they conflict with conda.
# Trick found here:
# https://discuss.circleci.com/t/disable-autodetection-of-project-or-application-of-python-venv/235/10
cd && rm -rf ~/.pyenv && rm -rf ~/virtualenvs
# We need to remove conflicting texlive packages.
sudo -E apt-get -yq remove texlive-binaries --purge
- run:
name: Install packages for make -C doc check
command: |
# Installing required packages for `make -C doc check command` to work.
sudo -E apt-get -yq update
sudo -E apt-get -yq --no-install-suggests --no-install-recommends --force-yes install dvipng texlive-latex-base texlive-latex-extra
restore_from_cache:
description: "Restores the cache of previously built docs & python packages if present"
steps:
- run:
name: Generate cache keys from today's date for built docs & week number for python packages
command: |
date +%F > today
date +%U > week_num
- restore_cache:
key: v1-packages+datasets-{{ checksum "week_num" }}
key: v1-packages+datasets-{{ checksum "week_num" }}-{{ checksum ".circleci/packages-cache-timestamp" }}
- restore_cache:
key: v1-docs-{{ .Branch }}-{{ checksum "today" }}-{{ checksum ".circleci/manual-cache-timestamp" }}
key: v1-docs-{{ .Branch }}-{{ checksum "today" }}-{{ checksum ".circleci/docs-cache-timestamp" }}

cache_aware_conda_setup:
description: "Downloads & installs conda if not restord by cache"
steps:
- run:
name: Download & install conda if absent
command: |
Expand All @@ -63,91 +68,109 @@ jobs:
else
conda create -n testenv -yq
fi
cache_ignorant_conda_setup:
description: "Downloads & installs only the fresh copy of conda."
steps:
- run:
name: setup conda afresh
command: |
wget https://repo.continuum.io/miniconda/Miniconda3-latest-Linux-x86_64.sh -O ~/miniconda.sh
chmod +x ~/miniconda.sh && ~/miniconda.sh -b
echo 'export PATH="$HOME/miniconda3/bin:$PATH"' >> $BASH_ENV
- run: conda create -n testenv

install_dependencies:
description: "Installs the necessary Python packages"
steps:
- run:
name: Install packages in conda env
command: |
conda install -n testenv python=3.6 numpy scipy scikit-learn matplotlib pandas \
conda install -n testenv python=3.7 numpy scipy scikit-learn matplotlib pandas \
lxml mkl sphinx numpydoc pillow pandas -yq
conda install -n testenv nibabel sphinx-gallery junit-xml -c conda-forge -yq
build_docs:
description: "Installs Nilearn & builds documentation using Sphinx's make html-strict"
steps:
- run:
name: Running CircleCI test (make html)
name: Building documentation
command: |
source activate testenv
pip install -e .
set -o pipefail && cd doc && make html-strict 2>&1 | tee log.txt
no_output_timeout: 7h

store_results:
description: "Stores build times and artifacts"
steps:
- store_test_results:
path: doc/_build/test-results
- store_artifacts:
path: doc/_build/test-results
- store_artifacts:
path: doc/_build/html
- store_artifacts:
path: coverage
- store_artifacts:
path: doc/log.txt

save_to_cache:
description: "Caches the downloaded packages & buit docs."
steps:
- save_cache:
key: v1-packages+datasets-{{ checksum "week_num" }}
paths:
- ../nilearn_data
- ../miniconda3
- save_cache:
key: v1-docs-{{ .Branch }}-{{ checksum "today" }}-{{ checksum ".circleci/manual-cache-timestamp" }}
key: v1-docs-{{ .Branch }}-{{ checksum "today" }}-{{ checksum ".circleci/docs-cache-timestamp" }}
paths:
- doc

- store_artifacts:
path: doc/_build/html
- store_artifacts:
path: coverage
- store_artifacts:
path: doc/log.txt

jobs:

full-build:
quick-build:
docker:
- image: circleci/python:3.6
- image: circleci/python:3.7
environment:
DISTRIB: "conda"
PYTHON_VERSION: "3.6"
PYTHON_VERSION: "3.7"
NUMPY_VERSION: "*"
SCIPY_VERSION: "*"
SCIKIT_LEARN_VERSION: "*"
JOBLIB_VERSION: "*"
MATPLOTLIB_VERSION: "*"

steps:
- checkout
# Get rid of existing virtualenvs on circle ci as they conflict with conda.
# Trick found here:
# https://discuss.circleci.com/t/disable-autodetection-of-project-or-application-of-python-venv/235/10
- run: cd && rm -rf ~/.pyenv && rm -rf ~/virtualenvs
# We need to remove conflicting texlive packages.
- run: sudo -E apt-get -yq remove texlive-binaries --purge
# Installing required packages for `make -C doc check command` to work.
- run: sudo -E apt-get -yq update
- run: sudo -E apt-get -yq --no-install-suggests --no-install-recommends --force-yes install dvipng texlive-latex-base texlive-latex-extra
- run: wget https://repo.continuum.io/miniconda/Miniconda3-latest-Linux-x86_64.sh -O ~/miniconda.sh
- run: chmod +x ~/miniconda.sh && ~/miniconda.sh -b
- run: echo 'export PATH="$HOME/miniconda3/bin:$PATH"' >> $BASH_ENV
- run:
name: Install packages in conda env
command: |
conda create -n testenv python=3.6 numpy scipy scikit-learn matplotlib pandas \
lxml mkl sphinx numpydoc pillow pandas -yq
conda install -n testenv nibabel sphinx-gallery junit-xml -c conda-forge -yq
- run:
name: Running CircleCI test (make html)
command: |
source activate testenv
pip install -e .
set -o pipefail && cd doc && make html-strict 2>&1 | tee log.txt
no_output_timeout: 7h
- store_test_results:
path: doc/_build/test-results
- store_artifacts:
path: doc/_build/test-results
- preinstall
- restore_from_cache
- cache_aware_conda_setup
- install_dependencies
- build_docs
- store_results
- save_to_cache

- store_artifacts:
path: doc/_build/html
- store_artifacts:
path: coverage
- store_artifacts:
path: doc/log.txt
full-build:
docker:
- image: circleci/python:3.7
environment:
DISTRIB: "conda"
PYTHON_VERSION: "3.7"
NUMPY_VERSION: "*"
SCIPY_VERSION: "*"
SCIKIT_LEARN_VERSION: "*"
MATPLOTLIB_VERSION: "*"

steps:
- checkout
- preinstall
- cache_ignorant_conda_setup
- install_dependencies
- build_docs
- store_results


workflows:
Expand Down
1 change: 1 addition & 0 deletions .circleci/docs-cache-timestamp
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
2019-11-07 13:17:41.900352
1 change: 0 additions & 1 deletion .circleci/manual-cache-timestamp

This file was deleted.

1 change: 1 addition & 0 deletions .circleci/packages-cache-timestamp
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
2019-11-07 13:17:41.900617
5 changes: 5 additions & 0 deletions .coveragerc
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
[run]
branch = True
parallel = True
omit =
*/nilearn/externals/*
11 changes: 9 additions & 2 deletions .mailmap
Original file line number Diff line number Diff line change
Expand Up @@ -3,39 +3,46 @@ Alexandre Abadie <[email protected]>
Alexandre Abraham <[email protected]>
Alexandre Gramfort <[email protected]>
Alexandre Savio <[email protected]>
Andrés Hoyos Idrobo <[email protected]>
Antoine Grigis <[email protected]>
Arthur Mensch <[email protected]>
Ben Cipollini <[email protected]>
Bertrand Thirion <[email protected]>
Céline Delettre <[email protected]>
Chris Filo Gorgolewski <[email protected]>
Danilo Bzdok <[email protected]>
Demian Wassermann <[email protected]>
Dimitri Papadopoulos Orfanos <[email protected]>
Elvis Dohmatob <[email protected]>
Fabian Pedregosa <[email protected]>
Franz Liem <[email protected]>
Gael Varoquaux <[email protected]>
Greg Kiar <[email protected]>
Jan Margeta <[email protected]>
Jaques Grobler <[email protected]>
Jason Gors <[email protected]>
Jona Sassenhagen <[email protected]>
Jean Kossaifi <[email protected]>
Jean Remi King <[email protected]>
Jeff Chiang <[email protected]>
Jerome-Alexis Chevalier <[email protected]>
Jerome Dockes <[email protected]>
Julia Huntenburg <[email protected]>
J Necus <[email protected]>
Kamalakar Daddy <[email protected]>
Konstantin Shmelkov <[email protected]>
Kshitij Chawla (kchawla-pi) <[email protected]>
Loïc Estève <[email protected]>
Martin Perez-Guevara <[email protected]>
Matthias Ekman <[email protected]>
Mehdi Rahim <[email protected]>
Mehdi Rahim <[email protected]> <[email protected]>
Michael Eickenberg <[email protected]>
Michael Hanke <[email protected]>
Michael Waskom <[email protected]>
Moritz Boos <[email protected]>
Moritz Boos <[email protected]> <[email protected]>
Óscar Nájera <[email protected]>
Philippe Gervais <[email protected]>
Roberto Guidotti <[email protected]>
Ronald Phlypo <[email protected]>
Salma Bougacha <[email protected]>
Vincent Michel <[email protected]>
Expand Down
Loading

0 comments on commit 7758445

Please sign in to comment.