Started by timer Running as SYSTEM Building remotely on Ubuntu_18.04_bioeng49 (buildslave Testing) in workspace /home/cmiss/Jenkins/workspace/SPARC-API-DEV [WS-CLEANUP] Deleting project workspace... [WS-CLEANUP] Deferred wipeout is used... [WS-CLEANUP] Done The recommended git tool is: NONE No credentials specified Cloning the remote Git repository Cloning repository https://github.com/nih-sparc/sparc-api.git > git init /home/cmiss/Jenkins/workspace/SPARC-API-DEV # timeout=10 Fetching upstream changes from https://github.com/nih-sparc/sparc-api.git > git --version # timeout=10 > git --version # 'git version 2.25.1' > git fetch --tags --force --progress -- https://github.com/nih-sparc/sparc-api.git +refs/heads/*:refs/remotes/origin/* # timeout=10 > git config remote.origin.url https://github.com/nih-sparc/sparc-api.git # timeout=10 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 Avoid second fetch > git rev-parse refs/remotes/origin/master^{commit} # timeout=10 Checking out Revision 3e282891409dc8be4f9539770789babeae12a569 (refs/remotes/origin/master) > git config core.sparsecheckout # timeout=10 > git checkout -f 3e282891409dc8be4f9539770789babeae12a569 # timeout=10 Commit message: "Merge pull request #286 from nih-sparc/encode-sparc-logo" > git rev-list --no-walk 3e282891409dc8be4f9539770789babeae12a569 # timeout=10 [SPARC-API-DEV] $ /bin/bash /tmp/jenkins11266049448234750340.sh Requirement already satisfied: algoliasearch==2.6.2 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 1)) (2.6.2) Requirement already satisfied: api==0.0.7 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 2)) (0.0.7) Requirement already satisfied: APScheduler==3.7.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 3)) (3.7.0) Requirement already satisfied: boto3==1.26 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 4)) (1.26.0) Requirement already satisfied: botocore==1.29.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 5)) (1.29.0) Requirement already satisfied: certifi==2023.5.7 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 6)) (2023.5.7) Requirement already satisfied: chardet==3.0.4 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 7)) (3.0.4) Collecting Click==7.1.2 (from -r requirements.txt (line 8)) Using cached click-7.1.2-py2.py3-none-any.whl.metadata (2.9 kB) Requirement already satisfied: contentful==1.13.1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 9)) (1.13.1) Requirement already satisfied: contentful_management==2.11.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 10)) (2.11.0) Requirement already satisfied: docutils==0.15.2 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 11)) (0.15.2) Requirement already satisfied: Flask==1.1.1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 12)) (1.1.1) Requirement already satisfied: Flask-Caching==2.3.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 13)) (2.3.0) Requirement already satisfied: Flask-Cors==3.0.8 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 14)) (3.0.8) Requirement already satisfied: flask-marshmallow==0.10.1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 15)) (0.10.1) Requirement already satisfied: google-api-python-client==2.52.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 16)) (2.52.0) Requirement already satisfied: gunicorn==20.0.4 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 17)) (20.0.4) Requirement already satisfied: httpx>=0.27.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 18)) (0.28.1) Requirement already satisfied: hubspot-api-client==9.0.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 19)) (9.0.0) Requirement already satisfied: idna==2.8 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 20)) (2.8) Requirement already satisfied: itsdangerous==1.1.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 21)) (1.1.0) Requirement already satisfied: Jinja2==2.11.3 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 22)) (2.11.3) Requirement already satisfied: jmespath==0.9.4 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 23)) (0.9.4) Requirement already satisfied: MarkupSafe==1.1.1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 24)) (1.1.1) Requirement already satisfied: markdown==3.8 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 25)) (3.8) Requirement already satisfied: marshmallow==3.2.2 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 26)) (3.2.2) Requirement already satisfied: nose==1.3.7 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 27)) (1.3.7) Requirement already satisfied: oauth2client==4.1.3 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 28)) (4.1.3) Requirement already satisfied: osparc==0.4.3 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 29)) (0.4.3) Requirement already satisfied: Pennsieve==6.1.1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 30)) (6.1.1) Requirement already satisfied: Pennsieve2==0.1.2 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 31)) (0.1.2) Requirement already satisfied: Pillow in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 32)) (11.2.1) Requirement already satisfied: psycopg2-binary==2.9.10 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 33)) (2.9.10) Requirement already satisfied: public==2019.4.13 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 34)) (2019.4.13) Requirement already satisfied: pytest in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 35)) (8.4.1) Requirement already satisfied: pymongo==3.8.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 36)) (3.8.0) Requirement already satisfied: python-dateutil==2.8.2 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 37)) (2.8.2) Requirement already satisfied: python-dotenv==0.10.3 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 38)) (0.10.3) Requirement already satisfied: query-string==2019.4.13 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 39)) (2019.4.13) Requirement already satisfied: requests==2.31.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 40)) (2.31.0) Requirement already satisfied: s3transfer==0.6.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 41)) (0.6.0) Requirement already satisfied: sendgrid==6.9.7 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 42)) (6.9.7) Requirement already satisfied: six==1.13.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 43)) (1.13.0) Requirement already satisfied: SQLAlchemy==2.0.40 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 44)) (2.0.40) Requirement already satisfied: urllib3==1.26.4 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 45)) (1.26.4) Requirement already satisfied: Werkzeug==0.16.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements.txt (line 46)) (0.16.0) Requirement already satisfied: charset-normalizer<4,>=2 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from requests==2.31.0->-r requirements.txt (line 40)) (3.4.2) Requirement already satisfied: setuptools>=0.7 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from APScheduler==3.7.0->-r requirements.txt (line 3)) (80.3.1) Requirement already satisfied: pytz in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from APScheduler==3.7.0->-r requirements.txt (line 3)) (2025.2) Requirement already satisfied: tzlocal~=2.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from APScheduler==3.7.0->-r requirements.txt (line 3)) (2.1) Requirement already satisfied: cachelib<0.10.0,>=0.9.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Flask-Caching==2.3.0->-r requirements.txt (line 13)) (0.9.0) Requirement already satisfied: httplib2<1dev,>=0.15.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from google-api-python-client==2.52.0->-r requirements.txt (line 16)) (0.22.0) Requirement already satisfied: google-auth<3.0.0dev,>=1.19.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from google-api-python-client==2.52.0->-r requirements.txt (line 16)) (2.40.0) Requirement already satisfied: google-auth-httplib2>=0.1.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from google-api-python-client==2.52.0->-r requirements.txt (line 16)) (0.2.0) Requirement already satisfied: google-api-core!=2.0.*,!=2.1.*,!=2.2.*,!=2.3.0,<3.0.0dev,>=1.31.5 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from google-api-python-client==2.52.0->-r requirements.txt (line 16)) (2.25.0rc0) Requirement already satisfied: uritemplate<5,>=3.0.1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from google-api-python-client==2.52.0->-r requirements.txt (line 16)) (4.1.1) Requirement already satisfied: pyasn1>=0.1.7 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from oauth2client==4.1.3->-r requirements.txt (line 28)) (0.6.1) Requirement already satisfied: pyasn1-modules>=0.0.5 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from oauth2client==4.1.3->-r requirements.txt (line 28)) (0.4.2) Requirement already satisfied: rsa>=3.1.4 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from oauth2client==4.1.3->-r requirements.txt (line 28)) (4.0) Requirement already satisfied: configparser>=3.5 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Pennsieve==6.1.1->-r requirements.txt (line 30)) (7.2.0) Requirement already satisfied: deprecated>=1.2.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Pennsieve==6.1.1->-r requirements.txt (line 30)) (1.2.18) Requirement already satisfied: future>=0.15.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Pennsieve==6.1.1->-r requirements.txt (line 30)) (1.0.0) Requirement already satisfied: futures in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Pennsieve==6.1.1->-r requirements.txt (line 30)) (3.0.5) Requirement already satisfied: protobuf>=3.2.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Pennsieve==6.1.1->-r requirements.txt (line 30)) (4.25.7) Requirement already satisfied: python-jose==3.2.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Pennsieve==6.1.1->-r requirements.txt (line 30)) (3.2.0) Requirement already satisfied: semver>=2.8.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Pennsieve==6.1.1->-r requirements.txt (line 30)) (3.0.4) Requirement already satisfied: websocket-client>=0.57.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Pennsieve==6.1.1->-r requirements.txt (line 30)) (1.8.0) Requirement already satisfied: docopt>=0.6 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Pennsieve==6.1.1->-r requirements.txt (line 30)) (0.6.2) Requirement already satisfied: psutil>=5.4 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Pennsieve==6.1.1->-r requirements.txt (line 30)) (7.0.0) Requirement already satisfied: grpcio<2.0,>=1.51 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Pennsieve2==0.1.2->-r requirements.txt (line 31)) (1.71.0) Requirement already satisfied: grpcio_tools<2.0,>=1.51 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Pennsieve2==0.1.2->-r requirements.txt (line 31)) (1.62.3) Requirement already satisfied: pyjwt<3.0,>=2.6 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Pennsieve2==0.1.2->-r requirements.txt (line 31)) (2.10.1) Requirement already satisfied: tqdm<5.0,>=4.64 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from Pennsieve2==0.1.2->-r requirements.txt (line 31)) (4.67.1) Requirement already satisfied: python-http-client>=3.2.1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from sendgrid==6.9.7->-r requirements.txt (line 42)) (3.3.7) Requirement already satisfied: starkbank-ecdsa>=2.0.1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from sendgrid==6.9.7->-r requirements.txt (line 42)) (2.2.0) Requirement already satisfied: greenlet>=1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from SQLAlchemy==2.0.40->-r requirements.txt (line 44)) (3.2.1) Requirement already satisfied: typing-extensions>=4.6.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from SQLAlchemy==2.0.40->-r requirements.txt (line 44)) (4.13.2) Requirement already satisfied: ecdsa<0.15 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from python-jose==3.2.0->Pennsieve==6.1.1->-r requirements.txt (line 30)) (0.14.1) Requirement already satisfied: googleapis-common-protos<2.0.0,>=1.56.2 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from google-api-core!=2.0.*,!=2.1.*,!=2.2.*,!=2.3.0,<3.0.0dev,>=1.31.5->google-api-python-client==2.52.0->-r requirements.txt (line 16)) (1.70.0) Requirement already satisfied: proto-plus<2.0.0,>=1.22.3 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from google-api-core!=2.0.*,!=2.1.*,!=2.2.*,!=2.3.0,<3.0.0dev,>=1.31.5->google-api-python-client==2.52.0->-r requirements.txt (line 16)) (1.26.1) Requirement already satisfied: cachetools<6.0,>=2.0.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from google-auth<3.0.0dev,>=1.19.0->google-api-python-client==2.52.0->-r requirements.txt (line 16)) (5.5.2) Requirement already satisfied: pyparsing!=3.0.0,!=3.0.1,!=3.0.2,!=3.0.3,<4,>=2.4.2 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from httplib2<1dev,>=0.15.0->google-api-python-client==2.52.0->-r requirements.txt (line 16)) (3.2.3) Requirement already satisfied: anyio in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from httpx>=0.27.0->-r requirements.txt (line 18)) (4.9.0) Requirement already satisfied: httpcore==1.* in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from httpx>=0.27.0->-r requirements.txt (line 18)) (1.0.9) Requirement already satisfied: h11>=0.16 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from httpcore==1.*->httpx>=0.27.0->-r requirements.txt (line 18)) (0.16.0) Requirement already satisfied: exceptiongroup>=1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest->-r requirements.txt (line 35)) (1.2.2) Requirement already satisfied: iniconfig>=1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest->-r requirements.txt (line 35)) (2.1.0) Requirement already satisfied: packaging>=20 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest->-r requirements.txt (line 35)) (25.0) Requirement already satisfied: pluggy<2,>=1.5 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest->-r requirements.txt (line 35)) (1.6.0) Requirement already satisfied: pygments>=2.7.2 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest->-r requirements.txt (line 35)) (2.19.1) Requirement already satisfied: tomli>=1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest->-r requirements.txt (line 35)) (2.2.1) Requirement already satisfied: wrapt<2,>=1.10 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from deprecated>=1.2.0->Pennsieve==6.1.1->-r requirements.txt (line 30)) (1.17.2) Requirement already satisfied: sniffio>=1.1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from anyio->httpx>=0.27.0->-r requirements.txt (line 18)) (1.3.1) Using cached click-7.1.2-py2.py3-none-any.whl (82 kB) Installing collected packages: Click Attempting uninstall: Click Found existing installation: click 8.2.1 Uninstalling click-8.2.1: Successfully uninstalled click-8.2.1 ERROR: pip's dependency resolver does not currently take into account all the packages that are installed. This behaviour is the source of the following dependency conflicts. black 25.1.0 requires click>=8.0.0, but you have click 7.1.2 which is incompatible. Successfully installed Click-7.1.2 Collecting pytest==5.4.3 (from -r requirements-dev.txt (line 1)) Using cached pytest-5.4.3-py3-none-any.whl.metadata (7.3 kB) Requirement already satisfied: pennsieve==6.1.1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements-dev.txt (line 2)) (6.1.1) Requirement already satisfied: black in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements-dev.txt (line 3)) (25.1.0) Requirement already satisfied: isort in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements-dev.txt (line 4)) (6.0.1) Requirement already satisfied: nose in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements-dev.txt (line 5)) (1.3.7) Requirement already satisfied: packaging in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from -r requirements-dev.txt (line 6)) (25.0) Requirement already satisfied: py>=1.5.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest==5.4.3->-r requirements-dev.txt (line 1)) (1.11.0) Requirement already satisfied: attrs>=17.4.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest==5.4.3->-r requirements-dev.txt (line 1)) (25.3.0) Requirement already satisfied: more-itertools>=4.0.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest==5.4.3->-r requirements-dev.txt (line 1)) (10.7.0) Collecting pluggy<1.0,>=0.12 (from pytest==5.4.3->-r requirements-dev.txt (line 1)) Using cached pluggy-0.13.1-py2.py3-none-any.whl.metadata (15 kB) Requirement already satisfied: wcwidth in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest==5.4.3->-r requirements-dev.txt (line 1)) (0.2.13) Requirement already satisfied: boto3 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (1.26.0) Requirement already satisfied: configparser>=3.5 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (7.2.0) Requirement already satisfied: deprecated>=1.2.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (1.2.18) Requirement already satisfied: future>=0.15.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (1.0.0) Requirement already satisfied: futures in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (3.0.5) Requirement already satisfied: protobuf>=3.2.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (4.25.7) Requirement already satisfied: python-jose==3.2.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (3.2.0) Requirement already satisfied: pytz>=2016 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (2025.2) Requirement already satisfied: requests>=2.18 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (2.31.0) Requirement already satisfied: rsa==4.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (4.0) Requirement already satisfied: semver>=2.8.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (3.0.4) Requirement already satisfied: websocket-client>=0.57.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (1.8.0) Requirement already satisfied: docopt>=0.6 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (0.6.2) Requirement already satisfied: psutil>=5.4 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (7.0.0) Requirement already satisfied: python-dateutil>=2.8.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (2.8.2) Requirement already satisfied: six<2.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from python-jose==3.2.0->pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (1.13.0) Requirement already satisfied: ecdsa<0.15 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from python-jose==3.2.0->pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (0.14.1) Requirement already satisfied: pyasn1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from python-jose==3.2.0->pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (0.6.1) Collecting click>=8.0.0 (from black->-r requirements-dev.txt (line 3)) Using cached click-8.2.1-py3-none-any.whl.metadata (2.5 kB) Requirement already satisfied: mypy-extensions>=0.4.3 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from black->-r requirements-dev.txt (line 3)) (1.1.0) Requirement already satisfied: pathspec>=0.9.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from black->-r requirements-dev.txt (line 3)) (0.12.1) Requirement already satisfied: platformdirs>=2 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from black->-r requirements-dev.txt (line 3)) (4.3.7) Requirement already satisfied: tomli>=1.1.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from black->-r requirements-dev.txt (line 3)) (2.2.1) Requirement already satisfied: typing-extensions>=4.0.1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from black->-r requirements-dev.txt (line 3)) (4.13.2) Requirement already satisfied: wrapt<2,>=1.10 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from deprecated>=1.2.0->pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (1.17.2) Requirement already satisfied: charset-normalizer<4,>=2 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from requests>=2.18->pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (3.4.2) Requirement already satisfied: idna<4,>=2.5 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from requests>=2.18->pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (2.8) Requirement already satisfied: urllib3<3,>=1.21.1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from requests>=2.18->pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (1.26.4) Requirement already satisfied: certifi>=2017.4.17 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from requests>=2.18->pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (2023.5.7) Requirement already satisfied: botocore<1.30.0,>=1.29.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from boto3->pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (1.29.0) Requirement already satisfied: jmespath<2.0.0,>=0.7.1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from boto3->pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (0.9.4) Requirement already satisfied: s3transfer<0.7.0,>=0.6.0 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from boto3->pennsieve==6.1.1->-r requirements-dev.txt (line 2)) (0.6.0) Using cached pytest-5.4.3-py3-none-any.whl (248 kB) Using cached pluggy-0.13.1-py2.py3-none-any.whl (18 kB) Using cached click-8.2.1-py3-none-any.whl (102 kB) Installing collected packages: pluggy, click, pytest Attempting uninstall: pluggy Found existing installation: pluggy 1.6.0 Uninstalling pluggy-1.6.0: Successfully uninstalled pluggy-1.6.0 Attempting uninstall: click Found existing installation: click 7.1.2 Uninstalling click-7.1.2: Successfully uninstalled click-7.1.2 Attempting uninstall: pytest Found existing installation: pytest 8.4.1 Uninstalling pytest-8.4.1: Successfully uninstalled pytest-8.4.1 Successfully installed click-8.2.1 pluggy-0.13.1 pytest-5.4.3 Requirement already satisfied: pytest in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (5.4.3) Collecting pytest Using cached pytest-8.4.1-py3-none-any.whl.metadata (7.7 kB) Requirement already satisfied: exceptiongroup>=1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest) (1.2.2) Requirement already satisfied: iniconfig>=1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest) (2.1.0) Requirement already satisfied: packaging>=20 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest) (25.0) Collecting pluggy<2,>=1.5 (from pytest) Using cached pluggy-1.6.0-py3-none-any.whl.metadata (4.8 kB) Requirement already satisfied: pygments>=2.7.2 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest) (2.19.1) Requirement already satisfied: tomli>=1 in /home/cmiss/python3.10.venv/lib/python3.10/site-packages (from pytest) (2.2.1) Using cached pytest-8.4.1-py3-none-any.whl (365 kB) Using cached pluggy-1.6.0-py3-none-any.whl (20 kB) Installing collected packages: pluggy, pytest Attempting uninstall: pluggy Found existing installation: pluggy 0.13.1 Uninstalling pluggy-0.13.1: Successfully uninstalled pluggy-0.13.1 Attempting uninstall: pytest Found existing installation: pytest 5.4.3 Uninstalling pytest-5.4.3: Successfully uninstalled pytest-5.4.3 Successfully installed pluggy-1.6.0 pytest-8.4.1 ============================= test session starts ============================== platform linux -- Python 3.10.18, pytest-8.4.1, pluggy-1.6.0 rootdir: /home/cmiss/Jenkins/workspace/SPARC-API-DEV plugins: anyio-4.9.0 collected 122 items tests/test_api.py ..................FFF......... [ 24%] tests/test_biolucida.py ............. [ 35%] tests/test_dataset_info.py FsFFssFFF.. [ 44%] tests/test_health.py . [ 45%] tests/test_monthly_stats.py ......... [ 52%] tests/test_osparc.py .............. [ 63%] tests/test_plot.py F [ 64%] tests/test_pmr.py ......... [ 72%] tests/test_scicrunch.py FFFFFFFFFFFFFFFFFFFFFFFFFFF. [ 95%] tests/test_segmentation_info.py .. [ 96%] tests/test_thumbnails.py ... [ 99%] tests/test_update_contentful_entries.py . [100%] =================================== FAILURES =================================== _____________________ test_non_existing_simulation_ui_file _____________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_non_existing_simulation_ui_file(client): > r = client.get('/simulation_ui_file/137') tests/test_api.py:296: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:2227: in simulation_ui_file results = process_results(dataset_search(create_pennsieve_identifier_query(identifier))) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ------------------------------ Captured log call ------------------------------- ERROR root:main.py:2066 Emailoctopus contact did not get added/updated for email: hubspot_webhook_test@test.com. Returned a response of 400: {"title":"An error occurred.","detail":"Bad request.","status":400,"errors":[{"detail":"This value is not a valid UUID.","parameter":"list_id"}],"type":"https://emailoctopus.com/api-documentation/v2#bad-request"} ERROR root:main.py:2163 Error processing event {'subscriptionType': 'contact.propertyChange', 'objectId': '83944215465'}: 'tags' ____________________ test_simulation_ui_file_old_s3_bucket _____________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_simulation_ui_file_old_s3_bucket(client): > r = client.get('/simulation_ui_file/135') tests/test_api.py:301: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:2227: in simulation_ui_file results = process_results(dataset_search(create_pennsieve_identifier_query(identifier))) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ____________________ test_simulation_ui_file_new_s3_bucket _____________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_simulation_ui_file_new_s3_bucket(client): > r = client.get('/simulation_ui_file/308') tests/test_api.py:307: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:2227: in simulation_ui_file results = process_results(dataset_search(create_pennsieve_identifier_query(identifier))) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ____________________________ test_current_doi_list _____________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_current_doi_list(client): doi_stem = "doi:" start = timer() > r = client.get('/current_doi_list') tests/test_dataset_info.py:23: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:740: in get_all_doi results = reform_aggregation_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ___________________ test_generic_mouse_colon_dataset_search ____________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_generic_mouse_colon_dataset_search(client): title = "Generic mouse colon scaffold" start = timer() > r = client.get('/dataset_info/using_title', query_string={'title': title}) tests/test_dataset_info.py:132: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:662: in get_dataset_info_title return reform_dataset_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ______________________ test_complex_title_dataset_search _______________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_complex_title_dataset_search(client): title = "Spatial distribution and morphometric characterization of vagal efferents associated with the myenteric plexus of the rat stomach" start = timer() > r = client.get('/dataset_info/using_title', query_string={'title': title}) tests/test_dataset_info.py:151: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:662: in get_dataset_info_title return reform_dataset_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError __________________ test_title_plot_annotation_dataset_search ___________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_title_plot_annotation_dataset_search(client): print() title = "Sympathetic nerve stimulation of mouse and rabbit hearts" start = timer() > r = client.get('/dataset_info/using_title', query_string={'title': title}) tests/test_dataset_info.py:202: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:662: in get_dataset_info_title return reform_dataset_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ----------------------------- Captured stdout call ----------------------------- ____________________ test_object_identifier_dataset_search _____________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_object_identifier_dataset_search(client): #Dataset 212 print() identifier = "package:b5f9e5d7-7e09-4855-a923-a966454967d7" start = timer() > r = client.get('/dataset_info/using_object_identifier', query_string={'identifier': identifier}) tests/test_dataset_info.py:231: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:670: in get_dataset_info_object_identifier return reform_dataset_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ----------------------------- Captured stdout call ----------------------------- ___________________ test_pennsieve_identifier_dataset_search ___________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_pennsieve_identifier_dataset_search(client): print() identifier = "43" start = timer() > r = client.get('/dataset_info/using_pennsieve_identifier', query_string={'identifier': identifier}) tests/test_dataset_info.py:259: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:689: in get_dataset_info_pennsieve_identifier return reform_dataset_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ----------------------------- Captured stdout call ----------------------------- ________________________________ test_abi_plot _________________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_abi_plot(client): # Testing abi-plot with dataset 26 dataset_id = "26" > r = client.get('/dataset_info/using_pennsieve_identifier', query_string={'identifier': dataset_id}) tests/test_plot.py:17: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:689: in get_dataset_info_pennsieve_identifier return reform_dataset_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError _____________________________ test_scicrunch_keys ______________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_scicrunch_keys(client): > r = client.get('/search/') tests/test_scicrunch.py:26: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:779: in kb_search return process_results(response.json()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ____________________ test_scicrunch_versions_are_supported _____________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: def test_scicrunch_versions_are_supported(): # Lines below are to allow the test to be run from the root dir or sparc-api/tests current_directory = os.path.dirname(os.path.abspath(__file__)) app_directory = os.path.join(current_directory, '..', 'app') # List the contents of the 'app' directory, to find which versions we have files for available_versions = os.listdir(app_directory) r = requests.get(f'{Config.SCI_CRUNCH_HOST}/_search?api_key={Config.KNOWLEDGEBASE_KEY}&q=""') > results = r.json() tests/test_scicrunch.py:39: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError __________________________ test_scicrunch_dataset_doi __________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_scicrunch_dataset_doi(client): # Testing with dataset 55 identifier = "55" > run_doi_test = check_doi_status(client, identifier, '10.26275/pzek-91wx') tests/test_scicrunch.py:68: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ tests/test_scicrunch.py:53: in check_doi_status r = client.get('/dataset_info/using_pennsieve_identifier', query_string={'identifier': dataset_id}) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:689: in get_dataset_info_pennsieve_identifier return reform_dataset_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError _____________________ test_scicrunch_multiple_dataset_doi ______________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_scicrunch_multiple_dataset_doi(client): # Testing with dataset 55 and 68 > run_doi_test_1 = check_doi_status(client, "55", '10.26275/pzek-91wx') tests/test_scicrunch.py:84: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ tests/test_scicrunch.py:53: in check_doi_status r = client.get('/dataset_info/using_pennsieve_identifier', query_string={'identifier': dataset_id}) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:689: in get_dataset_info_pennsieve_identifier return reform_dataset_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError _____________________ test_scicrunch_multiple_dataset_ids ______________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_scicrunch_multiple_dataset_ids(client): # Testing with dataset 55 and 68 > r = client.get('/dataset_info/using_multiple_discoverIds/?discoverIds=55&discoverIds=68') tests/test_scicrunch.py:102: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:654: in get_dataset_info_discoverIds return process_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ____________________________ test_scicrunch_search _____________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_scicrunch_search(client): > r = client.get('/search/heart') tests/test_scicrunch.py:113: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:779: in kb_search return process_results(response.json()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ___________________________ test_scicrunch_all_data ____________________________ client = <FlaskClient <Flask 'app.main'>> def test_scicrunch_all_data(client): r = client.get('/filter-search/') > assert json.loads(r.data)['numberOfHits'] > 40 E KeyError: 'numberOfHits' tests/test_scicrunch.py:120: KeyError ____________________________ test_scicrunch_filter _____________________________ client = <FlaskClient <Flask 'app.main'>> def test_scicrunch_filter(client): r = client.get('/filter-search/', query_string={'term': 'organ', 'facet': 'heart'}) > assert json.loads(r.data)['numberOfHits'] > 4 E KeyError: 'numberOfHits' tests/test_scicrunch.py:125: KeyError _______________________ test_scicrunch_filter_scaffolds ________________________ client = <FlaskClient <Flask 'app.main'>> def test_scicrunch_filter_scaffolds(client): r = client.get('/filter-search/?facet=scaffolds&term=datasets') > assert json.loads(r.data)['numberOfHits'] > 10 E KeyError: 'numberOfHits' tests/test_scicrunch.py:130: KeyError _________________________ test_scicrunch_basic_search __________________________ client = <FlaskClient <Flask 'app.main'>> def test_scicrunch_basic_search(client): r = client.get('/filter-search/Heart/?facet=All+Species&term=species') > assert json.loads(r.data)['numberOfHits'] > 10 E KeyError: 'numberOfHits' tests/test_scicrunch.py:135: KeyError _________________________ test_scicrunch_image_search __________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_scicrunch_image_search(client): > r = client.get('/multiple_dataset_info/using_multiple_mimetype/?q="*jp2*+OR+*vnd.ome.xml*+OR+*jpx*"') tests/test_scicrunch.py:138: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:645: in get_file_info_from_mimetype return process_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError _________________________ test_scicrunch_boolean_logic _________________________ client = <FlaskClient <Flask 'app.main'>> def test_scicrunch_boolean_logic(client): r = client.get('/filter-search/?facet=All+Species&term=species&facet=male&term=gender&facet=female&term=gender') > assert json.loads(r.data)['numberOfHits'] > 20 E KeyError: 'numberOfHits' tests/test_scicrunch.py:143: KeyError ______________________ test_scicrunch_combined_facet_text ______________________ client = <FlaskClient <Flask 'app.main'>> def test_scicrunch_combined_facet_text(client): r = client.get('/filter-search/heart/?facet=All+Species&term=species&facet=male&term=gender&facet=female&term=gender') > assert json.loads(r.data)['numberOfHits'] > 1 E KeyError: 'numberOfHits' tests/test_scicrunch.py:148: KeyError _____________________________ test_getting_facets ______________________________ client = <FlaskClient <Flask 'app.main'>> def test_getting_facets(client): r = client.get('/get-facets/organ') facet_results = json.loads(r.data) > facets = [facet_result['key'] for facet_result in facet_results] tests/test_scicrunch.py:154: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ .0 = <dict_keyiterator object at 0x7f99084acb30> > facets = [facet_result['key'] for facet_result in facet_results] E TypeError: string indices must be integers tests/test_scicrunch.py:154: TypeError _________________________ test_create_identifier_query _________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_create_identifier_query(client): > r = client.get('/dataset_info/using_object_identifier?identifier=package:e6435710-dd9c-46b7-9dfd-932103469733') tests/test_scicrunch.py:159: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:670: in get_dataset_info_object_identifier return reform_dataset_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError __________________________ test_create_anatomy_query ___________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_create_anatomy_query(client): > r = client.get('/dataset_info/anatomy?identifier=90') tests/test_scicrunch.py:176: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:681: in get_dataset_info_anatomy return reform_anatomy_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ____________________________ test_response_version _____________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_response_version(client): # Testing with dataset 44 identifier = "44" doi = "10.26275/duz8-mq3n" > run_doi_test = check_doi_status(client, identifier, doi) tests/test_scicrunch.py:206: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ tests/test_scicrunch.py:53: in check_doi_status r = client.get('/dataset_info/using_pennsieve_identifier', query_string={'identifier': dataset_id}) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:689: in get_dataset_info_pennsieve_identifier return reform_dataset_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ____________________________ test_response_abi_plot ____________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_response_abi_plot(client): # Testing abi-plot with dataset 212 identifier = "212" doi = "10.26275/lok5-wje6" > run_doi_test = check_doi_status(client, identifier, doi) tests/test_scicrunch.py:221: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ tests/test_scicrunch.py:53: in check_doi_status r = client.get('/dataset_info/using_pennsieve_identifier', query_string={'identifier': dataset_id}) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:689: in get_dataset_info_pennsieve_identifier return reform_dataset_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError __________________________ test_response_abi_scaffold __________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_response_abi_scaffold(client): # Testing abi-scaffold with dataset 76 identifier = "76" doi = "10.26275/jarb-s8jw" > run_doi_test = check_doi_status(client, identifier, doi) tests/test_scicrunch.py:255: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ tests/test_scicrunch.py:53: in check_doi_status r = client.get('/dataset_info/using_pennsieve_identifier', query_string={'identifier': dataset_id}) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:689: in get_dataset_info_pennsieve_identifier return reform_dataset_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ______________________ test_response_sample_subject_size _______________________ client = <FlaskClient <Flask 'app.main'>> def test_response_sample_subject_size(client): # Only filter search returns the sample and subjectSuze r = client.get('/filter-search/?facet=liver&term=organ') data = r.data.decode('utf-8') json_data = json.loads(data) print(json_data) > assert len(json_data['results']) == 1 E KeyError: 'results' tests/test_scicrunch.py:315: KeyError ----------------------------- Captured stdout call ----------------------------- {'error': 'JSONDecodeError', 'message': 'Could not parse SciCrunch output, please try again later'} _________________________ test_raw_response_structure __________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_raw_response_structure(client): # 10.26275/zdxd-84xz # 10.26275/duz8-mq3n query = create_query_string("computational") > data = dataset_search(query) tests/test_scicrunch.py:428: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError _________________________ test_get_body_scaffold_info __________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_get_body_scaffold_info(client): # Test if we get a shorter list of uberons with species specified > r = client.get('/get_body_scaffold_info/human') tests/test_scicrunch.py:458: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:1185: in get_body_scaffold_info result = process_get_first_scaffold_info(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError _____________________________ test_getting_curies ______________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: @app.route("/get-organ-curies/") def get_available_uberonids(): species = request.args.getlist('species') requestBody = create_request_body_for_curies(species) result = {} try: response = requests.post( f'{Config.SCI_CRUNCH_HOST}/_search?api_key={Config.KNOWLEDGEBASE_KEY}', json=requestBody) > result = reform_curies_results(response.json()) app/main.py:2187: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_getting_curies(client): # Test if we get a shorter list of uberons with species specified > r = client.get('/get-organ-curies/') tests/test_scicrunch.py:467: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:2189: in get_available_uberonids logging.error("Failed getting Uberon IDs", ex) /usr/lib/python3.10/logging/__init__.py:2105: in error root.error(msg, *args, **kwargs) /usr/lib/python3.10/logging/__init__.py:1506: in error self._log(ERROR, msg, args, **kwargs) /usr/lib/python3.10/logging/__init__.py:1624: in _log self.handle(record) /usr/lib/python3.10/logging/__init__.py:1634: in handle self.callHandlers(record) /usr/lib/python3.10/logging/__init__.py:1696: in callHandlers hdlr.handle(record) /usr/lib/python3.10/logging/__init__.py:968: in handle self.emit(record) ../../../python3.10.venv/lib/python3.10/site-packages/_pytest/logging.py:384: in emit super().emit(record) /usr/lib/python3.10/logging/__init__.py:1108: in emit self.handleError(record) /usr/lib/python3.10/logging/__init__.py:1100: in emit msg = self.format(record) /usr/lib/python3.10/logging/__init__.py:943: in format return fmt.format(record) ../../../python3.10.venv/lib/python3.10/site-packages/_pytest/logging.py:137: in format return super().format(record) /usr/lib/python3.10/logging/__init__.py:678: in format record.message = record.getMessage() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <LogRecord: root, 40, /home/cmiss/Jenkins/workspace/SPARC-API-DEV/app/main.py, 2189, "Failed getting Uberon IDs"> def getMessage(self): """ Return the message for this LogRecord. Return the message for this LogRecord after merging any user-supplied arguments with the message. """ msg = str(self.msg) if self.args: > msg = msg % self.args E TypeError: not all arguments converted during string formatting /usr/lib/python3.10/logging/__init__.py:368: TypeError ____________________________ test_get_related_terms ____________________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: query = 'UBERON:0002084' @app.route("/get-related-terms/<query>") def get_related_terms(query): payload = { 'direction': request.args.get('direction', default='OUTGOING'), 'relationshipType': request.args.get('relationshipType', default='BFO:0000050'), 'entail': request.args.get('entail', default='true'), 'api_key': Config.KNOWLEDGEBASE_KEY } result = {} try: response = requests.get( f'{Config.SCI_CRUNCH_SCIGRAPH_HOST}/graph/neighbors/{query}', params=payload) > result = reform_related_terms(response.json()) app/main.py:2214: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_get_related_terms(client): # Test if we can get the uberon term of heart using the uberon term # of left ventricle > r = client.get('/get-related-terms/UBERON:0002084') tests/test_scicrunch.py:484: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:2216: in get_related_terms logging.error(f"Failed getting related terms with payload {payload}", ex) /usr/lib/python3.10/logging/__init__.py:2105: in error root.error(msg, *args, **kwargs) /usr/lib/python3.10/logging/__init__.py:1506: in error self._log(ERROR, msg, args, **kwargs) /usr/lib/python3.10/logging/__init__.py:1624: in _log self.handle(record) /usr/lib/python3.10/logging/__init__.py:1634: in handle self.callHandlers(record) /usr/lib/python3.10/logging/__init__.py:1696: in callHandlers hdlr.handle(record) /usr/lib/python3.10/logging/__init__.py:968: in handle self.emit(record) ../../../python3.10.venv/lib/python3.10/site-packages/_pytest/logging.py:384: in emit super().emit(record) /usr/lib/python3.10/logging/__init__.py:1108: in emit self.handleError(record) /usr/lib/python3.10/logging/__init__.py:1100: in emit msg = self.format(record) /usr/lib/python3.10/logging/__init__.py:943: in format return fmt.format(record) ../../../python3.10.venv/lib/python3.10/site-packages/_pytest/logging.py:137: in format return super().format(record) /usr/lib/python3.10/logging/__init__.py:678: in format record.message = record.getMessage() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <LogRecord: root, 40, /home/cmiss/Jenkins/workspace/SPARC-API-DEV/app/main.py, 2216, "Failed getting related terms wit...ion': 'OUTGOING', 'relationshipType': 'BFO:0000050', 'entail': 'true', 'api_key': 'xBOrIfnZTvJQtobGo8XHRvThdMYGTxtf'}"> def getMessage(self): """ Return the message for this LogRecord. Return the message for this LogRecord after merging any user-supplied arguments with the message. """ msg = str(self.msg) if self.args: > msg = msg % self.args E TypeError: not all arguments converted during string formatting /usr/lib/python3.10/logging/__init__.py:368: TypeError _____________________________ test_scaffold_files ______________________________ client = <FlaskClient <Flask 'app.main'>> def test_scaffold_files(client): r = client.get('/filter-search/?size=30') results = json.loads(r.data) > assert results['numberOfHits'] > 0 E KeyError: 'numberOfHits' tests/test_scicrunch.py:500: KeyError _____________________ test_finding_contextual_information ______________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_finding_contextual_information(client): > r = client.get('/dataset_info/using_multiple_discoverIds/?discoverIds=76') tests/test_scicrunch.py:514: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:654: in get_dataset_info_discoverIds return process_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError ____________________ test_undefined_version_dataset_search _____________________ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: > return complexjson.loads(self.text, **kwargs) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:971: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/lib/python3.10/json/__init__.py:346: in loads return _default_decoder.decode(s) /usr/lib/python3.10/json/decoder.py:337: in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <json.decoder.JSONDecoder object at 0x7f991261dcf0>, s = '', idx = 0 def raw_decode(self, s, idx=0): """Decode a JSON document from ``s`` (a ``str`` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in ``s`` where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. """ try: obj, end = self.scan_once(s, idx) except StopIteration as err: > raise JSONDecodeError("Expecting value", s, err.value) from None E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) /usr/lib/python3.10/json/decoder.py:355: JSONDecodeError During handling of the above exception, another exception occurred: client = <FlaskClient <Flask 'app.main'>> def test_undefined_version_dataset_search(client): # Testing with dataset 17 which is not versioned identifier = "17" doi = "10.26275/mlua-o9oj" > r = client.get('/dataset_info/using_doi', query_string={'doi': doi}) tests/test_scicrunch.py:525: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1029: in get return self.open(*args, **kw) ../../../python3.10.venv/lib/python3.10/site-packages/flask/testing.py:222: in open return Client.open( ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:993: in open response = self.run_wsgi_app(environ.copy(), buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:884: in run_wsgi_app rv = run_wsgi_app(self.application, environ, buffered=buffered) ../../../python3.10.venv/lib/python3.10/site-packages/werkzeug/test.py:1119: in run_wsgi_app app_rv = app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2463: in __call__ return self.wsgi_app(environ, start_response) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2449: in wsgi_app response = self.handle_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1866: in handle_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:2446: in wsgi_app response = self.full_dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1951: in full_dispatch_request rv = self.handle_user_exception(e) ../../../python3.10.venv/lib/python3.10/site-packages/flask_cors/extension.py:161: in wrapped_function return cors_after_request(app.make_response(f(*args, **kwargs))) ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1820: in handle_user_exception reraise(exc_type, exc_value, tb) ../../../python3.10.venv/lib/python3.10/site-packages/flask/_compat.py:39: in reraise raise value ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1949: in full_dispatch_request rv = self.dispatch_request() ../../../python3.10.venv/lib/python3.10/site-packages/flask/app.py:1935: in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) app/main.py:624: in get_dataset_info_doi return reform_dataset_results(dataset_search(query)) app/main.py:758: in dataset_search return response.json() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <Response [200]>, kwargs = {} def json(self, **kwargs): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. :raises requests.exceptions.JSONDecodeError: If the response body does not contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass except JSONDecodeError as e: raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) try: return complexjson.loads(self.text, **kwargs) except JSONDecodeError as e: # Catch JSON-related errors and raise as requests.JSONDecodeError # This aliases json.JSONDecodeError and simplejson.JSONDecodeError > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ../../../python3.10.venv/lib/python3.10/site-packages/requests/models.py:975: JSONDecodeError =============================== warnings summary =============================== scripts/monthly_db.py:9 /home/cmiss/Jenkins/workspace/SPARC-API-DEV/scripts/monthly_db.py:9: MovedIn20Warning: The ``declarative_base()`` function is now available as sqlalchemy.orm.declarative_base(). (deprecated since: 2.0) (Background on SQLAlchemy 2.0 at: https://sqlalche.me/e/b8d9) base = declarative_base() ../../../python3.10.venv/lib/python3.10/site-packages/apscheduler/__init__.py:1 /home/cmiss/python3.10.venv/lib/python3.10/site-packages/apscheduler/__init__.py:1: DeprecationWarning: pkg_resources is deprecated as an API. See https://setuptools.pypa.io/en/latest/pkg_resources.html from pkg_resources import get_distribution, DistributionNotFound ../../../python3.10.venv/lib/python3.10/site-packages/marshmallow/__init__.py:17 /home/cmiss/python3.10.venv/lib/python3.10/site-packages/marshmallow/__init__.py:17: DeprecationWarning: distutils Version classes are deprecated. Use packaging.version instead. __version_info__ = tuple(LooseVersion(__version__).version) ../../../python3.10.venv/lib/python3.10/site-packages/flask_marshmallow/__init__.py:34 /home/cmiss/python3.10.venv/lib/python3.10/site-packages/flask_marshmallow/__init__.py:34: DeprecationWarning: distutils Version classes are deprecated. Use packaging.version instead. __version_info__ = tuple(LooseVersion(__version__).version) ../../../python3.10.venv/lib/python3.10/site-packages/pennsieve/cache/cache_segment_pb2.py:19 /home/cmiss/python3.10.venv/lib/python3.10/site-packages/pennsieve/cache/cache_segment_pb2.py:19: DeprecationWarning: Call to deprecated create function FileDescriptor(). Note: Create unlinked descriptors is going to go away. Please use get/find descriptors from generated code or query the descriptor_pool. DESCRIPTOR = _descriptor.FileDescriptor( ../../../python3.10.venv/lib/python3.10/site-packages/pennsieve/cache/cache_segment_pb2.py:36 /home/cmiss/python3.10.venv/lib/python3.10/site-packages/pennsieve/cache/cache_segment_pb2.py:36: DeprecationWarning: Call to deprecated create function FieldDescriptor(). Note: Create unlinked descriptors is going to go away. Please use get/find descriptors from generated code or query the descriptor_pool. _descriptor.FieldDescriptor( ../../../python3.10.venv/lib/python3.10/site-packages/pennsieve/cache/cache_segment_pb2.py:53 /home/cmiss/python3.10.venv/lib/python3.10/site-packages/pennsieve/cache/cache_segment_pb2.py:53: DeprecationWarning: Call to deprecated create function FieldDescriptor(). Note: Create unlinked descriptors is going to go away. Please use get/find descriptors from generated code or query the descriptor_pool. _descriptor.FieldDescriptor( ../../../python3.10.venv/lib/python3.10/site-packages/pennsieve/cache/cache_segment_pb2.py:70 /home/cmiss/python3.10.venv/lib/python3.10/site-packages/pennsieve/cache/cache_segment_pb2.py:70: DeprecationWarning: Call to deprecated create function FieldDescriptor(). Note: Create unlinked descriptors is going to go away. Please use get/find descriptors from generated code or query the descriptor_pool. _descriptor.FieldDescriptor( ../../../python3.10.venv/lib/python3.10/site-packages/pennsieve/cache/cache_segment_pb2.py:29 /home/cmiss/python3.10.venv/lib/python3.10/site-packages/pennsieve/cache/cache_segment_pb2.py:29: DeprecationWarning: Call to deprecated create function Descriptor(). Note: Create unlinked descriptors is going to go away. Please use get/find descriptors from generated code or query the descriptor_pool. _CACHESEGMENT = _descriptor.Descriptor( app/dbtable.py:12 /home/cmiss/Jenkins/workspace/SPARC-API-DEV/app/dbtable.py:12: MovedIn20Warning: The ``declarative_base()`` function is now available as sqlalchemy.orm.declarative_base(). (deprecated since: 2.0) (Background on SQLAlchemy 2.0 at: https://sqlalche.me/e/b8d9) base = declarative_base() ../../../python3.10.venv/lib/python3.10/site-packages/urllib3/util/ssl_.py:281: 3 warnings tests/test_api.py: 33 warnings tests/test_biolucida.py: 13 warnings tests/test_dataset_info.py: 6 warnings tests/test_monthly_stats.py: 11 warnings tests/test_osparc.py: 17 warnings tests/test_plot.py: 1 warning tests/test_pmr.py: 4 warnings tests/test_scicrunch.py: 28 warnings tests/test_thumbnails.py: 2 warnings /home/cmiss/python3.10.venv/lib/python3.10/site-packages/urllib3/util/ssl_.py:281: DeprecationWarning: ssl.PROTOCOL_TLS is deprecated context = SSLContext(ssl_version or PROTOCOL_TLS) ../../../python3.10.venv/lib/python3.10/site-packages/urllib3/connection.py:512: 3 warnings tests/test_api.py: 36 warnings tests/test_biolucida.py: 13 warnings tests/test_dataset_info.py: 7 warnings tests/test_monthly_stats.py: 14 warnings tests/test_osparc.py: 17 warnings tests/test_plot.py: 1 warning tests/test_pmr.py: 4 warnings tests/test_scicrunch.py: 28 warnings tests/test_segmentation_info.py: 1 warning tests/test_thumbnails.py: 2 warnings /home/cmiss/python3.10.venv/lib/python3.10/site-packages/urllib3/connection.py:512: DeprecationWarning: ssl.match_hostname() is deprecated match_hostname(cert, asserted_hostname) ../../../python3.10.venv/lib/python3.10/site-packages/nose/importer.py:12 /home/cmiss/python3.10.venv/lib/python3.10/site-packages/nose/importer.py:12: DeprecationWarning: the imp module is deprecated in favour of importlib and slated for removal in Python 3.12; see the module's documentation for alternative uses from imp import find_module, load_module, acquire_lock, release_lock tests/test_health.py::test_request_response /home/cmiss/Jenkins/workspace/SPARC-API-DEV/tests/test_health.py:13: DeprecationWarning: Please use assertEqual instead. assert_equals("healthy", json_response.get("status")) -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html =========================== short test summary info ============================ FAILED tests/test_api.py::test_non_existing_simulation_ui_file - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_api.py::test_simulation_ui_file_old_s3_bucket - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_api.py::test_simulation_ui_file_new_s3_bucket - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_dataset_info.py::test_current_doi_list - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_dataset_info.py::test_generic_mouse_colon_dataset_search - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_dataset_info.py::test_complex_title_dataset_search - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_dataset_info.py::test_title_plot_annotation_dataset_search - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_dataset_info.py::test_object_identifier_dataset_search - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_dataset_info.py::test_pennsieve_identifier_dataset_search - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_plot.py::test_abi_plot - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_scicrunch_keys - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_scicrunch_versions_are_supported - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_scicrunch_dataset_doi - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_scicrunch_multiple_dataset_doi - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_scicrunch_multiple_dataset_ids - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_scicrunch_search - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_scicrunch_all_data - KeyError: 'numberOfHits' FAILED tests/test_scicrunch.py::test_scicrunch_filter - KeyError: 'numberOfHits' FAILED tests/test_scicrunch.py::test_scicrunch_filter_scaffolds - KeyError: 'numberOfHits' FAILED tests/test_scicrunch.py::test_scicrunch_basic_search - KeyError: 'numberOfHits' FAILED tests/test_scicrunch.py::test_scicrunch_image_search - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_scicrunch_boolean_logic - KeyError: 'numberOfHits' FAILED tests/test_scicrunch.py::test_scicrunch_combined_facet_text - KeyError: 'numberOfHits' FAILED tests/test_scicrunch.py::test_getting_facets - TypeError: string indices must be integers FAILED tests/test_scicrunch.py::test_create_identifier_query - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_create_anatomy_query - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_response_version - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_response_abi_plot - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_response_abi_scaffold - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_response_sample_subject_size - KeyError: 'results' FAILED tests/test_scicrunch.py::test_raw_response_structure - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_get_body_scaffold_info - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_getting_curies - TypeError: not all arguments converted during string formatting FAILED tests/test_scicrunch.py::test_get_related_terms - TypeError: not all arguments converted during string formatting FAILED tests/test_scicrunch.py::test_scaffold_files - KeyError: 'numberOfHits' FAILED tests/test_scicrunch.py::test_finding_contextual_information - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) FAILED tests/test_scicrunch.py::test_undefined_version_dataset_search - requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) ====== 37 failed, 82 passed, 3 skipped, 256 warnings in 241.96s (0:04:01) ====== Build step 'Execute shell' marked build as failure [Slack Notifications] found #1307 as previous completed, non-aborted build [Slack Notifications] will send OnEveryFailureNotification because build matches and user preferences allow it Finished: FAILURE