Title: Split Up _testsinglephase.c and _testmultiphase.c · Issue #124983 · python/cpython · GitHub
Open Graph Title: Split Up _testsinglephase.c and _testmultiphase.c · Issue #124983 · python/cpython
X Title: Split Up _testsinglephase.c and _testmultiphase.c · Issue #124983 · python/cpython
Description: (low priority) Modules/_testsinglephase.c and Modules/_testmultiphase.c both contain the implementations of multiple modules. We should consider splitting up both files, so each contained module has its own file. Here are several reasons...
Open Graph Description: (low priority) Modules/_testsinglephase.c and Modules/_testmultiphase.c both contain the implementations of multiple modules. We should consider splitting up both files, so each contained module ha...
X Description: (low priority) Modules/_testsinglephase.c and Modules/_testmultiphase.c both contain the implementations of multiple modules. We should consider splitting up both files, so each contained module ha...
Opengraph URL: https://github.com/python/cpython/issues/124983
X: @github
Domain: github.com
{"@context":"https://schema.org","@type":"DiscussionForumPosting","headline":"Split Up _testsinglephase.c and _testmultiphase.c","articleBody":"(low priority)\r\n\r\n`Modules/_testsinglephase.c` and `Modules/_testmultiphase.c` both contain the implementations of multiple modules. We should consider splitting up both files, so each contained module has its own file.\r\n\r\nHere are several reasons why this may be worth doing:\r\n\r\n* testing with a module hidden in another's .so file is awkward and makes those tests harder to understand\r\n* it's easier to accidentally leak C-module global data between modules when they are implemented in the same file\r\n* when adding a new module, it's trickier (less familiar) to implement it in an existing file than in a new file [^1]\r\n\r\n[^1]: However, adding it to an existing file is also simpler in how adding a new file involves tweaking the build. See [the devguide](https://devguide.python.org/developer-workflow/extension-modules/#adding-an-extension-module-to-cpython).\r\n\r\nFurthermore, both files were added to test specific import functionality. As far as I can tell[^2], that never included any need for the multiple-modules-in-one-file approach. However, currently they are the only place where we're testing the feature, regardless of how unintentionally or superficially. [gh-124978](https://github.com/python/cpython/issues/124978) targets fixing that lack of explicit testing, including moving away from `_testsinglephase.c` and `_testmultiphase.c` (e.g. using the dedicated `Modules/_testimportmultiple.c`).\r\n\r\n[^2]: I personally added `Modules/_testsinglephase.c` and @encukou added `_testmultiphase.c`.\r\n\r\nAll that said, splitting up the files is a fairly low priority task. The status quo isn't ideal but it isn't that bad either.\r\n\r\n----\r\n\r\nHere's how I see us taking care of this:\r\n\r\n1. make sure multiple-modules-in-one-file is tested via the dedicated `Modules/_testimportmultiple.c` [^2] (see [gh-124978](https://github.com/python/cpython/issues/124978))\r\n2. create the `Modules/_testsinglephase` directory\r\n3. move each module from `_testsinglephase.c` to its own file (see [the devguide](https://devguide.python.org/developer-workflow/extension-modules/#adding-an-extension-module-to-cpython))\r\n4. update the relevant tests\r\n5. delete `Modules/_testsinglephase.c`\r\n6. repeat steps 2-5 for `Modules/_testmultiphase.c`","author":{"url":"https://github.com/ericsnowcurrently","@type":"Person","name":"ericsnowcurrently"},"datePublished":"2024-10-04T19:47:48.000Z","interactionStatistic":{"@type":"InteractionCounter","interactionType":"https://schema.org/CommentAction","userInteractionCount":2},"url":"https://github.com/124983/cpython/issues/124983"}
| route-pattern | /_view_fragments/issues/show/:user_id/:repository/:id/issue_layout(.:format) |
| route-controller | voltron_issues_fragments |
| route-action | issue_layout |
| fetch-nonce | v2:254e0d66-0c71-dc84-7bb9-4e6e7f94b00f |
| current-catalog-service-hash | 81bb79d38c15960b92d99bca9288a9108c7a47b18f2423d0f6438c5b7bcd2114 |
| request-id | 9F2A:319547:1225CA9:17778DC:696B1577 |
| html-safe-nonce | 2aaa570c728fe96cc24f22790b89fec0c6d5905d7bb5e0fd4f4d1465d684dcf9 |
| visitor-payload | eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI5RjJBOjMxOTU0NzoxMjI1Q0E5OjE3Nzc4REM6Njk2QjE1NzciLCJ2aXNpdG9yX2lkIjoiMTE1MTM5MTAyNzg3NzA0MTgzIiwicmVnaW9uX2VkZ2UiOiJpYWQiLCJyZWdpb25fcmVuZGVyIjoiaWFkIn0= |
| visitor-hmac | 0cc43560037ea17fd4c566bf760d26c6b2f36dd63d0a8310759ad450bf52e5d5 |
| hovercard-subject-tag | issue:2567214650 |
| github-keyboard-shortcuts | repository,issues,copilot |
| google-site-verification | Apib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I |
| octolytics-url | https://collector.github.com/github/collect |
| analytics-location | / |
| fb:app_id | 1401488693436528 |
| apple-itunes-app | app-id=1477376905, app-argument=https://github.com/_view_fragments/issues/show/python/cpython/124983/issue_layout |
| twitter:image | https://opengraph.githubassets.com/cc83c68df5c0de5dc20459786aeea40358dd6beb841e36570074763595e05655/python/cpython/issues/124983 |
| twitter:card | summary_large_image |
| og:image | https://opengraph.githubassets.com/cc83c68df5c0de5dc20459786aeea40358dd6beb841e36570074763595e05655/python/cpython/issues/124983 |
| og:image:alt | (low priority) Modules/_testsinglephase.c and Modules/_testmultiphase.c both contain the implementations of multiple modules. We should consider splitting up both files, so each contained module ha... |
| og:image:width | 1200 |
| og:image:height | 600 |
| og:site_name | GitHub |
| og:type | object |
| og:author:username | ericsnowcurrently |
| hostname | github.com |
| expected-hostname | github.com |
| None | 5f99f7c1d70f01da5b93e5ca90303359738944d8ab470e396496262c66e60b8d |
| turbo-cache-control | no-preview |
| go-import | github.com/python/cpython git https://github.com/python/cpython.git |
| octolytics-dimension-user_id | 1525981 |
| octolytics-dimension-user_login | python |
| octolytics-dimension-repository_id | 81598961 |
| octolytics-dimension-repository_nwo | python/cpython |
| octolytics-dimension-repository_public | true |
| octolytics-dimension-repository_is_fork | false |
| octolytics-dimension-repository_network_root_id | 81598961 |
| octolytics-dimension-repository_network_root_nwo | python/cpython |
| turbo-body-classes | logged-out env-production page-responsive |
| disable-turbo | false |
| browser-stats-url | https://api.github.com/_private/browser/stats |
| browser-errors-url | https://api.github.com/_private/browser/errors |
| release | 82560a55c6b2054555076f46e683151ee28a19bc |
| ui-target | full |
| theme-color | #1e2327 |
| color-scheme | light dark |
Links:
Viewport: width=device-width