From 847c5e2d3488d68a541199723b09ec3550776f82 Mon Sep 17 00:00:00 2001 From: Antonio Gonzalez Date: Fri, 10 Feb 2023 13:37:34 -0700 Subject: [PATCH 1/7] Python 2.7 --- .github/workflows/qiita-ci.yml | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/.github/workflows/qiita-ci.yml b/.github/workflows/qiita-ci.yml index c210eea..50cda0d 100644 --- a/.github/workflows/qiita-ci.yml +++ b/.github/workflows/qiita-ci.yml @@ -9,6 +9,10 @@ jobs: main: runs-on: ubuntu-latest + strategy: + matrix: + python-version: ["2.7", "3.9"] + services: postgres: # Docker Hub image @@ -73,7 +77,7 @@ jobs: - name: Install Qiita plugins shell: bash -l {0} run: | - conda create --yes -n qiita_client python=3.9 pip nose flake8 coverage + conda create --yes -n qiita_client python=${{ matrix.python-version }} pip nose flake8 coverage conda activate qiita_client pip --quiet install . From 3b373416af3b67b9320d5bfe34d141c66e0ea509 Mon Sep 17 00:00:00 2001 From: Antonio Gonzalez Date: Fri, 10 Feb 2023 13:44:45 -0700 Subject: [PATCH 2/7] fix RuntimeError --- qiita_client/qiita_client.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/qiita_client/qiita_client.py b/qiita_client/qiita_client.py index 00e6e29..fbbe76f 100644 --- a/qiita_client/qiita_client.py +++ b/qiita_client/qiita_client.py @@ -590,8 +590,9 @@ def artifact_and_preparation_files(self, artifact_id, if artifact_info['analysis'] is not None: raise RuntimeError( - f'Artifact {artifact_id} is an analysis artifact, this method ' - 'is meant to work with artifacts linked to a preparation.') + 'Artifact' + str(artifact_id) + 'is an analysis artifact, ' + 'this method is meant to work with artifacts linked to ' + 'a preparation.') prep_info = self.get('/qiita_db/prep_template/%s/' % artifact_info['prep_information'][0]) From 4eeeaf871af093f382f693af79ac89ed8973bc2f Mon Sep 17 00:00:00 2001 From: Antonio Gonzalez Date: Fri, 10 Feb 2023 13:52:29 -0700 Subject: [PATCH 3/7] readd spaces --- qiita_client/qiita_client.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/qiita_client/qiita_client.py b/qiita_client/qiita_client.py index fbbe76f..a413cf8 100644 --- a/qiita_client/qiita_client.py +++ b/qiita_client/qiita_client.py @@ -590,7 +590,7 @@ def artifact_and_preparation_files(self, artifact_id, if artifact_info['analysis'] is not None: raise RuntimeError( - 'Artifact' + str(artifact_id) + 'is an analysis artifact, ' + 'Artifact ' + str(artifact_id) + ' is an analysis artifact, ' 'this method is meant to work with artifacts linked to ' 'a preparation.') From c049f68b2717b3cc1f3b4d8d4d11f064e6f881c2 Mon Sep 17 00:00:00 2001 From: Antonio Gonzalez Date: Fri, 10 Feb 2023 14:01:55 -0700 Subject: [PATCH 4/7] rm some f-strigs --- qiita_client/qiita_client.py | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/qiita_client/qiita_client.py b/qiita_client/qiita_client.py index a413cf8..3414152 100644 --- a/qiita_client/qiita_client.py +++ b/qiita_client/qiita_client.py @@ -616,8 +616,9 @@ def _process_files_per_sample_fastq(self, files, prep_info, revs = sorted( files['raw_reverse_seqs'], key=lambda x: x['filepath']) if len(fwds) != len(revs): - raise ValueError(f'The fwd ({len(fwds)}) and rev ({len(revs)})' - ' files should be of the same length') + raise ValueError('The fwd (' + str(len(fwds)) ') and rev (' + + str(len(revs)) + ') files should be of the ' + 'same length') run_prefixes = prep_info['run_prefix'].to_dict() @@ -636,15 +637,15 @@ def _process_files_per_sample_fastq(self, files, prep_info, run_prefix = rp sample_name = sn elif fwd_fn.startswith(rp) and run_prefix is not None: - raise ValueError( - f'Multiple run prefixes match this fwd read: {fwd_fn}') + raise ValueError('Multiple run prefixes match this fwd ' + 'read: %s' % fwd_fn) if run_prefix is None: raise ValueError( - f'No run prefix matching this fwd read: {fwd_fn}') + 'No run prefix matching this fwd read: %s' % fwd_fn) if run_prefix in used_prefixes: raise ValueError( - f'Run prefix matches multiple fwd reads: {run_prefix}') + f'Run prefix matches multiple fwd reads: %s' % run_prefix) used_prefixes.append(run_prefix) if rev is not None: @@ -656,7 +657,7 @@ def _process_files_per_sample_fastq(self, files, prep_info, if not rev_fn.startswith(run_prefix): raise ValueError( 'Reverse read does not match run prefix. run_prefix: ' - f'{run_prefix}; files: {fwd_fn} / {rev_fn}') + '%s; files: %s / %s') % (run_prefix, fwd_fn, rev_fn) used_prefixes.append(run_prefix) From a8a98acda9b26b6d412ef24d57e71d318e28c9e8 Mon Sep 17 00:00:00 2001 From: Antonio Gonzalez Date: Fri, 10 Feb 2023 14:08:14 -0700 Subject: [PATCH 5/7] flake8 --- qiita_client/qiita_client.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/qiita_client/qiita_client.py b/qiita_client/qiita_client.py index 3414152..7fcf4cd 100644 --- a/qiita_client/qiita_client.py +++ b/qiita_client/qiita_client.py @@ -616,8 +616,8 @@ def _process_files_per_sample_fastq(self, files, prep_info, revs = sorted( files['raw_reverse_seqs'], key=lambda x: x['filepath']) if len(fwds) != len(revs): - raise ValueError('The fwd (' + str(len(fwds)) ') and rev (' + - str(len(revs)) + ') files should be of the ' + raise ValueError('The fwd (' + str(len(fwds)) + ') and rev (' + + str(len(revs)) + ') files should be of the ' 'same length') run_prefixes = prep_info['run_prefix'].to_dict() @@ -645,7 +645,7 @@ def _process_files_per_sample_fastq(self, files, prep_info, 'No run prefix matching this fwd read: %s' % fwd_fn) if run_prefix in used_prefixes: raise ValueError( - f'Run prefix matches multiple fwd reads: %s' % run_prefix) + 'Run prefix matches multiple fwd reads: %s' % run_prefix) used_prefixes.append(run_prefix) if rev is not None: From a8508ffd7dba22551f680dd0241bf729bc4fbdcf Mon Sep 17 00:00:00 2001 From: Antonio Gonzalez Date: Fri, 10 Feb 2023 14:19:32 -0700 Subject: [PATCH 6/7] zip_longest --- qiita_client/qiita_client.py | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/qiita_client/qiita_client.py b/qiita_client/qiita_client.py index 7fcf4cd..881cf5a 100644 --- a/qiita_client/qiita_client.py +++ b/qiita_client/qiita_client.py @@ -12,7 +12,12 @@ import pandas as pd from json import dumps from random import randint -from itertools import zip_longest + +try: + from itertools import zip_longest +except ImportError: + from itertools import izip_longest as zip_longest + from os.path import basename from .exceptions import (QiitaClientError, NotFoundError, BadRequestError, From 1a6f26844d0d3a61cec7c9bfef49b63ff586efba Mon Sep 17 00:00:00 2001 From: Antonio Gonzalez Date: Fri, 10 Feb 2023 14:31:10 -0700 Subject: [PATCH 7/7] assertRaisesRegex --- qiita_client/tests/test_qiita_client.py | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/qiita_client/tests/test_qiita_client.py b/qiita_client/tests/test_qiita_client.py index 6d85afa..cfc6ec2 100644 --- a/qiita_client/tests/test_qiita_client.py +++ b/qiita_client/tests/test_qiita_client.py @@ -101,6 +101,10 @@ def setUp(self): CLIENT_SECRET, server_cert=self.server_cert) self.clean_up_files = [] + # making assertRaisesRegex compatible with Python 2.7 and 3.9 + if not hasattr(self, 'assertRaisesRegex'): + setattr(self, 'assertRaisesRegex', self.assertRaisesRegexp) + def tearDown(self): for fp in self.clean_up_files: if exists(fp):