Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implementing namespace_exists function on the REST Catalog #1434

Merged
merged 4 commits into from
Dec 17, 2024

Conversation

AhmedNader42
Copy link
Contributor

@AhmedNader42 AhmedNader42 commented Dec 16, 2024

As per #1430 I have added the namespace_exists functionality for REST Catalog.

Here's an example usage similar to the table_exists function of the same class

Screenshot from 2024-12-16 18-29-00

Please review the changes

Comment on lines +684 to +692
def test_namespace_exists_200(rest_mock: Mocker) -> None:
rest_mock.head(
f"{TEST_URI}v1/namespaces/fokko",
status_code=200,
request_headers=TEST_HEADERS,
)
catalog = RestCatalog("rest", uri=TEST_URI, token=TEST_TOKEN)

assert catalog.namespace_exists("fokko")
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nit: the tests here are only verifying against the mock response.
it would be great to test against the actual REST catalog in integration tests.

i noticed that does not exist right now, perhaps we can start a tests/integration/test_rest_catalog.py

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, Good point! I was looking for how to properly test this but didn't find any tests touching the REST Catalog. I thought it was a bit out of scope for the initial issue to add a new integration test flow.

Maybe we should open a new enhancement and add the details to it to implement a new integration test for REST Catalog at tests/integration/test_rest_catalog.py like you mentioned. Thoughts? I'm willing to pick it up

@sungwy
Copy link
Collaborator

sungwy commented Dec 16, 2024

Hi @AhmedNader42 - thank you very much for picking up this issue and getting a working solution up already!

I'm in agreement with @kevinjqliu 's comment, that it would be great to have an integration test as well, and I think it is well within the scope of this PR.

https://github.com/apache/iceberg-python/blob/main/tests/integration/test_reads.py already uses session_catalog in its tests, which is a rest catalog fixture defined in the conftest.py, and I think it would be a good place to add this test case.

@AhmedNader42
Copy link
Contributor Author

Hello @sungwy, Thank you for pointing that out! Sounds good to me. I'll work on adding some test cases for REST Catalog in test_reads.py

Hi @AhmedNader42 - thank you very much for picking up this issue and getting a working solution up already!

I'm in agreement with @kevinjqliu 's comment, that it would be great to have an integration test as well, and I think it is well within the scope of this PR.

https://github.com/apache/iceberg-python/blob/main/tests/integration/test_reads.py already uses session_catalog in its tests, which is a rest catalog fixture defined in the conftest.py, and I think it would be a good place to add this test case.

@AhmedNader42
Copy link
Contributor Author

I created a new file for REST Catalog integration tests tests/integration/test_rest_catalog.py as suggestsed by @kevinjqliu and included some tests covering the namespace_exists functionality. Kindly re-check

Copy link
Contributor

@kevinjqliu kevinjqliu left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM! Thank you for adding the integration test for rest catalog, much needed :)

I double-checked with namespaceExists in the REST spec, everything looks good.
Similar to tableExists, we're including 200 status code as a convenience. I'll see if we can add this to the spec itself

@kevinjqliu
Copy link
Contributor

@AhmedNader42 looks like the RAT check failed. For new files, we need to include the ASF license on top, like

# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.


from pyiceberg.catalog.rest import RestCatalog

TEST_NAMESPACE_IDENTIFIER = "TEST NS"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hmm, I didn't know that spaces are allowed :D

@kevinjqliu
Copy link
Contributor

Thanks for the contribution, @AhmedNader42 !
I created #1439 so that we can add more integration tests for the REST catalog.
I also started this devlist discussion to propose adding 200 status code as a valid response for HEAD requests.

@kevinjqliu kevinjqliu merged commit d8c6c94 into apache:main Dec 17, 2024
7 checks passed
sungwy pushed a commit to sungwy/iceberg-python that referenced this pull request Dec 24, 2024
* - Added the namespace_exists function in the RESTCatalog
- Added the relevant unit tests

* - Removed docstring to match other namespace functions

* - Added integration test for REST Catalog namespace_exists functionality

* - Added ASF license to test_rest_catalog.py to recover from failing test
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants