Skip to content

Conversation

fatelei
Copy link
Contributor

@fatelei fatelei commented Sep 13, 2025

gh-94808: add test coversage for PyFile_FromFd

What I fixed
• Corrected PyFile_FromFd in Objects/fileobject.c to accept optional NULL strings for encoding, errors, and newline by switching the call format to use optional string specifiers:
• was "isisssO"
• now "isizzzO"
This fixes the bug where passing NULL crashed or misrouted arguments.

Unit tests added
• Extended Lib/test/test_capi/test_file.py:
• Added coverage for default buffering with buffering=-1:
◦ "rb" returns a _io.BufferedReader
◦ "r" returns a _io.TextIOWrapper
• Added a closefd=True behavior test (test_pyfile_fromfd_closefd) that ensures the underlying fd is closed when the returned object is closed (verifies EBADF on a second os.close).

@bedevere-app

This comment was marked as resolved.

@StanFromIreland StanFromIreland changed the title feat: add test coversage for PyFile_FromFd gh-94808: add test coversage for PyFile_FromFd Sep 13, 2025
@StanFromIreland StanFromIreland added tests Tests in the Lib/test dir skip issue labels Sep 13, 2025
Copy link
Member

@serhiy-storchaka serhiy-storchaka left a comment

Choose a reason for hiding this comment

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

A PR that adds tests for existing API should not change that API.

If you want to change PyFile_FromFd(), this should be a separate issue and a separate PR.

finally:
obj.close()

# Default buffering in binary mode (-1): BufferedReader
Copy link
Member

Choose a reason for hiding this comment

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

Why you're checking this here?
There's already tests on BufferedReader and TextIOWrapper below in this function.
Also, it's strange to open fd2 and fd3 under already existing with section for fp.

I need to ask if this PR was generated by LLM?

@fatelei fatelei closed this Oct 19, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

5 participants