Skip to content

Start testing with 3.14 alphas#1189

Merged
ericwb merged 6 commits intoPyCQA:mainfrom
ericwb:py3.13
Jan 7, 2025
Merged

Start testing with 3.14 alphas#1189
ericwb merged 6 commits intoPyCQA:mainfrom
ericwb:py3.13

Conversation

@ericwb
Copy link
Member

@ericwb ericwb commented Oct 9, 2024

This change starts testing against the alpha versions of Python 3.14 to catch potential problems early before it is officially released.

Python 3.14 has dropped the deprecated use of ast.Bytes, ast.Ellipsis, ast.NameConstant, ast.Num, ast.Str. They are replaced with ast.Constant and Node.value is used to get the value instead of the previous attributes like Node.s.

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

This also has the potential to break 3rd party plugins that were checking on Str or Num, etc. As a result, Bandit keeps the validity of checking on those non-existent ast types.

These changes did break a quite a few plugins that were directly accessing ast classes to determine a result, but were fixed as part of this PR.

@ericwb ericwb force-pushed the py3.13 branch 2 times, most recently from ea5133f to f1372d9 Compare October 9, 2024 01:53
This change updates the unit testing to use the official
Python 3.13 released yesterday (Oct 7). It also starts
testing against the alpha versions of Python 3.14 to
catch potential problems early before it is officially released.

Signed-off-by: Eric Brown <eric_wade_brown@yahoo.com>
@ericwb
Copy link
Member Author

ericwb commented Oct 10, 2024

Seems GitHub hasn't released builds of 3.14 for windows and macos yet, just linux.

https://github.com/actions/python-versions/releases/tag/3.14.0-alpha.0-10616720958

Signed-off-by: Eric Brown <eric_wade_brown@yahoo.com>
@ericwb ericwb marked this pull request as ready for review October 16, 2024 23:10
@ericwb ericwb changed the title Test with official 3.13 and 3.14 alphas Start testing with 3.14 alphas Oct 16, 2024
@ericwb ericwb merged commit 13d3406 into PyCQA:main Jan 7, 2025
15 checks passed
@ericwb ericwb deleted the py3.13 branch January 7, 2025 15:12
ericwb added a commit that referenced this pull request Jan 12, 2025
ericwb added a commit that referenced this pull request Jan 12, 2025
Revert "Start testing with 3.14 alphas (#1189)"

This reverts commit 13d3406.
ericwb added a commit to ericwb/bandit that referenced this pull request Nov 10, 2025
This is a re-opening of PR PyCQA#1189 and revert of revert PyCQA#1217.
PR PyCQA#1189 caused issue PyCQA#1216 which must be fixed as part of
this PR.

This change starts testing against Python 3.14 now that is has
been officially released.

Python 3.14 has dropped the deprecated use of ast.Bytes,
ast.Ellipsis, ast.NameConstant, ast.Num, ast.Str. They are
replaced with ast.Constant and Node.value is used to get the
value instead of the previous attributes like Node.s.

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

This also has the potential to break 3rd party plugins that
were checking on Str or Num, etc. As a result, Bandit keeps
the validity of checking on those non-existent ast types.

These changes did break a quite a few plugins that were
directly accessing ast classes to determine a result, but
were fixed as part of this PR.

Signed-off-by: Eric Brown <eric_wade_brown@yahoo.com>
@ericwb ericwb mentioned this pull request Nov 10, 2025
ericwb added a commit that referenced this pull request Nov 11, 2025
* Support of Python 3.14

This is a re-opening of PR #1189 and revert of revert #1217.
PR #1189 caused issue #1216 which must be fixed as part of
this PR.

This change starts testing against Python 3.14 now that is has
been officially released.

Python 3.14 has dropped the deprecated use of ast.Bytes,
ast.Ellipsis, ast.NameConstant, ast.Num, ast.Str. They are
replaced with ast.Constant and Node.value is used to get the
value instead of the previous attributes like Node.s.

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

This also has the potential to break 3rd party plugins that
were checking on Str or Num, etc. As a result, Bandit keeps
the validity of checking on those non-existent ast types.

These changes did break a quite a few plugins that were
directly accessing ast classes to determine a result, but
were fixed as part of this PR.

Signed-off-by: Eric Brown <eric_wade_brown@yahoo.com>

* Add 3.14 classifier

Signed-off-by: Eric Brown <eric_wade_brown@yahoo.com>

* Add test case

Signed-off-by: Eric Brown <eric_wade_brown@yahoo.com>

* Check if value.value is str

Signed-off-by: Eric Brown <eric_wade_brown@yahoo.com>

* Incorrect comment

Signed-off-by: Eric Brown <eric_wade_brown@yahoo.com>

* Fix up injection_sql.py

Signed-off-by: Eric Brown <eric_wade_brown@yahoo.com>

* More checking on Constant.value

Signed-off-by: Eric Brown <eric_wade_brown@yahoo.com>

* Final Constant value checks

Signed-off-by: Eric Brown <eric_wade_brown@yahoo.com>

---------

Signed-off-by: Eric Brown <eric_wade_brown@yahoo.com>
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.

2 participants