-
Notifications
You must be signed in to change notification settings - Fork 94
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
refactor: replace darglint
with pydoclint
#749
base: main
Are you sure you want to change the base?
Conversation
New and removed dependencies detected. Learn more about Socket for GitHub ↗︎
🚮 Removed packages: pypi/darglint@1.8.1 |
@coderabbitai full review |
Actions performedFull review triggered. |
Warning Rate limit exceeded@mvadari has exceeded the limit for the number of commits or files that can be reviewed per hour. Please wait 0 minutes and 11 seconds before requesting another review. ⌛ How to resolve this issue?After the wait time has elapsed, a review can be triggered using the We recommend that you space out your commits to avoid hitting the rate limit. 🚦 How do rate limits work?CodeRabbit enforces hourly rate limits for each developer per organization. Our paid plans have higher rate limits than the trial, open-source and free plans. In all cases, we re-allow further reviews after a brief timeout. Please see our FAQ for further information. ⛔ Files ignored due to path filters (1)
📒 Files selected for processing (1)
WalkthroughThe changes in this pull request involve updating the unit testing workflow and the Changes
Assessment against linked issues
Possibly related PRs
Suggested reviewers
Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media? 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
Documentation and Community
|
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.
Actionable comments posted: 1
Outside diff range and nitpick comments (3)
.flake8 (1)
14-17
: Temporary workaround looks good, but track the TODO.Allowing docstrings in
__init__
functions as a temporary measure for easier migration fromdarglint
is a pragmatic approach. However, please ensure that the TODO comment is tracked and addressed in the future to maintain consistency with standard docstring conventions.xrpl/core/binarycodec/types/st_object.py (2)
61-63
: Linting warning suppressed, but consider addressing the underlying issue.The addition of the
# noqa: ANN401
comment suppresses the linting warning related to the return type annotation of the_str_to_enum
function. While this allows the code to pass the linting checks, it's important to consider addressing the underlying issue to improve code quality and maintainability.Consider updating the return type annotation to accurately reflect the possible return values of the function. This will not only resolve the linting warning but also provide better type information for users of the function.
73-74
: Linting warning suppressed, but consider addressing the underlying issue.The addition of the
# noqa: ANN401
comment suppresses the linting warning related to the return type annotation of the_enum_to_str
function. While this allows the code to pass the linting checks, it's important to consider addressing the underlying issue to improve code quality and maintainability.Consider updating the return type annotation to accurately reflect the possible return values of the function. This will not only resolve the linting warning but also provide better type information for users of the function.
Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Files ignored due to path filters (1)
poetry.lock
is excluded by!**/*.lock
Files selected for processing (16)
- .darglint (0 hunks)
- .flake8 (3 hunks)
- .github/workflows/unit_test.yml (1 hunks)
- .pre-commit-config.yaml (1 hunks)
- CONTRIBUTING.md (1 hunks)
- pyproject.toml (3 hunks)
- tests/unit/core/binarycodec/types/test_serialized_type.py (1 hunks)
- xrpl/core/addresscodec/codec.py (1 hunks)
- xrpl/core/binarycodec/types/serialized_type.py (2 hunks)
- xrpl/core/binarycodec/types/st_object.py (2 hunks)
- xrpl/models/base_model.py (3 hunks)
- xrpl/models/nested_model.py (1 hunks)
- xrpl/models/requests/generic_request.py (1 hunks)
- xrpl/models/response.py (2 hunks)
- xrpl/transaction/main.py (1 hunks)
- xrpl/utils/xrp_conversions.py (3 hunks)
Files not reviewed due to no reviewable changes (1)
- .darglint
Additional comments not posted (26)
.pre-commit-config.yaml (1)
24-24
: LGTM! The change aligns with the PR objective of replacingdarglint
withpydoclint
.The removal of the
--darglint-ignore-regex
argument from theflake8
command is consistent with the goal of replacingdarglint
withpydoclint
for docstring linting. This change may result in additional warnings being reported during the pre-commit checks, as the specified darglint warnings will no longer be ignored.Ensure that all relevant docstrings have been updated to comply with the new linting rules enforced by
pydoclint
. The PR objectives indicate that all linter issues arising from the upgrades have been addressed, which suggests that the necessary updates have been made..flake8 (3)
21-21
: LGTM!Updating the
per-file-ignores
setting for test files to useDOC
instead ofDAR
aligns with the PR objective of replacingdarglint
withpydoclint
. This ensures that test files are linted using the new docstring style rules.
33-33
: Comment adds clarity.Adding a comment to clarify that
DOC
enables docstring style linting viapydoclint
is helpful for developers. It provides a clear indication of the tool being used for this purpose.
43-43
: LGTM!Updating the
select
option to includeDOC
and removeDAR
aligns with the PR objective of replacingdarglint
withpydoclint
. This change ensures that the linter applies the new docstring style rules consistently across the codebase.pyproject.toml (6)
33-33
: Clarify the reasoning behind the Python version bump.The Python version requirement change from
^3.8
to^3.8.1
looks good and is unlikely to cause any compatibility issues. However, could you please provide some context on why the minimum version was bumped specifically to 3.8.1? This will help maintain a clear record of the rationale behind the change.
44-44
: Verify the impact of the flake8 and flake8-annotations upgrades.The upgrades to
flake8
(to^7.0.0
) andflake8-annotations
(to3.1.1
) look good, considering that the PR objectives state all linter issues arising from these upgrades have been addressed.However, given that the
flake8
upgrade is a major version bump, it would be prudent to double-check that the new linting rules do not flag any unintended issues in the codebase. Please verify that the linter passes cleanly after these upgrades.Also applies to: 51-51
53-53
: Monitor pydoclint's stability and verify its impact on the codebase.The migration from
darglint
topydoclint
looks good as it aligns with the PR objective of replacing the outdateddarglint
with a more actively maintained and faster alternative. The reduction in linting time from 23 seconds to 9 seconds is a significant improvement.However, please note that
pydoclint
is still in an early version (^0.5.7
), which may indicate potential instability or future breaking changes. It would be wise to monitorpydoclint
's releases and stability going forward.Additionally, please verify that the new
pydoclint
rules do not flag any unintended documentation issues in the codebase.
60-60
: Provide more context on the poethepoet upgrade.The upgrade of
poethepoet
from^0.19.0
to^0.28.0
looks good as it is a minor version bump, which generally indicates the addition of new features and bug fixes without introducing breaking changes.However, could you please provide more context on the motivation behind this upgrade? Are there any specific features or fixes from the newer
poethepoet
versions that are being leveraged in this project? This information will help maintain a clear record of the reasoning behind the upgrade.
83-83
: LGTM!The addition of the
lint
task under[tool.poe.tasks]
is a great improvement to the project's linting capabilities. Runningflake8
on thexrpl
,tests
, andsnippets
directories will help maintain code quality and consistency by enforcing coding standards and identifying potential issues early in the development process. This task will be a valuable addition to the development workflow and CI/CD pipeline.
Line range hint
1-90
: Great work on improving the project's dependencies and linting capabilities!The changes made in this PR, including the dependency upgrades, migration to
pydoclint
, and addition of thelint
task, align well with the stated objectives of keeping the project up-to-date, improving performance, and enhancing code quality. These changes collectively contribute to a better development workflow, increased maintainability, and more consistent code.The migration to
pydoclint
and the addition of thelint
task are particularly noteworthy, as they can significantly reduce linting time and catch potential issues early in the development process.Overall, the changes look good, subject to addressing any outstanding questions or concerns raised in the previous review comments. Keep up the great work!
tests/unit/core/binarycodec/types/test_serialized_type.py (1)
51-51
: LGTM!The change from
type(fixture.test_json) == dict
toisinstance(fixture.test_json, dict)
is a good improvement. It enhances the robustness of the type checking by allowing for subclassing, which is more Pythonic and flexible.xrpl/models/nested_model.py (1)
24-24
: Verify if suppressing the linting warning is justified.The change of adding the
# noqa: ANN401
comment directive to suppress the specific linting warning related to type annotations does not impact the functionality or correctness of theis_dict_of_model
method.However, please ensure that suppressing the
ANN401
warning is justified and aligns with the project's linting guidelines. If the suppression is deemed necessary, consider adding a comment explaining the reason for suppressing the warning to maintain code clarity.To verify the suppression, run the following script:
Verification successful
ANN401 suppression is justified and consistent with project practices.
The addition of
# noqa: ANN401
to suppress the linting warning for theAny
type annotation in theis_dict_of_model
method is justified and aligns with the project's coding practices. Here's why:
- The suppression is used consistently throughout the codebase for functions with
Any
type annotations, indicating a deliberate coding style choice.- The use of
Any
type and its suppression appears necessary due to the nature of the XRPL library, which likely needs to handle various data types flexibly.- The suppression is not overused, appearing only in specific scenarios where the
Any
type is required.- The project demonstrates a judicious use of linting suppressions overall, suggesting that this particular suppression is part of a well-considered approach to code quality.
The change is approved, as it maintains consistency with the existing codebase practices and does not impact the functionality of the method.
Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Description: Verify if suppressing the ANN401 linting warning is justified. # Test: Search for the suppression comment in the codebase. Expect: Only occurrences in justified cases. rg --type python $'# noqa: ANN401'Length of output: 66
Script:
#!/bin/bash # Description: Verify the usage of linting suppressions in Python files # Search for "# noqa: ANN401" in Python files echo "Occurrences of '# noqa: ANN401':" fd -e py -x rg -n "# noqa: ANN401" {} echo -e "\nAll occurrences of 'noqa' in Python files:" fd -e py -x rg -n "# noqa:" {} echo -e "\nPython files containing 'noqa':" fd -e py -x rg -l "# noqa:" {} | sort | uniqLength of output: 5183
xrpl/core/binarycodec/types/serialized_type.py (3)
28-28
: Suppressing ANN401 linting error for flexibility.The addition of the
# noqa: ANN401
comment directive to suppress the linting error for theAny
type annotation on thelength_hint
parameter is a reasonable decision. It allows subclasses to define their own type requirements forlength_hint
, providing flexibility in the implementation.While using
Any
is generally discouraged, in this case, it serves a purpose to accommodate different use cases in subclasses. The suppression of the linting error is justified given the context and the need for adaptability.
34-34
: Suppressing D102 and ANN401 linting errors for flexibility and brevity.The addition of the
# noqa: D102 ANN401
comment directive to suppress the linting errors for the missing docstring and theAny
type annotation on thevalue
parameter is a reasonable decision in this context. It allows thefrom_value
method to accept different types of values, providing flexibility in the implementation.While missing docstrings and using
Any
are generally discouraged, in this case, the developer has made a conscious choice to prioritize flexibility and brevity. The suppression of the linting errors is justified given the specific requirements and design decisions of the codebase.
57-57
: Suppressing ANN401 linting error for flexibility in JSON representation.The addition of the
# noqa: ANN401
comment directive to suppress the linting error for theAny
type annotation on the return value of theto_json
method is a reasonable decision. It allows the method to return different types of JSON representations, providing flexibility in the implementation.While using
Any
is generally discouraged, in this case, it serves a purpose to accommodate different JSON structures that may be returned by subclasses or overridden implementations. The suppression of the linting error is justified given the context and the need for adaptability in the JSON representation.xrpl/models/requests/generic_request.py (1)
31-31
: LGTM!The addition of the
# noqa: ANN401
directive to suppress the linting warning related to the lack of type annotation for thekwargs
parameter is appropriate in this case. The directive indicates that the developer has intentionally chosen not to annotatekwargs
with a specific type, as it is meant to accept any keyword arguments.The change addresses the linting feedback without altering the functionality of the
__init__
method, which remains unchanged. This stylistic adjustment improves code quality while maintaining the intended behavior of the method.xrpl/utils/xrp_conversions.py (2)
39-39
: LGTM!The change from
type(xrp) == str
toisinstance(xrp, str)
is an improvement as it allows for subclassing and is considered a best practice for type checking in Python. The rest of the function logic remains unchanged, and the overall functionality is not affected.
87-87
: LGTM!The change from
type(drops) != str
tonot isinstance(drops, str)
is an improvement as it allows for subclassing and is considered a best practice for type checking in Python. The rest of the function logic remains unchanged, and the overall functionality is not affected.xrpl/transaction/main.py (1)
2-2
: LGTM!Adding a blank line after the module docstring is consistent with the PEP 8 style guide and enhances code readability. Good catch!
xrpl/models/response.py (2)
95-95
: LGTM!The addition of the
# noqa: ANN401
comment suppresses the linting ruleANN401
for this function. This rule is likely related to missing type annotations. Since this is an internal function and the types can be inferred from the context, suppressing this specific rule is acceptable.
114-114
: LGTM!Similar to the
_do_contains_partial_payment
function, the addition of the# noqa: ANN401
comment suppresses the linting ruleANN401
for this function. This rule is likely related to missing type annotations. Since this is an internal function and the types can be inferred from the context, suppressing this specific rule is acceptable.xrpl/core/addresscodec/codec.py (1)
43-44
: LGTM!Splitting the long error message into two lines improves readability without altering the semantic content. The error message still conveys the same information about the mismatch between the length of the provided bytestring and the expected length.
CONTRIBUTING.md (1)
69-69
: LGTM!The change from directly running
flake8
to usingpoetry run poe lint
is a good improvement. It abstracts the linting process and makes it easier for contributors to run the linter with the correct arguments and configurations. This reduces the chances of contributors running the linter with incorrect settings and ensures consistency across all contributions.xrpl/models/base_model.py (3)
88-88
: LGTM!The addition of the
# noqa: ANN401
comment is used to suppress a specific type annotation related linting warning (likely from theflake8-annotations
plugin). This is an acceptable way to silence the linter when the type hint is complex or the linter is raising a false positive. The method functionality remains unaffected.
153-153
: LGTM!As explained in the previous comment, the
# noqa: ANN401
comment is an acceptable way to suppress a specific type annotation related linting warning when the type hint is complex or the linter is raising a false positive. The method functionality remains unaffected.
324-324
: LGTM!As explained in the previous comments, the
# noqa: ANN401
comment is an acceptable way to suppress a specific type annotation related linting warning when the type hint is complex or the linter is raising a false positive. The method functionality remains unaffected.
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.
Actionable comments posted: 0
🧹 Outside diff range and nitpick comments (1)
pyproject.toml (1)
Line range hint
86-90
: LGTM: Improved test and coverage tasksThe updates to the
test
andtest_coverage
tasks are good improvements:
- The
test
task now usespython3 -m unittest ${FILE_PATHS}
, which allows for more flexible test execution.- The
test_coverage
task now includes a sequence to run tests and report coverage, which is a more comprehensive approach.These changes should enhance the testing process and provide better insights into code coverage.
Consider adding a minimum coverage threshold to the
coverage report
command in thetest_coverage
task. For example:[tool.poe.tasks.test_coverage] sequence = [ { cmd = "coverage run -m unittest discover" }, { cmd = "coverage report --fail-under=90" } ]This ensures that the coverage check fails if it falls below the specified threshold, helping maintain high test coverage.
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
⛔ Files ignored due to path filters (1)
poetry.lock
is excluded by!**/*.lock
📒 Files selected for processing (1)
- pyproject.toml (3 hunks)
🔇 Additional comments (6)
pyproject.toml (6)
33-33
: LGTM: Python version requirement updateThe update from
^3.8
to^3.8.1
is a minor version bump, which is unlikely to introduce breaking changes. This change aligns with the PR objectives of updating dependencies and may include bug fixes or security improvements.
53-53
: LGTM: Replacement of darglint with pydoclintThe introduction of
pydoclint ^0.5.7
as a replacement fordarglint
aligns perfectly with the PR objectives. This change should improve the docstring linting process and reduce the overall linting time as mentioned in the PR summary.
83-83
: LGTM: New lint task addedThe addition of the
lint
task in the[tool.poe.tasks]
section is a good improvement. It provides a convenient way to runflake8
on the project's main directories (xrpl
,tests
, andsnippets
). This change aligns with the PR objectives and should help streamline the linting process.
Line range hint
1-90
: Summary of pyproject.toml changesThe changes in this file successfully achieve the main objectives of the PR:
- Replacing
darglint
withpydoclint
.- Updating various dependencies, including
flake8
andflake8-annotations
.- Adding a new
lint
command inpoe
.- Improving test and coverage tasks.
These updates should lead to faster linting, improved development workflow, and better maintenance of the project. However, please address the following points:
- Verify compatibility with the updated linting tools.
- Clarify the reason for downgrading Sphinx.
- Consider adding a minimum coverage threshold to the
test_coverage
task.Overall, these changes represent a positive step in improving the project's tooling and processes.
59-59
: Clarify the reason for downgrading SphinxThe downgrade of Sphinx from
^7.1.2
to^5.3.0
is unexpected and not mentioned in the PR objectives. Could you please provide the rationale for this change? It's important to ensure that this downgrade doesn't negatively impact the project's documentation generation process.#!/bin/bash # Description: Check if Sphinx 5.3.0 is compatible with the current documentation # Run Sphinx build and capture any warnings or errors sphinx_output=$(poetry run sphinx-build -W -b html docs docs/_build 2>&1) # Check if there are any errors if [ -n "$sphinx_output" ]; then echo "Warnings or errors found when building documentation with Sphinx 5.3.0:" echo "$sphinx_output" else echo "Documentation builds successfully with Sphinx 5.3.0." fi
44-44
: Verify compatibility with updated linting toolsThe updates to
flake8
(^4.0.1 to ^7.0.0) andflake8-annotations
(2.7.0 to 3.1.1) are significant version bumps. While these updates align with the PR objectives, please ensure that:
- The project's code is compatible with any new linting rules introduced in these versions.
- The CI/CD pipeline has been updated to accommodate these changes.
- The team is aware of any new warnings or errors that may arise from these updates.
Also applies to: 51-51
darglint
with pydoclint
darglint
with pydoclint
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.
Actionable comments posted: 1
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
⛔ Files ignored due to path filters (1)
poetry.lock
is excluded by!**/*.lock
📒 Files selected for processing (2)
.github/workflows/unit_test.yml
(1 hunks)pyproject.toml
(3 hunks)
🧰 Additional context used
📓 Learnings (1)
.github/workflows/unit_test.yml (2)
Learnt from: mvadari
PR: XRPLF/xrpl-py#749
File: .github/workflows/unit_test.yml:52-52
Timestamp: 2024-10-08T16:29:11.194Z
Learning: - The project has always used the Google docstring convention for linting.
- The linting settings are in the `.flake8` file.
- The darglint-specific error wasn't supported in `.flake8`.
Learnt from: mvadari
PR: XRPLF/xrpl-py#749
File: .github/workflows/unit_test.yml:52-52
Timestamp: 2024-09-19T19:59:13.398Z
Learning: - The project has always used the Google docstring convention for linting.
- The linting settings are in the `.flake8` file.
- The darglint-specific error wasn't supported in `.flake8`.
🔇 Additional comments (5)
pyproject.toml (3)
37-37
: Review dependency version compatibility.
The significant version updates require careful consideration:
flake8
upgrade from 4.0.1 to 7.0.0 is a major version jumpflake8-annotations
update to 3.1.1- New
pydoclint
dependency at 0.5.7
These changes align with the PR objectives and should improve linting performance. However, let's verify the compatibility between these tools.
#!/bin/bash
# Check for any custom flake8 configurations that might need updates
echo "Checking for flake8 configs..."
rg -l "flake8" -g "!pyproject.toml"
# Look for any darglint specific configurations that need to be migrated
echo "Checking for darglint configs to migrate..."
rg -l "darglint" -g "!pyproject.toml"
Also applies to: 44-44, 46-46
Line range hint 26-76
: Verify removal of darglint-specific configurations.
The PR replaces darglint with pydoclint, but we should ensure all darglint-specific configurations are properly migrated or removed.
#!/bin/bash
# Look for any remaining darglint references that need to be cleaned up
echo "Checking for remaining darglint references..."
rg "darglint" --type-not toml
# Check for any docstring-related configurations in setup.cfg or .flake8
echo "Checking for docstring configurations..."
fd -e cfg -e flake8 -x cat {}
26-26
: Verify Python version constraint change impact.
The Python version requirement has been updated from ^3.8
to ^3.8.1
. While this is a minor version bump, it could potentially affect users running Python 3.8.0.
✅ Verification successful
Let me gather more information to verify the Python version constraint change impact.
Based on the gathered information, I can now provide the final response:
Python version constraint change is safe
The change from ^3.8
to ^3.8.1
is safe because:
- All CI workflows are configured to test against Python versions "3.8" through "3.13", which includes newer 3.8.x releases
- No Python files in the codebase show usage of features specific to Python 3.8.1
- The change aligns with the project's testing matrix while maintaining broad compatibility
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Check if any CI/CD workflows specify Python 3.8.0
rg -l "3\.8\.0" .github/workflows/
Length of output: 255
Script:
#!/bin/bash
# Check Python version specifications in CI workflows
rg -l "python-version" .github/workflows/
# If files found, check their content for Python version specifications
rg "python-version" .github/workflows/ -A 2
# Check if there are any Python files that might use 3.8-specific features
fd -e py --exec head -n 1 {}
Length of output: 17598
.github/workflows/unit_test.yml (2)
Line range hint 102-103
: Great addition of coverage threshold!
The explicit coverage threshold of 85% is a good practice for maintaining code quality. This ensures that any new changes maintain a high level of test coverage.
52-52
: LGTM! The linting command has been simplified.
The change from direct flake8 invocation to poetry run poe lint
aligns with the PR objectives of replacing darglint with pydoclint. This abstraction through poe tasks not only simplifies the command but also significantly improves performance (23s → 9s).
Let's verify the poe lint task configuration:
✅ Verification successful
Let me verify the flake8 configuration to ensure pydoclint is properly configured:
Linting configuration is properly set up with pydoclint
The verification confirms that:
- The
poe lint
task correctly runs flake8 on the required directories - Flake8 is configured to use pydoclint (DOC selector enabled)
- pydoclint v0.5.7 is included in the project dependencies
- Google docstring convention is properly set
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Description: Verify the poe lint task configuration
# Expect: The lint task should be configured to use flake8 with pydoclint
# Check the lint task configuration in pyproject.toml
echo "Checking lint task configuration:"
rg -A 5 '^\[tool\.poe\.tasks\]' pyproject.toml
Length of output: 344
Script:
#!/bin/bash
# Check flake8 configuration
echo "Checking .flake8 configuration:"
cat .flake8
# Check pyproject.toml for any pydoclint configuration
echo -e "\nChecking pyproject.toml for pydoclint:"
rg "pydoclint" pyproject.toml
# Check poetry dependencies
echo -e "\nChecking poetry dependencies:"
cat pyproject.toml | rg -A 2 '^\[tool\.poetry\.dependencies\]|^\[tool\.poetry\.dev-dependencies\]'
Length of output: 1980
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.
Actionable comments posted: 0
🧹 Outside diff range and nitpick comments (1)
CONTRIBUTING.md (1)
69-69
: LGTM! Consider adding more details about the linting process.The simplified linting command aligns with the PR objectives. However, consider adding:
- A description of what the lint command checks (flake8, pydoclint, etc.)
- Information about the minimum code coverage requirement (85%)
Add this content after the linting command:
poetry run poe lint + +The lint command runs: +- flake8: for code style and quality checks +- pydoclint: for docstring style and completeness checks + +Note: A minimum code coverage of 85% is required for all new code.
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.
Actionable comments posted: 0
🧹 Outside diff range and nitpick comments (2)
xrpl/core/binarycodec/types/serialized_type.py (2)
19-24
: Add Returns section to the constructor docstring.The docstring follows good practices but should include a Returns section for completeness, even when returning None.
""" Construct a new SerializedType. Args: buffer: The buffer containing the data for the SerializedType. + + Returns: + None """
94-99
: Enhance the len docstring clarity.While the docstring is correct, it could be more specific about what it's measuring.
""" - Get the length of a SerializedType's bytes. + Get the length of this SerializedType's underlying buffer. Returns: - The number of bytes. + int: The number of bytes in the buffer. """
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
⛔ Files ignored due to path filters (1)
poetry.lock
is excluded by!**/*.lock
📒 Files selected for processing (3)
pyproject.toml
(2 hunks)xrpl/core/binarycodec/types/serialized_type.py
(2 hunks)xrpl/core/binarycodec/types/st_object.py
(2 hunks)
✅ Files skipped from review due to trivial changes (1)
- xrpl/core/binarycodec/types/st_object.py
🚧 Files skipped from review as they are similar to previous changes (1)
- pyproject.toml
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.
Thanks for the PR. For the sake of completeness, I'd like to mention two other packages, which have been maintained frequently:
I don't have a preference for one over the other. However, these can be used for future updates to the linter.
# This is for pydocstyle - to allow docstrings in __init__ functions | ||
# This rule was used for easier migration from darglint | ||
# TODO: remove this rule | ||
allow-init-docstring=True |
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.
Is it possible to remove this rule within the scope of this PR ?
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.
It would make the diff gigantic and much harder to review.
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.
hmmm
Those would be a replacement for flake8, not darglint. |
I don't know how to compare these packages. For instance, here is a verbatim quote from the
This appears to suggest that |
Furthermore, I'm getting many
I am using this PR branch and I verified that there are no |
Did you run |
|
Yes, I got the following successful response:
However, the previous error persists on my local machine. I'm wondering if I need to update any other files/folder.
|
per-file-ignores = | ||
# For tests, disable type annotation and docstring linting. | ||
tests/*: ANN D DAR | ||
tests/*: ANN D DOC | ||
|
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.
Would you consider adding an ignore
line here?
# Ignore the docstring linting errors
xrpl/*: DAR
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.
I can subdue these errors with this .flake8
configuration setting. See this suggestion: https://github.com/XRPLF/xrpl-py/pull/749/files#r1888218681
However, I don't know if it is wise to ignore the linter errors.
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.
You might need to remove darglint
manually as a dependency: poetry remove darglint
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.
that doesn't help:
xrpl-py-py3.11➜ xrpl-py git:(pydoclint) ✗ poetry remove darglint
The following packages were not found: darglint
What version of Python do you have? I am using Python 3.11, the CI/CD uses Python v3.8
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.
I'm using 3.11, so not sure what problem you're having. The DAR errors shouldn't be showing up at all, given that the flake8 config no longer includes them in the select
list. My best suggestion is to nuke your .venv
folder and reinstall.
mvadari@mvadari-H2R24-MBP xrpl-py % poetry run python --version
Python 3.11.4
mvadari@mvadari-H2R24-MBP xrpl-py % poetry run poe lint
Poe => poetry run flake8 xrpl tests snippets
mvadari@mvadari-H2R24-MBP xrpl-py %
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.
okay, nuking the virtual environment folder helped me.
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.
Actionable comments posted: 2
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
⛔ Files ignored due to path filters (1)
poetry.lock
is excluded by!**/*.lock
📒 Files selected for processing (1)
pyproject.toml
(3 hunks)
🧰 Additional context used
📓 Learnings (1)
pyproject.toml (1)
Learnt from: mvadari
PR: XRPLF/xrpl-py#749
File: pyproject.toml:76-76
Timestamp: 2024-11-12T12:37:49.114Z
Learning: When configuring Flake8 tasks in `pyproject.toml` or Poe tasks, avoid duplicating the list of checks in the command line since the checks are already specified in the `.flake8` configuration file.
🔇 Additional comments (2)
pyproject.toml (2)
80-80
: LGTM! The lint task is well configured.
The lint task correctly relies on the .flake8
configuration file and includes all relevant directories.
46-49
: Verify the impact of replacing darglint with pydoclint.
Let's check if there are any docstring-related issues that need to be addressed with the new linter.
✅ Verification successful
Based on the output, I can see that there are many docstrings in the codebase that follow the darglint style with "Args:", "Returns:", and "Raises:" sections. This indicates that the codebase has been consistently using darglint-style docstrings.
Since pydoclint is designed to be compatible with Google-style docstrings (which includes the same "Args:", "Returns:", and "Raises:" sections), and the version constraints in pyproject.toml are properly set based on Python version compatibility, this change should not require any modifications to the existing docstrings.
Let me generate the final response:
The transition from darglint to pydoclint is safe and requires no changes
The codebase consistently uses Google-style docstrings with "Args:", "Returns:", and "Raises:" sections, which are fully compatible with both darglint and pydoclint. The version constraints in pyproject.toml are appropriately set for Python version compatibility.
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Description: Check for any docstring-related issues that need fixing
# Find Python files
echo "Checking Python files for docstrings..."
fd -e py -x echo "Checking {}" \; -x grep -l "def \|class " {} \; 2>/dev/null
# Look for existing darglint-style docstrings that might need updating
echo -e "\nChecking for darglint-style docstrings..."
rg "Args:|Returns:|Raises:" -A 2
Length of output: 102119
High Level Overview of Change
darglint
, the docstring linter we use, hasn't been updated in 3 years.pydoclint
is kept up to date and is also much faster (linting took 23 seconds previously and now only takes 9).This PR also creates a
lint
command inpoe
, upgradesflake8
andpoethepoet
to the latest versions, and fixes all linter issues that arose from the upgrade.Context of Change
Fixes #730
Type of Change
Did you update CHANGELOG.md?
Test Plan
The linter still passes.