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

refactor: replace darglint with pydoclint #749

Open
wants to merge 20 commits into
base: main
Choose a base branch
from
Open

refactor: replace darglint with pydoclint #749

wants to merge 20 commits into from

Conversation

mvadari
Copy link
Collaborator

@mvadari mvadari commented Sep 17, 2024

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 in poe, upgrades flake8 and poethepoet to the latest versions, and fixes all linter issues that arose from the upgrade.

Context of Change

Fixes #730

Type of Change

  • Refactor (non-breaking change that only restructures code)
  • Documentation Updates

Did you update CHANGELOG.md?

  • Yes
  • No, this change does not impact library users

Test Plan

The linter still passes.

Copy link

socket-security bot commented Sep 17, 2024

New and removed dependencies detected. Learn more about Socket for GitHub ↗︎

Package New capabilities Transitives Size Publisher
pypi/[email protected] None 0 196 kB jsh9
pypi/[email protected] eval, filesystem 0 268 kB jsh9
pypi/[email protected] filesystem 0 257 kB jsh9
pypi/[email protected] filesystem, shell 0 262 kB jsh9

🚮 Removed packages: pypi/[email protected]

View full report↗︎

@mvadari
Copy link
Collaborator Author

mvadari commented Sep 19, 2024

@coderabbitai full review

Copy link
Contributor

coderabbitai bot commented Sep 19, 2024

Actions performed

Full review triggered.

Copy link
Contributor

coderabbitai bot commented Sep 19, 2024

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 @coderabbitai review command as a PR comment. Alternatively, push new commits to this PR.

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.

📥 Commits

Reviewing files that changed from the base of the PR and between b30d6bf and 91c4223.

