Skip to content

UAT C1265136990-OB_CLOUD (PACE_OCI_L3M_CHL_NRT) #1240

UAT C1265136990-OB_CLOUD (PACE_OCI_L3M_CHL_NRT)

UAT C1265136990-OB_CLOUD (PACE_OCI_L3M_CHL_NRT) #1240

GitHub Actions / Tested with Harmony failed Jan 21, 2025 in 0s

1 fail in 4m 34s

1 tests  ±0   0 ✅ ±0   4m 34s ⏱️ -2s
1 suites ±0   0 💤 ±0 
1 files   ±0   1 ❌ ±0 

Results for commit 1f90913. ± Comparison against earlier commit 60672bc.

Annotations

Check warning on line 0 in tests.verify_collection

See this annotation in the file changed.

@github-actions github-actions / Tested with Harmony

test_concatenate[C1265136990-OB_CLOUD] (tests.verify_collection) failed

test-results/test_report.xml [took 4m 32s]
Raw output
tenacity.RetryError: RetryError[<Future at 0x7f1f572927a0 state=finished raised HTTPError>]
url = 'https://obdaac-tea.uat.earthdatacloud.nasa.gov/ob-cumulus-uat-public/PACE_OCI.20240726.L3m.DAY.CHL.V2_0.chlor_a.0p1deg.NRT.nc'
local_path = 'PACE_OCI.20240726.L3m.DAY.CHL.V2_0.chlor_a.0p1deg.NRT.nc'
headers = {'Authorization': 'Bearer eyJ0eXAiOiJKV1QiLCJvcmlnaW4iOiJFYXJ0aGRhdGEgTG9naW4iLCJzaWciOiJlZGxqd3RwdWJrZXlfdWF0IiwiYWxn...beJjaBKhl-gvXjLxBPtaCk2P7777DonclMKd413HI-jyiaz5c37cMfsCgU10L977PjAOk1emdrpg1kIeREr7E-CI7jPFq8qqe53WwNZbDHefYeqcFgGFQ'}

    @retry(retry=retry_if_exception_type(requests.RequestException), wait=wait_exponential(min=3, max=60), stop=stop_after_attempt(10))
    def download_file(url, local_path, headers=None):
        try:
            with requests.get(url, stream=True, headers=headers) as response:
                response.raise_for_status()  # Check if the request was successful
                with open(local_path, 'wb') as file:
                    for chunk in response.iter_content(chunk_size=8192):
                        if chunk:  # Filter out keep-alive new chunks
                            file.write(chunk)
                logging.info(f"File downloaded successfully: {local_path}")
        except requests.RequestException as e:
            logging.error(f"Failed to download the file. Exception: {e}")
>           raise e  # Re-raise the exception to trigger the retry

verify_collection.py:183: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
verify_collection.py:175: in download_file
    response.raise_for_status()  # Check if the request was successful
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <Response [403]>

    def raise_for_status(self):
        """Raises :class:`HTTPError`, if one occurred."""
    
        http_error_msg = ""
        if isinstance(self.reason, bytes):
            # We attempt to decode utf-8 first because some servers
            # choose to localize their reason strings. If the string
            # isn't utf-8, we fall back to iso-8859-1 for all other
            # encodings. (See PR #3538)
            try:
                reason = self.reason.decode("utf-8")
            except UnicodeDecodeError:
                reason = self.reason.decode("iso-8859-1")
        else:
            reason = self.reason
    
        if 400 <= self.status_code < 500:
            http_error_msg = (
                f"{self.status_code} Client Error: {reason} for url: {self.url}"
            )
    
        elif 500 <= self.status_code < 600:
            http_error_msg = (
                f"{self.status_code} Server Error: {reason} for url: {self.url}"
            )
    
        if http_error_msg:
>           raise HTTPError(http_error_msg, response=self)
E           requests.exceptions.HTTPError: 403 Client Error: Forbidden for url: https://obdaac-tea.uat.earthdatacloud.nasa.gov/ob-cumulus-uat-public/PACE_OCI.20240726.L3m.DAY.CHL.V2_0.chlor_a.0p1deg.NRT.nc

../../../../.cache/pypoetry/virtualenvs/concise-autotest-tfGktGnJ-py3.10/lib/python3.10/site-packages/requests/models.py:1024: HTTPError

The above exception was the direct cause of the following exception:

