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

Static type checking / problem annotation / improvements / refactoring #152

Closed
wants to merge 21 commits into from

Conversation

Root-Core
Copy link
Contributor

@Root-Core Root-Core commented Oct 17, 2024

This PR enables static type checking and annotation of CI issues on GitHub.

It has not been tested much though, so I am opening it as a draft PR.
I'm also not sure if the relative imports will cause problems.
Feedback and testing welcome.

  • Fixed all type errors
  • Added enums / type aliases
  • Added docstrings
  • Removed some ruff rule exceptions
  • Use pathlib in util.py and gamefixes
  • Refactoring of some gamefixes
  • Added some functions to util.py
    • create_dos_device()
    • patch_conf_value()
    • patch_voodoo_conf()
    • get_path_syswow64()
  • Reimplemented some functions in util.py
    • parsing of Proton version strings
    • get_resolution() with RegEx
    • _get_case_insensitive_name()
    • _killhanging()
    • _checkinstalled()
  • Implemented new ConfigBase class
  • Use config for caching dir
  • Refactored logger.py
  • et cetera..

CC #50


EDIT:
02/21 commits cherry-picked in #200

  1. e3771ff
  2. 71eb0da

10/21 commits cherry-picked in #201

  1. fd8b058
  2. ec2292f
  3. 6d7dc32
  4. ec4a37d
  5. a51a512
  6. f49e7fa
  7. ad470d5
  8. 1ce9d45
  9. 54c18c2
  10. 5142e5c

04/21 commits cherry-picked in #202

  1. 02a0213
  2. 19f61d0
  3. d738146
  4. 611641e

02/21 commits cherry-picked in #203

  1. 965a50e
  2. 12457bb

03/21 commits cherry-picked in #205

00/21 left

This prevents subsequent errors and fixes errors thrown by static code analysis.
- Correctly override optionxform
- String can not be None
- Fixed import of urllib
- Exit if game id is not present
- Allow paths to be str or Path
- Typed config
- Separate sections in object
- Easy and clean interface
- Reusable
- use print functions instead of manual
- class methods
- caching
- format string
- Changed ruff's docstring style to "google"
- Removed ignored ruff rules, that are already satisfied
- Ignore missing cls annotations (ANN102)
- Added docstrings to Config and ConfigBase (+Engine)
- enable static type checking via pyright-action
- added pyproject.toml with basic meta data and pyright configuration
- use action-shellcheck instead of installing it manually
- use ruff-action instead of installing it manually
- Cache pip dependencies
- Use pathlib if possible
- Return Path() object is possible
- Parse ProtonVersion correctly
- Reimplemented get_resolution() with RegEx
- Reimplemented _get_case_insensitive_name()
- Reimplemented _killhanging()
- Reimplemented _checkinstalled()
- Improved some logging
- Some caching
util.py:
- Added create_dos_device()
- Added patch_conf_value()
- Added patch_voodoo_conf()
- Added get_path_syswow64()
- Moved class ReplaceType from Bethesda mod support (class Redirect)

Other:
- Refactored gamefixes to use pathlib
- Simplified / reimplemented some fixes
- Some docstrings
- Linked Gobliiins 5 demo to main game
- Unified Gothic 3 and Gothic 3 Forsaken Gods Enhanced Edition
- Fixes after rebase
- Logger: use Enum values for colors
- Use default parameters, if argument is equal
- Fixed relative imports
- Removed import handling via ImportError exception
- Fixed CI by running via module, instead of file
- Added / improved handling in __init__.py for unit tests
@Root-Core Root-Core marked this pull request as ready for review December 17, 2024 23:55
@Root-Core
Copy link
Contributor Author

Root-Core commented Dec 18, 2024

The PR should be ready to go. I know it's heavy... but if you go through it commit by commit, it shouldn't be too complex. Sorry about that. Splitting wasn't really an option. If it gets merged, I would vote for keeping the commit history and avoiding squashing it.

I finally tested it and fixed the last remaining issue, the "ugly" imports for the unit tests.
So I think it's in a good state for review.