⛔ Files ignored due to path filters (1)
  • poetry.lock is excluded by !**/*.lock
📒 Files selected for processing (1)
  • CONTRIBUTING.md (1 hunks)

Walkthrough

The changes in this pull request involve updating the unit testing workflow and the pyproject.toml file to enhance linting and testing processes. The linting command has shifted from using darglint to pydoclint, and the Python version requirement has been updated. Additionally, a new linting task has been introduced, and a coverage report step has been added to the workflow, enforcing a minimum coverage threshold of 85%.

Changes

Files Change Summary
.github/workflows/unit_test.yml Updated linting command to poetry run poe lint, changed unit testing command to poetry run poe test_unit, and added coverage report step with a threshold.
pyproject.toml Updated Python version to >=3.8.1,<4.0, replaced darglint with pydoclint, and added a new linting task.
CONTRIBUTING.md Updated contribution guidelines to reflect new poe commands for linting and testing, consolidated test instructions, and clarified dependency management.
xrpl/core/binarycodec/types/serialized_type.py Enhanced docstring for the SerializedType constructor and __len__ method for improved clarity.
xrpl/core/binarycodec/types/st_object.py Removed comments from _str_to_enum and _enum_to_str functions for improved code clarity.

Assessment against linked issues

Objective Addressed Explanation
Replace darglint docstring linter (Issue #730)

Possibly related PRs

Suggested reviewers

  • ckeshava
  • justinr1234
  • pdp2121

🐰 In the meadow where bunnies play,
We’ve tidied up our code today!
With pydoclint now in sight,
Our docstrings shine so bright!
Hopping through the lines so neat,
A clearer path, oh what a treat!
🐇✨


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?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

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)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai generate docstrings to generate docstrings for this PR. (Beta)
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link
Contributor

@coderabbitai coderabbitai bot left a 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 from darglint 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

Commits

Files that changed from the base of the PR and between 17aad31 and de85464.

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 replacing darglint with pydoclint.

The removal of the --darglint-ignore-regex argument from the flake8 command is consistent with the goal of replacing darglint with pydoclint 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 use DOC instead of DAR aligns with the PR objective of replacing darglint with pydoclint. 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 via pydoclint 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 include DOC and remove DAR aligns with the PR objective of replacing darglint with pydoclint. 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) and flake8-annotations (to 3.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 to pydoclint looks good as it aligns with the PR objective of replacing the outdated darglint 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 monitor pydoclint'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. Running flake8 on the xrpl, tests, and snippets 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 the lint 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 the lint 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 to isinstance(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 the is_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 the Any type annotation in the is_dict_of_model method is justified and aligns with the project's coding practices. Here's why:

  1. The suppression is used consistently throughout the codebase for functions with Any type annotations, indicating a deliberate coding style choice.
  2. 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.
  3. The suppression is not overused, appearing only in specific scenarios where the Any type is required.
  4. 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 | uniq

Length 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 the Any type annotation on the length_hint parameter is a reasonable decision. It allows subclasses to define their own type requirements for length_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 the Any type annotation on the value parameter is a reasonable decision in this context. It allows the from_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 the Any type annotation on the return value of the to_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 the kwargs parameter is appropriate in this case. The directive indicates that the developer has intentionally chosen not to annotate kwargs 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 to isinstance(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 to not 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 rule ANN401 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 rule ANN401 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 using poetry 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 the flake8-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.

.github/workflows/unit_test.yml Show resolved Hide resolved
Copy link
Contributor

@coderabbitai coderabbitai bot left a 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 tasks

The updates to the test and test_coverage tasks are good improvements:

  1. The test task now uses python3 -m unittest ${FILE_PATHS}, which allows for more flexible test execution.
  2. 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 the test_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

📥 Commits

Files that changed from the base of the PR and between de85464 and 7f04b43.

⛔ 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 update

The 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 pydoclint

The introduction of pydoclint ^0.5.7 as a replacement for darglint 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 added

The addition of the lint task in the [tool.poe.tasks] section is a good improvement. It provides a convenient way to run flake8 on the project's main directories (xrpl, tests, and snippets). This change aligns with the PR objectives and should help streamline the linting process.


Line range hint 1-90: Summary of pyproject.toml changes

The changes in this file successfully achieve the main objectives of the PR:

  1. Replacing darglint with pydoclint.
  2. Updating various dependencies, including flake8 and flake8-annotations.
  3. Adding a new lint command in poe.
  4. 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:

  1. Verify compatibility with the updated linting tools.
  2. Clarify the reason for downgrading Sphinx.
  3. 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 Sphinx

The 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 tools

The updates to flake8 (^4.0.1 to ^7.0.0) and flake8-annotations (2.7.0 to 3.1.1) are significant version bumps. While these updates align with the PR objectives, please ensure that:

  1. The project's code is compatible with any new linting rules introduced in these versions.
  2. The CI/CD pipeline has been updated to accommodate these changes.
  3. The team is aware of any new warnings or errors that may arise from these updates.

Also applies to: 51-51

@mvadari mvadari changed the title chore: replace darglint with pydoclint refactor: replace darglint with pydoclint Oct 16, 2024
Copy link
Contributor

@coderabbitai coderabbitai bot left a 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

📥 Commits

Reviewing files that changed from the base of the PR and between 687fba8 and e671998.

⛔ 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:

  1. flake8 upgrade from 4.0.1 to 7.0.0 is a major version jump
  2. flake8-annotations update to 3.1.1
  3. 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

pyproject.toml Show resolved Hide resolved
Copy link
Contributor

@coderabbitai coderabbitai bot left a 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.
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between e671998 and 95e3681.

📒 Files selected for processing (1)
  • CONTRIBUTING.md (1 hunks)

Copy link
Contributor

@coderabbitai coderabbitai bot left a 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

📥 Commits

Reviewing files that changed from the base of the PR and between 95e3681 and 60c5cd4.

⛔ 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

Copy link
Collaborator

@ckeshava ckeshava left a 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
Copy link
Collaborator

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 ?

Copy link
Collaborator Author

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.

Copy link
Collaborator

Choose a reason for hiding this comment

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

hmmm

@mvadari
Copy link
Collaborator Author

mvadari commented Dec 9, 2024

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.

Those would be a replacement for flake8, not darglint.

@ckeshava
Copy link
Collaborator

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.

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 pylint project website:

Projects that you might want to use alongside pylint include ruff (really fast, with builtin auto-fix and a large number of checks taken from popular linters, but implemented in rust) or flake8 (a framework to implement your own checks in python using ast directly)

This appears to suggest that pylint and flake8 are complementary to each other.

@ckeshava
Copy link
Collaborator

Furthermore, I'm getting many DAR... errors from the linter on my local computer (I'm using Python 3.11).

xrpl-py-py3.11➜  xrpl-py git:(pydoclint) poetry run poe lint
Poe => poetry run flake8 xrpl tests snippets
xrpl/account/main.py:26:1: DAR402 Excess exception(s) in Raises section: +r XRPLRequestFailureException
xrpl/account/transaction_history.py:21:1: DAR402 Excess exception(s) in Raises section: +r XRPLRequestFailureException
xrpl/asyncio/clients/async_websocket_client.py:273:1: DAR101 Missing parameter(s) in Docstring: - timeout
xrpl/asyncio/clients/json_rpc_base.py:30:1: DAR003 Incorrect indentation: ~<
xrpl/asyncio/clients/websocket_base.py:207:1: DAR101 Missing parameter(s) in Docstring: - timeout
xrpl/asyncio/clients/websocket_base.py:214:1: DAR402 Excess exception(s) in Raises section: +r XRPLWebsocketException
xrpl/asyncio/transaction/main.py:191:1: DAR402 Excess exception(s) in Raises section: +r XRPLException
xrpl/asyncio/transaction/reliable_submission.py:31:1: DAR101 Missing parameter(s) in Docstring: - client
xrpl/asyncio/transaction/reliable_submission.py:31:1: DAR101 Missing parameter(s) in Docstring: - last_ledger_sequence
xrpl/asyncio/transaction/reliable_submission.py:31:1: DAR101 Missing parameter(s) in Docstring: - prelim_result
xrpl/asyncio/transaction/reliable_submission.py:31:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/asyncio/transaction/reliable_submission.py:31:1: DAR101 Missing parameter(s) in Docstring: - transaction_hash
xrpl/asyncio/transaction/reliable_submission.py:31:1: DAR401 Missing exception(s) in Raises section: -r XRPLReliableSubmissionException
xrpl/asyncio/transaction/reliable_submission.py:31:1: DAR401 Missing exception(s) in Raises section: -r XRPLRequestFailureException
xrpl/clients/websocket_client.py:212:1: DAR101 Missing parameter(s) in Docstring: - timeout
xrpl/core/addresscodec/codec.py:37:1: DAR101 Missing parameter(s) in Docstring: - bytestring
xrpl/core/addresscodec/codec.py:37:1: DAR101 Missing parameter(s) in Docstring: - expected_length
xrpl/core/addresscodec/codec.py:37:1: DAR101 Missing parameter(s) in Docstring: - prefix
xrpl/core/addresscodec/codec.py:37:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/addresscodec/codec.py:37:1: DAR401 Missing exception(s) in Raises section: -r XRPLAddressCodecException
xrpl/core/addresscodec/codec.py:52:1: DAR401 Missing exception(s) in Raises section: -r XRPLAddressCodecException
xrpl/core/addresscodec/main.py:150:1: DAR401 Missing exception(s) in Raises section: -r XRPLAddressCodecException
xrpl/core/binarycodec/binary_wrappers/binary_parser.py:35:1: DAR101 Missing parameter(s) in Docstring: - hex_bytes
xrpl/core/binarycodec/binary_wrappers/binary_parser.py:39:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/binary_wrappers/binary_parser.py:135:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/binary_wrappers/binary_parser.py:135:1: DAR401 Missing exception(s) in Raises section: -r XRPLBinaryCodecException
xrpl/core/binarycodec/binary_wrappers/binary_serializer.py:22:1: DAR101 Missing parameter(s) in Docstring: - length
xrpl/core/binarycodec/binary_wrappers/binary_serializer.py:22:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/binary_wrappers/binary_serializer.py:22:1: DAR401 Missing exception(s) in Raises section: -r ValueError
xrpl/core/binarycodec/definitions/field_header.py:14:1: DAR101 Missing parameter(s) in Docstring: - field_code
xrpl/core/binarycodec/definitions/field_header.py:14:1: DAR101 Missing parameter(s) in Docstring: - type_code
xrpl/core/binarycodec/definitions/field_header.py:25:1: DAR101 Missing parameter(s) in Docstring: - other
xrpl/core/binarycodec/definitions/field_header.py:25:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/definitions/field_header.py:31:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/definitions/field_header.py:56:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/definitions/field_info.py:20:1: DAR101 Missing parameter(s) in Docstring: - is_serialized
xrpl/core/binarycodec/definitions/field_info.py:20:1: DAR101 Missing parameter(s) in Docstring: - is_signing_field
xrpl/core/binarycodec/definitions/field_info.py:20:1: DAR101 Missing parameter(s) in Docstring: - is_variable_length_encoded
xrpl/core/binarycodec/definitions/field_info.py:20:1: DAR101 Missing parameter(s) in Docstring: - nth
xrpl/core/binarycodec/definitions/field_info.py:20:1: DAR101 Missing parameter(s) in Docstring: - type_name
xrpl/core/binarycodec/definitions/field_instance.py:46:1: DAR101 Missing parameter(s) in Docstring: - field_header
xrpl/core/binarycodec/definitions/field_instance.py:46:1: DAR101 Missing parameter(s) in Docstring: - field_info
xrpl/core/binarycodec/definitions/field_instance.py:46:1: DAR101 Missing parameter(s) in Docstring: - field_name
xrpl/core/binarycodec/field_id_codec.py:42:1: DAR101 Missing parameter(s) in Docstring: - field_header
xrpl/core/binarycodec/field_id_codec.py:42:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/field_id_codec.py:42:1: DAR401 Missing exception(s) in Raises section: -r XRPLBinaryCodecException
xrpl/core/binarycodec/field_id_codec.py:82:1: DAR101 Missing parameter(s) in Docstring: - field_id
xrpl/core/binarycodec/field_id_codec.py:82:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/field_id_codec.py:82:1: DAR401 Missing exception(s) in Raises section: -r XRPLBinaryCodecException
xrpl/core/binarycodec/types/account_id.py:35:1: DAR101 Missing parameter(s) in Docstring: - buffer
xrpl/core/binarycodec/types/amount.py:111:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/amount.py:111:1: DAR101 Missing parameter(s) in Docstring: - value
xrpl/core/binarycodec/types/amount.py:123:1: DAR101 Missing parameter(s) in Docstring: - decimal
xrpl/core/binarycodec/types/amount.py:123:1: DAR401 Missing exception(s) in Raises section: -r XRPLBinaryCodecException
xrpl/core/binarycodec/types/amount.py:141:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/amount.py:141:1: DAR101 Missing parameter(s) in Docstring: - value
xrpl/core/binarycodec/types/amount.py:141:1: DAR401 Missing exception(s) in Raises section: -r XRPLBinaryCodecException
xrpl/core/binarycodec/types/amount.py:227:1: DAR101 Missing parameter(s) in Docstring: - buffer
xrpl/core/binarycodec/types/blob.py:24:1: DAR101 Missing parameter(s) in Docstring: - buffer
xrpl/core/binarycodec/types/currency.py:17:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/currency.py:17:1: DAR101 Missing parameter(s) in Docstring: - value
xrpl/core/binarycodec/types/currency.py:34:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/currency.py:34:1: DAR101 Missing parameter(s) in Docstring: - value
xrpl/core/binarycodec/types/currency.py:39:1: DAR101 Missing parameter(s) in Docstring: - iso
xrpl/core/binarycodec/types/currency.py:39:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/currency.py:39:1: DAR401 Missing exception(s) in Raises section: -r XRPLBinaryCodecException
xrpl/core/binarycodec/types/currency.py:78:1: DAR101 Missing parameter(s) in Docstring: - buffer
xrpl/core/binarycodec/types/hash.py:24:1: DAR401 Missing exception(s) in Raises section: -r XRPLBinaryCodecException
xrpl/core/binarycodec/types/hash.py:40:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/hash128.py:25:1: DAR401 Missing exception(s) in Raises section: -r XRPLBinaryCodecException
xrpl/core/binarycodec/types/hash128.py:45:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/path_set.py:28:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/path_set.py:28:1: DAR101 Missing parameter(s) in Docstring: - value
xrpl/core/binarycodec/types/path_set.py:33:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/path_set.py:33:1: DAR101 Missing parameter(s) in Docstring: - value
xrpl/core/binarycodec/types/uint.py:21:1: DAR101 Missing parameter(s) in Docstring: - buffer
xrpl/core/binarycodec/types/uint.py:35:1: DAR101 Missing parameter(s) in Docstring: - other
xrpl/core/binarycodec/types/uint.py:35:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/uint.py:35:1: DAR401 Missing exception(s) in Raises section: -r XRPLBinaryCodecException
xrpl/core/binarycodec/types/uint.py:43:1: DAR101 Missing parameter(s) in Docstring: - other
xrpl/core/binarycodec/types/uint.py:43:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/uint.py:43:1: DAR401 Missing exception(s) in Raises section: -r XRPLBinaryCodecException
xrpl/core/binarycodec/types/uint.py:51:1: DAR101 Missing parameter(s) in Docstring: - other
xrpl/core/binarycodec/types/uint.py:51:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/uint.py:51:1: DAR401 Missing exception(s) in Raises section: -r XRPLBinaryCodecException
xrpl/core/binarycodec/types/uint.py:59:1: DAR101 Missing parameter(s) in Docstring: - other
xrpl/core/binarycodec/types/uint.py:59:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/uint.py:59:1: DAR401 Missing exception(s) in Raises section: -r XRPLBinaryCodecException
xrpl/core/binarycodec/types/uint.py:67:1: DAR101 Missing parameter(s) in Docstring: - other
xrpl/core/binarycodec/types/uint.py:67:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/uint.py:67:1: DAR401 Missing exception(s) in Raises section: -r XRPLBinaryCodecException
xrpl/core/binarycodec/types/uint.py:75:1: DAR101 Missing parameter(s) in Docstring: - other
xrpl/core/binarycodec/types/uint.py:75:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/binarycodec/types/uint.py:75:1: DAR401 Missing exception(s) in Raises section: -r XRPLBinaryCodecException
xrpl/core/binarycodec/types/uint16.py:24:1: DAR101 Missing parameter(s) in Docstring: - buffer
xrpl/core/binarycodec/types/uint32.py:25:1: DAR101 Missing parameter(s) in Docstring: - buffer
xrpl/core/binarycodec/types/uint64.py:29:1: DAR101 Missing parameter(s) in Docstring: - buffer
xrpl/core/binarycodec/types/uint8.py:26:1: DAR101 Missing parameter(s) in Docstring: - buffer
xrpl/core/binarycodec/types/vector256.py:21:1: DAR101 Missing parameter(s) in Docstring: - buffer
xrpl/core/binarycodec/types/xchain_bridge.py:29:1: DAR101 Missing parameter(s) in Docstring: - buffer
xrpl/core/keypairs/main.py:40:1: DAR402 Excess exception(s) in Raises section: +r XRPLAddressCodecException
xrpl/core/keypairs/secp256k1.py:150:1: DAR101 Missing parameter(s) in Docstring: - bytes_input
xrpl/core/keypairs/secp256k1.py:150:1: DAR101 Missing parameter(s) in Docstring: - phase
xrpl/core/keypairs/secp256k1.py:150:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/keypairs/secp256k1.py:184:1: DAR101 Missing parameter(s) in Docstring: - candidate_merger
xrpl/core/keypairs/secp256k1.py:184:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/core/keypairs/secp256k1.py:184:1: DAR401 Missing exception(s) in Raises section: -r XRPLKeypairsException
xrpl/ledger/main.py:20:1: DAR402 Excess exception(s) in Raises section: +r XRPLRequestFailureException
xrpl/ledger/main.py:36:1: DAR402 Excess exception(s) in Raises section: +r XRPLRequestFailureException
xrpl/ledger/main.py:62:1: DAR402 Excess exception(s) in Raises section: +r XRPLException
xrpl/ledger/main.py:63:1: DAR402 Excess exception(s) in Raises section: +r XRPLRequestFailureException
xrpl/models/base_model.py:51:1: DAR101 Missing parameter(s) in Docstring: - field
xrpl/models/base_model.py:51:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/models/base_model.py:155:1: DAR101 Missing parameter(s) in Docstring: - param
xrpl/models/base_model.py:155:1: DAR101 Missing parameter(s) in Docstring: - param_type
xrpl/models/base_model.py:155:1: DAR101 Missing parameter(s) in Docstring: - param_value
xrpl/models/base_model.py:155:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/models/base_model.py:155:1: DAR401 Missing exception(s) in Raises section: -r XRPLModelException
xrpl/models/base_model.py:339:1: DAR101 Missing parameter(s) in Docstring: - other
xrpl/models/base_model.py:339:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/models/base_model.py:343:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/models/nested_model.py:59:1: DAR402 Excess exception(s) in Raises section: +r XRPLModelException
xrpl/models/requests/submit.py:76:1: DAR402 Excess exception(s) in Raises section: +r XRPLModelException
xrpl/models/transactions/transaction.py:47:1: DAR101 Missing parameter(s) in Docstring: - key
xrpl/models/transactions/transaction.py:47:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/models/transactions/transaction.py:290:1: DAR101 Missing parameter(s) in Docstring: - lst
xrpl/models/transactions/transaction.py:290:1: DAR201 Missing "Returns" in Docstring: - return
xrpl/transaction/main.py:62:1: DAR402 Excess exception(s) in Raises section: +r XRPLRequestFailureException
xrpl/wallet/main.py:47:1: DAR401 Missing exception(s) in Raises section: -r XRPLAddressCodecException

I am using this PR branch and I verified that there are no darglint references in the codebase.

@mvadari
Copy link
Collaborator Author

mvadari commented Dec 10, 2024

Furthermore, I'm getting many DAR... errors from the linter on my local computer (I'm using Python 3.11).

Did you run poetry install first to get the new set of packages?

@mvadari
Copy link
Collaborator Author

mvadari commented Dec 10, 2024

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 pylint project website:

Projects that you might want to use alongside pylint include ruff (really fast, with builtin auto-fix and a large number of checks taken from popular linters, but implemented in rust) or flake8 (a framework to implement your own checks in python using ast directly)

This appears to suggest that pylint and flake8 are complementary to each other.

pylint might be a replacement for black. Regardless, it definitely doesn't solve the problem that pydoclint solves.

@ckeshava
Copy link
Collaborator

Furthermore, I'm getting many DAR... errors from the linter on my local computer (I'm using Python 3.11).

Did you run poetry install first to get the new set of packages?

Yes, I got the following successful response:

xrpl-py-py3.11➜  xrpl-py git:(pydoclint) ✗ poetry install
Updating dependencies
Resolving dependencies... (7.8s)

Package operations: 0 installs, 3 updates, 0 removals

  - Updating certifi (2024.8.30 -> 2024.12.14)
  - Updating attrs (24.2.0 -> 24.3.0)
  - Updating pydoclint (0.5.7 -> 0.5.11)

Writing lock file

Installing the current project: xrpl-py (4.0.0)

However, the previous error persists on my local machine. I'm wondering if I need to update any other files/folder.

poetry install produces a poetry.lock file different from your PR. Newer updates to the dependency tree could cause this change, but it's still pretty suspicious.

per-file-ignores =
# For tests, disable type annotation and docstring linting.
tests/*: ANN D DAR
tests/*: ANN D DOC

Copy link
Collaborator

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

Copy link
Collaborator

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.

Copy link
Collaborator Author

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

Copy link
Collaborator

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

Copy link
Collaborator Author

@mvadari mvadari Dec 20, 2024

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 % 

Copy link
Collaborator

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.

Copy link
Contributor

@coderabbitai coderabbitai bot left a 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

📥 Commits

Reviewing files that changed from the base of the PR and between d28ae27 and b30d6bf.

⛔ 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

pyproject.toml Show resolved Hide resolved
pyproject.toml Show resolved Hide resolved
@mvadari mvadari requested a review from ckeshava January 2, 2025 23:19
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.

Replace darglint docstring linter
2 participants