collection_concept_id = 'C1265136990-OB_CLOUD'
harmony_env = <Environment.UAT: 3>
bearer_token = 'eyJ0eXAiOiJKV1QiLCJvcmlnaW4iOiJFYXJ0aGRhdGEgTG9naW4iLCJzaWciOiJlZGxqd3RwdWJrZXlfdWF0IiwiYWxnIjoiUlMyNTYifQ.eyJ0eXBlIj...kbeJjaBKhl-gvXjLxBPtaCk2P7777DonclMKd413HI-jyiaz5c37cMfsCgU10L977PjAOk1emdrpg1kIeREr7E-CI7jPFq8qqe53WwNZbDHefYeqcFgGFQ'

    @pytest.mark.timeout(600)
    def test_concatenate(collection_concept_id, harmony_env, bearer_token):
    
        max_results = 2
        harmony_client = harmony.Client(env=harmony_env, token=bearer_token)
        collection = harmony.Collection(id=collection_concept_id)
        latest_granule_ids = get_latest_granules(collection_concept_id, max_results, harmony_env, bearer_token)
    
        if latest_granule_ids is None:
            if harmony_env == harmony.config.Environment.UAT:
                pytest.skip(f"No granules found for UAT collection {collection_concept_id}")
            raise Exception('Bad Request', 'Error: No matching granules found.')
    
        request = harmony.Request(
            collection=collection,
            concatenate=True,
            max_results=max_results,
            granule_id=latest_granule_ids,
            skip_preview=True,
            format="application/x-netcdf4",
        )
    
        request.is_valid()
    
        logging.info("Sending harmony request %s", harmony_client.request_as_url(request))
    
        try:
            job1_id = harmony_client.submit(request)
        except Exception as ex:
            if str(ex) == "('Bad Request', 'Error: No matching granules found.')":
                if harmony_env == harmony.config.Environment.UAT:
                    pytest.skip(f"No granules found for UAT collection {collection_concept_id}")
            raise ex
    
        logging.info(f'\n{job1_id}')
    
        logging.info(harmony_client.status(job1_id))
    
        logging.info('\nWaiting for the job to finish')
    
        results = harmony_client.result_json(job1_id)
    
        logging.info('\nDownloading results:')
    
        futures = harmony_client.download_all(job1_id)
        file_names = [f.result() for f in futures]
        logging.info('\nDone downloading.')
    
        filename = file_names[0]
    
        # Handle time dimension and variables dropping
        merge_dataset = netCDF4.Dataset(filename, 'r')
    
        headers = {
            "Authorization": f"Bearer {bearer_token}"
        }
    
        original_files = merge_dataset.variables['subset_files']
        history_json = json.loads(merge_dataset.history_json)
        assert len(original_files) == max_results
    
        for url in history_json[0].get("derived_from"):
            local_file_name = os.path.basename(url)
>           download_file(url, local_file_name, headers)

verify_collection.py:277: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../../../../.cache/pypoetry/virtualenvs/concise-autotest-tfGktGnJ-py3.10/lib/python3.10/site-packages/tenacity/__init__.py:336: in wrapped_f
    return copy(f, *args, **kw)
../../../../.cache/pypoetry/virtualenvs/concise-autotest-tfGktGnJ-py3.10/lib/python3.10/site-packages/tenacity/__init__.py:475: in __call__
    do = self.iter(retry_state=retry_state)
../../../../.cache/pypoetry/virtualenvs/concise-autotest-tfGktGnJ-py3.10/lib/python3.10/site-packages/tenacity/__init__.py:376: in iter
    result = action(retry_state)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

rs = <RetryCallState 139772338142704: attempt #10; slept for 246.0; last result: failed (HTTPError 403 Client Error: Forbid...obdaac-tea.uat.earthdatacloud.nasa.gov/ob-cumulus-uat-public/PACE_OCI.20240726.L3m.DAY.CHL.V2_0.chlor_a.0p1deg.NRT.nc)>

    def exc_check(rs: "RetryCallState") -> None:
        fut = t.cast(Future, rs.outcome)
        retry_exc = self.retry_error_cls(fut)
        if self.reraise:
            raise retry_exc.reraise()
>       raise retry_exc from fut.exception()
E       tenacity.RetryError: RetryError[<Future at 0x7f1f572927a0 state=finished raised HTTPError>]

