From 7d664e2b3f499ec5de066143a743fd396fc40012 Mon Sep 17 00:00:00 2001 From: Heberto Mayorquin Date: Tue, 17 Sep 2024 20:36:57 -0600 Subject: [PATCH 1/3] centralized gin data preparation in an action --- .github/actions/load-data/action.yml | 96 ++++++++++++++++++++++++++++ .github/workflows/dev-testing.yml | 51 ++------------- .github/workflows/doctests.yml | 33 ++-------- .github/workflows/testing.yml | 54 +++------------- 4 files changed, 116 insertions(+), 118 deletions(-) create mode 100644 .github/actions/load-data/action.yml diff --git a/.github/actions/load-data/action.yml b/.github/actions/load-data/action.yml new file mode 100644 index 000000000..3ad750131 --- /dev/null +++ b/.github/actions/load-data/action.yml @@ -0,0 +1,96 @@ +name: 'Prepare Datasets' +description: 'Restores data form caches or downloads it from S3.' +inputs: + aws-access-key-id: + description: 'AWS Access Key ID' + required: true + aws-secret-access-key: + description: 'AWS Secret Access Key' + required: true + s3-gin-bucket: + description: 'S3 GIN Bucket URL' + required: true + os: + description: 'Operating system' + required: true +runs: + using: 'composite' + steps: + - name: Get ephy_testing_data current head hash + id: ephys + shell: bash + run: | + HASH=$(git ls-remote https://gin.g-node.org/NeuralEnsemble/ephy_testing_data.git HEAD | cut -f1) + echo "HASH_EPHY_DATASET=$HASH" >> $GITHUB_OUTPUT + + - name: Cache ephys dataset + uses: actions/cache@v4 + id: cache-ephys-datasets + with: + path: ./ephy_testing_data + key: ephys-datasets-${{ inputs.os }}-${{ steps.ephys.outputs.HASH_EPHY_DATASET }} + + - name: Get ophys_testing_data current head hash + id: ophys + shell: bash + run: | + HASH=$(git ls-remote https://gin.g-node.org/CatalystNeuro/ophys_testing_data.git HEAD | cut -f1) + echo "HASH_OPHYS_DATASET=$HASH" >> $GITHUB_OUTPUT + + - name: Cache ophys dataset + uses: actions/cache@v4 + id: cache-ophys-datasets + with: + path: ./ophys_testing_data + key: ophys-datasets-${{ inputs.os }}-${{ steps.ophys.outputs.HASH_OPHYS_DATASET }} + + - name: Get behavior_testing_data current head hash + id: behavior + shell: bash + run: | + HASH=$(git ls-remote https://gin.g-node.org/CatalystNeuro/behavior_testing_data.git HEAD | cut -f1) + echo "HASH_BEHAVIOR_DATASET=$HASH" >> $GITHUB_OUTPUT + + - name: Cache behavior dataset + uses: actions/cache@v4 + id: cache-behavior-datasets + with: + path: ./behavior_testing_data + key: behavior-datasets-${{ inputs.os }}-${{ steps.behavior.outputs.HASH_BEHAVIOR_DATASET }} + + - name: Determine if downloads are required + id: download-check + run: | + if [[ "${{ steps.cache-ephys-datasets.outputs.cache-hit }}" != 'true' || \ + "${{ steps.cache-ophys-datasets.outputs.cache-hit }}" != 'true' || \ + "${{ steps.cache-behavior-datasets.outputs.cache-hit }}" != 'true' ]]; then + echo "DOWNLOAD_REQUIRED=true" >> $GITHUB_OUTPUT + else + echo "DOWNLOAD_REQUIRED=false" >> $GITHUB_OUTPUT + fi + + - if: ${{ steps.download-check.outputs.DOWNLOAD_REQUIRED == 'true' }} + name: Install and configure AWS CLI + shell: bash + run: | + pip install awscli + aws configure set aws_access_key_id "${{ inputs.aws-access-key-id }}" + aws configure set aws_secret_access_key "${{ inputs.aws-secret-access-key }}" + + - if: ${{ steps.cache-ephys-datasets.outputs.cache-hit != 'true' }} + name: Download ephys dataset from S3 + shell: bash + run: | + aws s3 cp --recursive "${{ inputs.s3-gin-bucket }}/ephy_testing_data" ./ephy_testing_data + + - if: ${{ steps.cache-ophys-datasets.outputs.cache-hit != 'true' }} + name: Download ophys dataset from S3 + shell: bash + run: | + aws s3 cp --recursive "${{ inputs.s3-gin-bucket }}/ophys_testing_data" ./ophys_testing_data + + - if: ${{ steps.cache-behavior-datasets.outputs.cache-hit != 'true' }} + name: Download behavior dataset from S3 + shell: bash + run: | + aws s3 cp --recursive "${{ inputs.s3-gin-bucket }}/behavior_testing_data" ./behavior_testing_data diff --git a/.github/workflows/dev-testing.yml b/.github/workflows/dev-testing.yml index acd7a3d74..31b5329a8 100644 --- a/.github/workflows/dev-testing.yml +++ b/.github/workflows/dev-testing.yml @@ -72,52 +72,13 @@ jobs: run: | pip list - - name: Get ephy_testing_data current head hash - id: ephys - run: echo "::set-output name=HASH_EPHY_DATASET::$(git ls-remote https://gin.g-node.org/NeuralEnsemble/ephy_testing_data.git HEAD | cut -f1)" - - name: Cache ephys dataset - ${{ steps.ephys.outputs.HASH_EPHY_DATASET }} - uses: actions/cache@v4 - id: cache-ephys-datasets + - name: Prepare data for tests + uses: ./.github/actions/load-data with: - path: ./ephy_testing_data - key: ephys-datasets-2024-08-30-ubuntu-latest-${{ steps.ephys.outputs.HASH_EPHY_DATASET }} - - name: Get ophys_testing_data current head hash - id: ophys - run: echo "::set-output name=HASH_OPHYS_DATASET::$(git ls-remote https://gin.g-node.org/CatalystNeuro/ophys_testing_data.git HEAD | cut -f1)" - - name: Cache ophys dataset - ${{ steps.ophys.outputs.HASH_OPHYS_DATASET }} - uses: actions/cache@v4 - id: cache-ophys-datasets - with: - path: ./ophys_testing_data - key: ophys-datasets-2022-08-18-ubuntu-latest-${{ steps.ophys.outputs.HASH_OPHYS_DATASET }} - - name: Get behavior_testing_data current head hash - id: behavior - run: echo "::set-output name=HASH_BEHAVIOR_DATASET::$(git ls-remote https://gin.g-node.org/CatalystNeuro/behavior_testing_data.git HEAD | cut -f1)" - - name: Cache behavior dataset - ${{ steps.behavior.outputs.HASH_BEHAVIOR_DATASET }} - uses: actions/cache@v4 - id: cache-behavior-datasets - with: - path: ./behavior_testing_data - key: behavior-datasets-2023-07-26-ubuntu-latest-${{ steps.behavior.outputs.HASH_behavior_DATASET }} - - - - - if: steps.cache-ephys-datasets.outputs.cache-hit != 'true' || steps.cache-ophys-datasets.outputs.cache-hit != 'true' || steps.cache-behavior-datasets.outputs.cache-hit != 'true' - name: Install and configure AWS CLI - run: | - pip install awscli - aws configure set aws_access_key_id ${{ secrets.AWS_ACCESS_KEY_ID }} - aws configure set aws_secret_access_key ${{ secrets.AWS_SECRET_ACCESS_KEY }} - - if: steps.cache-ephys-datasets.outputs.cache-hit != 'true' - name: Download ephys dataset from S3 - run: aws s3 cp --recursive ${{ secrets.S3_GIN_BUCKET }}/ephy_testing_data ./ephy_testing_data - - if: steps.cache-ophys-datasets.outputs.cache-hit != 'true' - name: Download ophys dataset from S3 - run: aws s3 cp --recursive ${{ secrets.S3_GIN_BUCKET }}/ophys_testing_data ./ophys_testing_data - - if: steps.cache-behavior-datasets.outputs.cache-hit != 'true' - name: Download behavior dataset from S3 - run: aws s3 cp --recursive ${{ secrets.S3_GIN_BUCKET }}/behavior_testing_data ./behavior_testing_data - + aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} + aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} + s3-gin-bucket: ${{ secrets.S3_GIN_BUCKET }} + os: ${{ matrix.os }} - name: Run full pytest diff --git a/.github/workflows/doctests.yml b/.github/workflows/doctests.yml index d816dbd02..e492eda0c 100644 --- a/.github/workflows/doctests.yml +++ b/.github/workflows/doctests.yml @@ -46,34 +46,13 @@ jobs: with: os: ${{ runner.os }} - - name: Get ephy_testing_data current head hash - id: ephys - run: echo "::set-output name=HASH_EPHY_DATASET::$(git ls-remote https://gin.g-node.org/NeuralEnsemble/ephy_testing_data.git HEAD | cut -f1)" - - name: Cache ephys dataset - ${{ steps.ephys.outputs.HASH_EPHY_DATASET }} - uses: actions/cache@v4 - id: cache-ephys-datasets + - name: Prepare data for tests + uses: ./.github/actions/load-data with: - path: ./ephy_testing_data - key: ephys-datasets-2024-08-30-${{ matrix.os }}-${{ steps.ephys.outputs.HASH_EPHY_DATASET }} - - name: Get ophys_testing_data current head hash - id: ophys - run: echo "::set-output name=HASH_OPHYS_DATASET::$(git ls-remote https://gin.g-node.org/CatalystNeuro/ophys_testing_data.git HEAD | cut -f1)" - - name: Cache ophys dataset - ${{ steps.ophys.outputs.HASH_OPHYS_DATASET }} - uses: actions/cache@v4 - id: cache-ophys-datasets - with: - path: ./ophys_testing_data - key: ophys-datasets-2022-08-18-${{ matrix.os }}-${{ steps.ophys.outputs.HASH_OPHYS_DATASET }} - - name: Get behavior_testing_data current head hash - id: behavior - run: echo "::set-output name=HASH_BEHAVIOR_DATASET::$(git ls-remote https://gin.g-node.org/CatalystNeuro/behavior_testing_data.git HEAD | cut -f1)" - - name: Cache behavior dataset - ${{ steps.behavior.outputs.HASH_BEHAVIOR_DATASET }} - uses: actions/cache@v4 - id: cache-behavior-datasets - with: - path: ./behavior_testing_data - key: behavior-datasets-2023-07-26-${{ matrix.os }}-${{ steps.behavior.outputs.HASH_behavior_DATASET }} - + aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} + aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} + s3-gin-bucket: ${{ secrets.S3_GIN_BUCKET }} + os: ${{ matrix.os }} - name: Run doctests diff --git a/.github/workflows/testing.yml b/.github/workflows/testing.yml index 736da6030..06de82c4c 100644 --- a/.github/workflows/testing.yml +++ b/.github/workflows/testing.yml @@ -93,54 +93,16 @@ jobs: #- name: Run icephys tests # There are no icephys specific tests without data # run: pytest tests/test_icephys -rsx -n auto --dist loadscope - - name: Install full requirements - run: pip install .[full] - - - name: Get ephy_testing_data current head hash - id: ephys - run: echo "::set-output name=HASH_EPHY_DATASET::$(git ls-remote https://gin.g-node.org/NeuralEnsemble/ephy_testing_data.git HEAD | cut -f1)" - - name: Cache ephys dataset - ${{ steps.ephys.outputs.HASH_EPHY_DATASET }} - uses: actions/cache@v4 - id: cache-ephys-datasets - with: - path: ./ephy_testing_data - key: ephys-datasets-2024-08-30-${{ matrix.os }}-${{ steps.ephys.outputs.HASH_EPHY_DATASET }} - - name: Get ophys_testing_data current head hash - id: ophys - run: echo "::set-output name=HASH_OPHYS_DATASET::$(git ls-remote https://gin.g-node.org/CatalystNeuro/ophys_testing_data.git HEAD | cut -f1)" - - name: Cache ophys dataset - ${{ steps.ophys.outputs.HASH_OPHYS_DATASET }} - uses: actions/cache@v4 - id: cache-ophys-datasets - with: - path: ./ophys_testing_data - key: ophys-datasets-2022-08-18-${{ matrix.os }}-${{ steps.ophys.outputs.HASH_OPHYS_DATASET }} - - name: Get behavior_testing_data current head hash - id: behavior - run: echo "::set-output name=HASH_BEHAVIOR_DATASET::$(git ls-remote https://gin.g-node.org/CatalystNeuro/behavior_testing_data.git HEAD | cut -f1)" - - name: Cache behavior dataset - ${{ steps.behavior.outputs.HASH_BEHAVIOR_DATASET }} - uses: actions/cache@v4 - id: cache-behavior-datasets + - name: Prepare data for tests + uses: ./.github/actions/load-data with: - path: ./behavior_testing_data - key: behavior-datasets-2023-07-26-${{ matrix.os }}-${{ steps.behavior.outputs.HASH_behavior_DATASET }} + aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} + aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} + s3-gin-bucket: ${{ secrets.S3_GIN_BUCKET }} + os: ${{ matrix.os }} - - - - if: steps.cache-ephys-datasets.outputs.cache-hit != 'true' || steps.cache-ophys-datasets.outputs.cache-hit != 'true' || steps.cache-behavior-datasets.outputs.cache-hit != 'true' - name: Install and configure AWS CLI - run: | - pip install awscli - aws configure set aws_access_key_id ${{ secrets.AWS_ACCESS_KEY_ID }} - aws configure set aws_secret_access_key ${{ secrets.AWS_SECRET_ACCESS_KEY }} - - if: steps.cache-ephys-datasets.outputs.cache-hit != 'true' - name: Download ephys dataset from S3 - run: aws s3 cp --recursive ${{ secrets.S3_GIN_BUCKET }}/ephy_testing_data ./ephy_testing_data - - if: steps.cache-ophys-datasets.outputs.cache-hit != 'true' - name: Download ophys dataset from S3 - run: aws s3 cp --recursive ${{ secrets.S3_GIN_BUCKET }}/ophys_testing_data ./ophys_testing_data - - if: steps.cache-behavior-datasets.outputs.cache-hit != 'true' - name: Download behavior dataset from S3 - run: aws s3 cp --recursive ${{ secrets.S3_GIN_BUCKET }}/behavior_testing_data ./behavior_testing_data + - name: Install full requirements + run: pip install .[full] - name: Run full pytest with coverage run: pytest -vv -rsx -n auto --dist loadscope --cov=neuroconv --cov-report xml:./codecov.xml From a617f432c74faf6aadad629fc94ab2c6bd09d6e4 Mon Sep 17 00:00:00 2001 From: Heberto Mayorquin Date: Tue, 17 Sep 2024 22:16:57 -0600 Subject: [PATCH 2/3] add missing bash shell --- .github/actions/load-data/action.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/actions/load-data/action.yml b/.github/actions/load-data/action.yml index 3ad750131..77dd3ce93 100644 --- a/.github/actions/load-data/action.yml +++ b/.github/actions/load-data/action.yml @@ -1,5 +1,5 @@ name: 'Prepare Datasets' -description: 'Restores data form caches or downloads it from S3.' +description: 'Restores data from caches or downloads it from S3.' inputs: aws-access-key-id: description: 'AWS Access Key ID' @@ -60,6 +60,7 @@ runs: - name: Determine if downloads are required id: download-check + shell: bash # Added shell property run: | if [[ "${{ steps.cache-ephys-datasets.outputs.cache-hit }}" != 'true' || \ "${{ steps.cache-ophys-datasets.outputs.cache-hit }}" != 'true' || \ From 228b732845030802d1d53158cf0af730128348f7 Mon Sep 17 00:00:00 2001 From: Heberto Mayorquin Date: Wed, 18 Sep 2024 11:09:21 -0600 Subject: [PATCH 3/3] changelog --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index dc8d4112d..16ab95f71 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,7 +10,7 @@ ## Improvements * Run only the most basic testing while a PR is on draft [PR #1082](https://github.com/catalystneuro/neuroconv/pull/1082) * Avoid running link test when the PR is on draft [PR #1093](https://github.com/catalystneuro/neuroconv/pull/1093) - +* Centralize gin data preparation in a github action [PR #1095](https://github.com/catalystneuro/neuroconv/pull/1095) # v0.6.4 (September 17, 2024)