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

Core, CI: Add Python 3.12 support #3290

Merged
merged 10 commits into from
Sep 2, 2024
5 changes: 3 additions & 2 deletions .github/workflows/unittests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -37,12 +37,13 @@ jobs:
- {version: '3.9'}
- {version: '3.10'}
- {version: '3.11'}
- {version: '3.12'}
include:
- python: {version: '3.8'} # win7 compat
os: windows-latest
- python: {version: '3.11'} # current
- python: {version: '3.12'} # current
os: windows-latest
- python: {version: '3.11'} # current
- python: {version: '3.12'} # current
os: macos-latest

steps:
Expand Down
6 changes: 3 additions & 3 deletions ModuleUpdate.py
Original file line number Diff line number Diff line change
Expand Up @@ -75,13 +75,13 @@ def update(yes: bool = False, force: bool = False) -> None:
if not update_ran:
update_ran = True

install_pkg_resources(yes=yes)
import pkg_resources

if force:
update_command()
return

install_pkg_resources(yes=yes)
import pkg_resources

prev = "" # if a line ends in \ we store here and merge later
for req_file in requirements_files:
path = os.path.join(os.path.dirname(sys.argv[0]), req_file)
Expand Down
3 changes: 2 additions & 1 deletion WebHostLib/requirements.txt
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
flask>=3.0.0
pony>=0.7.17
pony>=0.7.17; python_version < '3.12'
pony @ git+https://github.com/black-sliver/pony@5a37f6d59b6433d17d6d56b54f3726190e98c98f#0.7.17; python_version >= '3.12'
waitress>=2.1.2
Flask-Caching>=2.1.0
Flask-Compress>=1.14
Expand Down
4 changes: 2 additions & 2 deletions docs/running from source.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ use that version. These steps are for developers or platforms without compiled r

What you'll need:
* [Python 3.8.7 or newer](https://www.python.org/downloads/), not the Windows Store version
* **Python 3.12 is currently unsupported**
* Python 3.12 is currently the newest supported version
black-sliver marked this conversation as resolved.
Show resolved Hide resolved
black-sliver marked this conversation as resolved.
Show resolved Hide resolved
* pip: included in downloads from python.org, separate in many Linux distributions
* Matching C compiler
* possibly optional, read operating system specific sections
Expand All @@ -31,7 +31,7 @@ After this, you should be able to run the programs.

Recommended steps
* Download and install a "Windows installer (64-bit)" from the [Python download page](https://www.python.org/downloads)
* **Python 3.12 is currently unsupported**
* [read above](#General) which versions are supported

* **Optional**: Download and install Visual Studio Build Tools from
[Visual Studio Build Tools](https://visualstudio.microsoft.com/visual-cpp-build-tools/).
Expand Down
14 changes: 7 additions & 7 deletions worlds/stardew_valley/test/TestItems.py
Original file line number Diff line number Diff line change
Expand Up @@ -93,42 +93,42 @@ def test_minsanity_1_metal_detector(self):
options = get_minsanity_options()
multiworld = setup_solo_multiworld(options)
items = [item.name for item in multiworld.get_items() if item.name == Wallet.metal_detector]
self.assertEquals(len(items), 1)
self.assertEqual(len(items), 1)

def test_museumsanity_2_metal_detector(self):
options = get_minsanity_options().copy()
options[Museumsanity.internal_name] = Museumsanity.option_all
multiworld = setup_solo_multiworld(options)
items = [item.name for item in multiworld.get_items() if item.name == Wallet.metal_detector]
self.assertEquals(len(items), 2)
self.assertEqual(len(items), 2)

def test_shipsanity_full_shipment_1_metal_detector(self):
options = get_minsanity_options().copy()
options[Shipsanity.internal_name] = Shipsanity.option_full_shipment
multiworld = setup_solo_multiworld(options)
items = [item.name for item in multiworld.get_items() if item.name == Wallet.metal_detector]
self.assertEquals(len(items), 1)
self.assertEqual(len(items), 1)

def test_shipsanity_everything_2_metal_detector(self):
options = get_minsanity_options().copy()
options[Shipsanity.internal_name] = Shipsanity.option_everything
multiworld = setup_solo_multiworld(options)
items = [item.name for item in multiworld.get_items() if item.name == Wallet.metal_detector]
self.assertEquals(len(items), 2)
self.assertEqual(len(items), 2)

def test_complete_collection_2_metal_detector(self):
options = get_minsanity_options().copy()
options[Goal.internal_name] = Goal.option_complete_collection
multiworld = setup_solo_multiworld(options)
items = [item.name for item in multiworld.get_items() if item.name == Wallet.metal_detector]
self.assertEquals(len(items), 2)
self.assertEqual(len(items), 2)

def test_perfection_2_metal_detector(self):
options = get_minsanity_options().copy()
options[Goal.internal_name] = Goal.option_perfection
multiworld = setup_solo_multiworld(options)
items = [item.name for item in multiworld.get_items() if item.name == Wallet.metal_detector]
self.assertEquals(len(items), 2)
self.assertEqual(len(items), 2)

def test_maxsanity_4_metal_detector(self):
options = get_minsanity_options().copy()
Expand All @@ -137,4 +137,4 @@ def test_maxsanity_4_metal_detector(self):
options[Goal.internal_name] = Goal.option_perfection
multiworld = setup_solo_multiworld(options)
items = [item.name for item in multiworld.get_items() if item.name == Wallet.metal_detector]
self.assertEquals(len(items), 4)
self.assertEqual(len(items), 4)
Loading