../../../../.cache/pypoetry/virtualenvs/concise-autotest-tfGktGnJ-py3.10/lib/python3.10/site-packages/tenacity/__init__.py:419: RetryError
--------------------------------- Captured Log ---------------------------------
INFO     root:verify_collection.py:238 Sending harmony request https://harmony.uat.earthdata.nasa.gov/C1265136990-OB_CLOUD/ogc-api-coverages/1.0.0/collections/parameter_vars/coverage/rangeset?forceAsync=true&granuleId=G1268937712-OB_CLOUD&granuleId=G1268937711-OB_CLOUD&format=application%2Fx-netcdf4&maxResults=2&concatenate=true&skipPreview=true&variable=all
INFO     root:verify_collection.py:248 
e6c7d395-94b9-4a53-bf03-975631db1a16
INFO     root:verify_collection.py:250 {'status': 'running', 'message': 'The job is being processed', 'progress': 0, 'created_at': datetime.datetime(2025, 1, 21, 8, 31, 0, 116000, tzinfo=tzlocal()), 'updated_at': datetime.datetime(2025, 1, 21, 8, 31, 0, 116000, tzinfo=tzlocal()), 'created_at_local': '2025-01-21T08:31:00+00:00', 'updated_at_local': '2025-01-21T08:31:00+00:00', 'request': 'https://harmony.uat.earthdata.nasa.gov/C1265136990-OB_CLOUD/ogc-api-coverages/1.0.0/collections/parameter_vars/coverage/rangeset?forceAsync=true&granuleId=G1268937712-OB_CLOUD%2CG1268937711-OB_CLOUD&format=application%2Fx-netcdf4&maxResults=2&concatenate=true&skipPreview=true&variable=all', 'num_input_granules': 2, 'data_expiration': datetime.datetime(2025, 2, 20, 8, 31, 0, 116000, tzinfo=tzlocal()), 'data_expiration_local': '2025-02-20T08:31:00+00:00'}
INFO     root:verify_collection.py:252 
Waiting for the job to finish
INFO     root:verify_collection.py:256 
Downloading results:
INFO     root:verify_collection.py:260 
Done downloading.
ERROR    root:verify_collection.py:182 Failed to download the file. Exception: 403 Client Error: Forbidden for url: https://obdaac-tea.uat.earthdatacloud.nasa.gov/ob-cumulus-uat-public/PACE_OCI.20240726.L3m.DAY.CHL.V2_0.chlor_a.0p1deg.NRT.nc
ERROR    root:verify_collection.py:182 Failed to download the file. Exception: 403 Client Error: Forbidden for url: https://obdaac-tea.uat.earthdatacloud.nasa.gov/ob-cumulus-uat-public/PACE_OCI.20240726.L3m.DAY.CHL.V2_0.chlor_a.0p1deg.NRT.nc
ERROR    root:verify_collection.py:182 Failed to download the file. Exception: 403 Client Error: Forbidden for url: https://obdaac-tea.uat.earthdatacloud.nasa.gov/ob-cumulus-uat-public/PACE_OCI.20240726.L3m.DAY.CHL.V2_0.chlor_a.0p1deg.NRT.nc
ERROR    root:verify_collection.py:182 Failed to download the file. Exception: 403 Client Error: Forbidden for url: https://obdaac-tea.uat.earthdatacloud.nasa.gov/ob-cumulus-uat-public/PACE_OCI.20240726.L3m.DAY.CHL.V2_0.chlor_a.0p1deg.NRT.nc
ERROR    root:verify_collection.py:182 Failed to download the file. Exception: 403 Client Error: Forbidden for url: https://obdaac-tea.uat.earthdatacloud.nasa.gov/ob-cumulus-uat-public/PACE_OCI.20240726.L3m.DAY.CHL.V2_0.chlor_a.0p1deg.NRT.nc
ERROR    root:verify_collection.py:182 Failed to download the file. Exception: 403 Client Error: Forbidden for url: https://obdaac-tea.uat.earthdatacloud.nasa.gov/ob-cumulus-uat-public/PACE_OCI.20240726.L3m.DAY.CHL.V2_0.chlor_a.0p1deg.NRT.nc
ERROR    root:verify_collection.py:182 Failed to download the file. Exception: 403 Client Error: Forbidden for url: https://obdaac-tea.uat.earthdatacloud.nasa.gov/ob-cumulus-uat-public/PACE_OCI.20240726.L3m.DAY.CHL.V2_0.chlor_a.0p1deg.NRT.nc
ERROR    root:verify_collection.py:182 Failed to download the file. Exception: 403 Client Error: Forbidden for url: https://obdaac-tea.uat.earthdatacloud.nasa.gov/ob-cumulus-uat-public/PACE_OCI.20240726.L3m.DAY.CHL.V2_0.chlor_a.0p1deg.NRT.nc
ERROR    root:verify_collection.py:182 Failed to download the file. Exception: 403 Client Error: Forbidden for url: https://obdaac-tea.uat.earthdatacloud.nasa.gov/ob-cumulus-uat-public/PACE_OCI.20240726.L3m.DAY.CHL.V2_0.chlor_a.0p1deg.NRT.nc
ERROR    root:verify_collection.py:182 Failed to download the file. Exception: 403 Client Error: Forbidden for url: https://obdaac-tea.uat.earthdatacloud.nasa.gov/ob-cumulus-uat-public/PACE_OCI.20240726.L3m.DAY.CHL.V2_0.chlor_a.0p1deg.NRT.nc