Disclaimer: I have only tested it with Steam and it works for me. It would be nice if someone could test it on other platforms.

@R1kaB3rN
Copy link
Member

The PR should be ready to go. I know it's heavy... but if you go through it commit by commit, it shouldn't be too complex. Sorry about that. Splitting wasn't really an option. If it gets merged, I would vote for keeping the commit history and avoiding squashing it.

I finally tested it and fixed the last remaining issue, the "ugly" imports for the unit tests. So I think it's in a good state for review.

Disclaimer: I have only tested it with Steam and it works for me. It would be nice if someone could test it on other platforms.

I'm open to merging some of this, but are you sure splitting it wasn't really an option? For instance, at a glance, I'm not seeing why the config-related functionality couldn't be.

@R1kaB3rN
Copy link
Member

We're making a lot of changes here on functionality that isn't currently unit tested. More importantly, it affects user created fixes that are not being tested in the CI either, which gives me less confidence. Unless you think that only using ruff is sufficient?

@R1kaB3rN
Copy link
Member

In our CI, I'm thinking it might be a good idea to simply run all our current fixes through umu-launcher. It won't guarantee that the fix works for the game, but it will guarantee a runtime error won't occur whenever we do big refactors.

@@ -57,20 +57,8 @@ select = [
"D"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We can enforce using pathlib through the PTH rule whenever working with paths.

See https://docs.astral.sh/ruff/rules/#flake8-use-pathlib-pth

@Root-Core
Copy link
Contributor Author

To be honest, I don't remember what the problem was with the config. I think there were some issues with the static types and it still needed to be rewritten. It might be a bit overkill with the current setup, but I think it's nicely typed and clean this way.

Sure, some of the refactoring could be excluded, mostly the refactored gamefixes, but again this is heavily tied to the transition to pathlib and fixing some of the typing issues.

The reason why splitting it up is a bit complicated is that the static type checks are active once the workflow is merged, and when it is merged, it will generate error messages and annotations for every PR until all issues are fixed. So undoing things will certainly break things, and it will create quite a bit of work to work around it. You might disagree, but if we end up merging all/most of it, it wouldn't be worth the effort to artificially split the PR just for the sake of it.

I know this isn't satisfying, but please just check commit for commit. Most of it is noise, and the rest is actually trying to improve and fix things.

@R1kaB3rN
Copy link
Member

Yeah, I won’t accept merge this in its current form.

However, someone else on the team may think differently so you’ll have to wait for them.

Later, I’ll be cherry picking a subset of changes and will try to write something up to ensure all our fixes are in order. Most of the changes you’re making in users’ fixes I won’t accept, unless the ones that are clearly bad practice (e.g. not creating a context manager when opening files).

@Root-Core
Copy link
Contributor Author

The changes to the user fixes are mostly well tested or trivial. Nevertheless, I understand your concerns about the changes, and I will try to split them into several pull requests. We may need some sort of order to merge them, as they build on each other. That's why commit for commit checking should work here.

Some commits can be cherry picked. I will start with the imports etc.. this will remove most of the noise from this PR.

@Root-Core
Copy link
Contributor Author

Root-Core commented Jan 9, 2025

@R1kaB3rN There is still some work to be done, but most of the commits have been cherry-picked into the appropriate PRs.

It would be most important to merge #200, as more or less any PR with changes/adds/removals to gamefixes will cause conflicts.

#201 should be straightforward and the most useful PR, as it actually fixes some bugs and improves the codebase a lot.

I fear #202 and #203 will be controversial.

The remaining commits will actually enable the static type checking and problem annotation. It would certainly fail with the current code base. These commits will be cherry-picked after the others are merged.

@Root-Core
Copy link
Contributor Author

Closing this PR, as it is superseded by #200 #201 #202 #203 #205 and all commits should be cherry-picked in them.
I will compare it again, when everything is merged to ensure nothing has been missed.

@Root-Core Root-Core closed this Jan 10, 2025
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