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

gh-132054: Add application/yaml to mimetypes #132056

Open
wants to merge 4 commits into
base: main
Choose a base branch
from

Conversation

Kristinita
Copy link

@Kristinita Kristinita commented Apr 3, 2025

@Kristinita Kristinita requested a review from a team as a code owner April 3, 2025 17:43
Copy link

cpython-cla-bot bot commented Apr 3, 2025

All commit authors signed the Contributor License Agreement.
CLA signed

@AA-Turner AA-Turner changed the title gh-132054 Add application/yaml to mimetypes gh-132054: Add application/yaml to mimetypes Apr 3, 2025
@Kristinita Kristinita requested review from JelleZijlstra, AlexWaygood and a team as code owners April 3, 2025 18:40
@brianschubert
Copy link
Contributor

@Kristinita I think you accidentally included some unrelated changes in your last push

@Kristinita
Copy link
Author

Kristinita commented Apr 3, 2025

Type: Reply 💬

@brianschubert, I’m sorry, I made a mistake in the test file and create the new commit that fix tests. I can’t push my changes to GitHub, so I run git fetch, git rebase and then push changes to GitHub.

I can close this pull request, update my CPython fork and send a new pull request. Or should I do something else? I can’t find instructions for this case in Python Developer’s Guide.

I apologize for the concern.

Thanks.

@brianschubert
Copy link
Contributor

brianschubert commented Apr 3, 2025

No worries! And no need to open a new PR. You can undo the extra changes by running git restore -s HEAD~1 ./ (which will reset your working tree to what it was before the commit), then remake the intended change to test_mimetypes.py and create a new commit.

@AA-Turner
Copy link
Member

@Kristinita please read our AI policy.

A

@Kristinita
Copy link
Author

Kristinita commented Apr 3, 2025

Type: Fixed ✔️

@brianschubert , done. All checks have passed now.

Thanks.

@hugovk
Copy link
Member

hugovk commented Apr 3, 2025

Please could you add it to What's New?

https://docs.python.org/3.14/whatsnew/3.14.html#mimetypes

And add a test for .yml?

@Kristinita
Copy link
Author

Type: Question

1. Question

And add a test for .yml?

@hugovk, what is the preferred format for tests for non-preferred extensions like .yml? I was looking for the answer to this in previous pull requests that add new media types, but I can’t find a conventional method.

2. Missing tests

Currently, the file test_mimetypes.py in many cases contains tests solely for preferred extensions. Examples:

  1. For audio/mpeg media type: test_mimetypes.py has the test for the .mp3 preferred extension, but not for the non-preferred extension .mp2.
  2. For video/mpeg media type: test_mimetypes.py has the test for the .mpeg preferred extension, but not for non-preferred extensions .m1v, .mpa, .mpe and .mpg.

3. Existing test for non-preferred extensions

Should I create a test like the test for the text/plain media type?

all = self.db.guess_all_extensions('text/plain', strict=True)
self.assertTrue(set(all) >= {'.bat', '.c', '.h', '.ksh', '.pl', '.txt'})
self.assertEqual(len(set(all)), len(all)) # no duplicates

4. Simpler adding tests

Possibly, it would be nice if adding tests for non-preferred extension will be simpler. For example, the file test_mimetypes.py could have a function like test_non_preferred_extensions to which users will be able to add all non-preferred extensions for media types. Example:

("application/yaml", ".yml"),
("audio/mpeg", ".mp2"),
("video/mpeg", ".m1v"),
("video/mpeg", ".mpa"),
("video/mpeg", ".mpe"),
("video/mpeg", ".mpg")

Thanks.

@hugovk
Copy link
Member

hugovk commented Apr 4, 2025

We could add some a test case to check the output of guess_file_type is as expected, for example:

    def test_guess_file_type(self):
        def check_file_type():
            for mime_type, ext in (
                ("application/yaml", ".yaml"),
                ("application/yaml", ".yml"),
            ):
                with self.subTest(mime_type=mime_type, ext=ext):
                    result, _ = mimetypes.guess_file_type(f"filename{ext}")
                    self.assertEqual(result, mime_type)

        check_file_type()
        mimetypes.init()
        check_file_type()

No need to exhaustively fill lots of other preferred+optional extensions, but we could include a few more, such as the audio/mpeg and video/mpeg ones mentioned.

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.

4 participants