-
Notifications
You must be signed in to change notification settings - Fork 888
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
Add Python 3.13, remove Python 3.8 and update CI Workflow #3767
base: main
Are you sure you want to change the base?
Conversation
0d868b5
to
c7315aa
Compare
Inner functions such as: def outer(): def inner(): pass Now have an attribute called `__name__`, which will be set to `inner`. Also it seems that there is a `__doc__` attribute that is now standard, and thus we add a pragma nocover to pshell.
c7315aa
to
bc84ac3
Compare
This replaces/supplements #3762 |
Windows support is broken on Py 3.13 |
Are there any further efforts to move to Python 3.13 and in particular to address the various deprecation warnings? Probably somewhat related PR Pylons/webob#475 (issue Pylons/webob#473). |
I recently moved a project to Python 3.13 and back again because dependabot
doesn't support Python 3.13 yet.
Just something to be aware of, but dependabot still doesn't support Python
3.13
dependabot/dependabot-core#10828
…On Sun, 15 Dec 2024 at 12:46, Jens Tröger ***@***.***> wrote:
Are there any further efforts to move to Python 3.13 and in particular to
address the various deprecation warnings?
Probably somewhat related PR Pylons/webob#475
<Pylons/webob#475> (issue Pylons/webob#473
<Pylons/webob#473>).
—
Reply to this email directly, view it on GitHub
<#3767 (comment)>, or
unsubscribe
<https://github.com/notifications/unsubscribe-auth/AAHYWMQ2D42IBZUSHAVPB5T2FS7PBAVCNFSM6AAAAABQVEMRROVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDKNBTGM3TQNBYGE>
.
You are receiving this because you are subscribed to this thread.Message
ID: ***@***.***>
|
Huh, I was not aware of that… that would explain why I have’t seen Dependabot PRs in those repos yet 👍🏼 Independently of that, do you have a timeline for merging this PR? |
@robvdl @jenstroeger Dependabot has 3.13 support by today. Also, I'm not sure what are the plans for this PR but if needed, I can help to get it merge faster by reviewing, testing or splitting it into smaller / focused PRs. |
@ulgens if you want to help, fixing the errors on Windows is the primary thing right now. Splitting the PR into multiple smaller ones won't help, I have done the bare minimum in this PR to add support for Python 3.13, except that on Windows the tests are now broken:
I don't have a Windows environment to test/validate/figure out what needs to be fixed. So this can't be merged until the tests are fixed. |
It looks like it is picking up "tests" as if it was a package, hence the colon edit: actually that is weird, because it is using a src-based layout! it shouldn't think tests is a package at all, because it is outside of the src directory. Something is off here. |
Why wouldn't that be an issue on Linux/macOS too though? |
Exactly, that is why I said "something seems off". One thing I don't understand why Pyramid has both a setup.py + setup.cfg AND a pyproject.toml Normally when I modernise a project the point is to delete the setup.py and replace it with a pyproject.toml, could it be that the fact it has two (setup.py AND pyproject.toml) is confusing things? |
Mixing and matching |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If this fixes windows which ships python 3.13 by default, just tested yesterday morning, we should merge sooner than later.
Thank you for the work on this! I skimmed the changes and nothing jumps out at me.
================================== FAILURES ===================================
__ Test_abspath_from_asset_spec.test_pname_is_None_after_resolve_asset_spec ___
self = <tests.test_asset.Test_abspath_from_asset_spec testMethod=test_pname_is_None_after_resolve_asset_spec>
def test_pname_is_None_after_resolve_asset_spec(self):
result = self._callFUT('/abc', '__main__')
> self.assertEqual(result, '/abc')
E AssertionError: 'D:\\a\\pyramid\\pyramid\\.tox\\py\\Lib\\site-packages\\pytest\\abc' != '/abc'
E - D:\a\pyramid\pyramid\.tox\py\Lib\site-packages\pytest\abc
E + /abc
tests\test_asset.py:61: AssertionError
__________________________ TestCallerPath.test_isabs __________________________
self = <tests.test_path.TestCallerPath testMethod=test_isabs>
def test_isabs(self):
result = self._callFUT('/a/b/c')
> self.assertEqual(result, '/a/b/c')
E AssertionError: 'D:/a/b/c' != '/a/b/c'
E - D:/a/b/c
E ? --
E + /a/b/c
tests\test_path.py:21: AssertionError
_________________ TestPRoutesCommand.test_route_static_views __________________
self = <tests.test_scripts.test_proutes.TestPRoutesCommand testMethod=test_route_static_views>
def test_route_static_views(self):
self = <tests.test_url.Test_static_url testMethod=test_it_abs>
def test_it_abs(self):
request = self._makeRequest()
result = self._callFUT('/foo/bar/abc', request, _app_url='')
self.assertEqual(result, 'static url')
> self.assertEqual(request.path, '/foo/bar/abc')
E AssertionError: 'tests:/foo/bar/abc' != '/foo/bar/abc'
E - tests:/foo/bar/abc
E ? ------
E + /foo/bar/abc
tests\test_url.py:1175: AssertionError
________________________ Test_static_path.test_it_abs _________________________
self = <tests.test_url.Test_static_path testMethod=test_it_abs>
def test_it_abs(self):
request = self._makeRequest()
result = self._callFUT('/foo/bar/abc', request, _anchor='anchor')
self.assertEqual(result, 'static path')
> self.assertEqual(request.path, '/foo/bar/abc')
E AssertionError: 'tests:/foo/bar/abc' != '/foo/bar/abc'
E - tests:/foo/bar/abc
E ? ------
E + /foo/bar/abc
tests\test_url.py:1212: AssertionError
============================== warnings summary ===============================
can we do a follow up to fix the tests or will the package not build with errors?
I have access to a windows machine, I will try running the tests locally today. I wonder if D drive is hard coded or if the test runner picks that because it uses D for checkouts? @digitalresistor thanks again. |
@digitalresistor thoughts? |
I have a Windows 11 Pro machine as well and have some time.
…On Sun, 22 Dec 2024 at 02:29, Russell ***@***.***> wrote:
exclude:
# Temporarily exclude Windows + Python 3.13 due to path handling issues
- os: "windows-latest"
py: "3.13"
@digitalresistor <https://github.com/digitalresistor> thoughts?
—
Reply to this email directly, view it on GitHub
<#3767 (comment)>, or
unsubscribe
<https://github.com/notifications/unsubscribe-auth/AAHYWMUFWMAKM47MRXLK72L2GVUM5AVCNFSM6AAAAABQVEMRROVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDKNJYGEZDGMBSHE>
.
You are receiving this because you were mentioned.Message ID:
***@***.***>
|
No, we will not be skipping Windows because tests are failing on that platform. We need to find out why, since it seems to affect url generation and looks like it would cause issues for people that would want to use Python 3.13 on Windows with Pyramid. Right now people can use Pyramid on Python 3.13 anyway if they want, we don't limit the upper Python version in our wheels/source dist, we just don't officially support it yet and as can be seen from this PR, it's broken on Windows so that's a good reason to not officially support it until we can be reasonably sure that everything is working as intended. |
Thanks for the explaination. |
Takes care of the following things:
Closes #3762 #3761