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

NXDRIVE-2967: Upgrade the deprecated datetime adapter.. #5445

Open
wants to merge 15 commits into
base: wip-NXDRIVE-2929-upgrade-python-from-3.9.5-to-3.12.3
Choose a base branch
from

Conversation

gitofanindya
Copy link
Collaborator

@gitofanindya gitofanindya commented Nov 19, 2024

Summary by Sourcery

Upgrade dependencies and improve datetime handling. Update the macOS release workflow to use a .p12 certificate format. Remove deprecated datetime adapter warnings from tests.

Enhancements:

  • Upgrade various dependencies including pycparser, pyobjc-core, pyobjc-frameworks, python-dateutil, requests, send2trash, and watchdog to their latest versions.

CI:

  • Modify the macOS release workflow to use a .p12 certificate format for developer ID application.

Documentation:

  • Update the changelog to include new changes and upgrades.

Tests:

  • Remove deprecated datetime adapter warnings from test configurations.

Copy link
Contributor

sourcery-ai bot commented Nov 19, 2024

Reviewer's Guide by Sourcery

This PR updates several dependencies to their latest versions and fixes timezone-related issues in datetime handling. The main changes include upgrading Python packages, addressing security vulnerabilities, and implementing a fix for zero-byte file handling.

Sequence diagram for zero-byte file handling

sequenceDiagram
    participant FoldersDialog
    participant Path
    FoldersDialog->>Path: get_size(file_path)
    Path-->>FoldersDialog: file_size
    alt file_size == 0
        FoldersDialog->>FoldersDialog: Ignore zero-byte file
    else file_size > 0
        FoldersDialog->>FoldersDialog: Add file to paths
    end
Loading

Class diagram for updated datetime handling

classDiagram
    class AutoRetryCursor {
        +adapt_datetime_iso(val)
        +execute(sql: str, parameters: Iterable[Any])
    }
    note for AutoRetryCursor "Updated to handle datetime with timezone awareness using adapt_datetime_iso method"
Loading

File-Level Changes

Change Details Files
Updated multiple Python package dependencies to their latest versions
  • Upgraded cryptography from 42.0.5 to 43.0.1 to address security vulnerabilities
  • Upgraded requests from 2.31.0 to 2.32.3
  • Upgraded watchdog from 3.0.0 to 5.0.2
  • Upgraded python-dateutil from 2.8.2 to 2.9.0.post0
  • Updated various PyObjC frameworks from 10.1 to 10.3.1
tools/deps/requirements.txt
docs/changes/5.5.1.md
Modified datetime handling to use explicit timezone information
  • Added timezone.utc to datetime conversions
  • Implemented datetime adapter for SQLite operations
  • Fixed timestamp conversions in file information retrieval
nxdrive/dao/base.py
nxdrive/client/local/base.py
Added zero-byte file handling in the upload process
  • Added method to get file size
  • Implemented checks to ignore zero-byte files during upload
  • Updated file processing logic to skip zero-byte files
nxdrive/gui/folders_dialog.py
Updated macOS certificate handling for deployment
  • Changed certificate file extension from .cer to .p12
  • Updated certificate import command in deployment script
.github/workflows/release.yml
tools/osx/deploy_ci_agent.sh

Tips and commands

Interacting with Sourcery

  • Trigger a new review: Comment @sourcery-ai review on the pull request.
  • Continue discussions: Reply directly to Sourcery's review comments.
  • Generate a GitHub issue from a review comment: Ask Sourcery to create an
    issue from a review comment by replying to it.
  • Generate a pull request title: Write @sourcery-ai anywhere in the pull
    request title to generate a title at any time.
  • Generate a pull request summary: Write @sourcery-ai summary anywhere in
    the pull request body to generate a PR summary at any time. You can also use
    this command to specify where the summary should be inserted.

Customizing Your Experience

Access your dashboard to:

  • Enable or disable review features such as the Sourcery-generated pull request
    summary, the reviewer's guide, and others.
  • Change the review language.
  • Add, remove or edit custom review instructions.
  • Adjust other review settings.

Getting Help

Copy link
Contributor

@sourcery-ai sourcery-ai bot left a comment

Choose a reason for hiding this comment

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

Hey @gitofanindya - I've reviewed your changes and they look great!

Here's what I looked at during the review
  • 🟡 General issues: 5 issues found
  • 🟢 Security: all looks good
  • 🟢 Testing: all looks good
  • 🟢 Complexity: all looks good
  • 🟢 Documentation: all looks good

Sourcery is free for open source - if you like our reviews please consider sharing them ✨
Help me be more useful! Please click 👍 or 👎 on each comment and I'll use the feedback to improve your reviews.

def execute(self, sql: str, parameters: Iterable[Any] = ()) -> Cursor:
count = 1
while True:
count += 1
try:
return super().execute(sql, parameters)
import sqlite3
# return super().execute(sql, parameters)
Copy link
Contributor

Choose a reason for hiding this comment

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

issue: The datetime parameter conversion logic should be simplified and the original super().execute() call restored

The current implementation with register_adapter could have unintended side effects. Consider moving the datetime conversion to a separate method and maintaining the original execution flow.

@@ -624,6 +624,9 @@ def _files_display(self) -> str:
txt += f" (+{self.overall_count - 1:,})"
return txt

def get_size(self, file_path: Path) -> bool:
Copy link
Contributor

Choose a reason for hiding this comment

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

issue (bug_risk): Return type hint is incorrect - method returns an integer not a boolean

@@ -647,10 +650,17 @@ def _process_additionnal_local_paths(self, paths: List[str], /) -> None:
# Save the path
if path.is_dir():
for file_path, size in get_tree_list(path):
if self.get_size(file_path) == 0:
Copy link
Contributor

Choose a reason for hiding this comment

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

suggestion (performance): Redundant size check - file size is already available from get_tree_list()

Consider using the size value already provided by get_tree_list() instead of calling get_size() again.

Suggested change
if self.get_size(file_path) == 0:
if size == 0:

except (ValueError, OverflowError, OSError) as e:
log.warning(
f"{e} file path: {os_path}. st_mtime value: {stat_info.st_mtime}"
)
mtime = datetime.utcfromtimestamp(0)
mtime = datetime.fromtimestamp(0, tz=timezone.utc)
Copy link
Contributor

Choose a reason for hiding this comment

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

suggestion: Error handling should use consistent timezone approach

Both the try and except blocks now use timezone-aware timestamps, but the error handling could be more consistent by using a common approach or constant for the fallback time.

Suggested change
mtime = datetime.fromtimestamp(0, tz=timezone.utc)
EPOCH = datetime(1970, 1, 1, tzinfo=timezone.utc)
mtime = EPOCH

else self.dao.get_dt_upload
if is_direct_transfer
else self.dao.get_upload
else self.dao.get_dt_upload if is_direct_transfer else self.dao.get_upload
Copy link
Contributor

Choose a reason for hiding this comment

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

suggestion: Nested ternary operator could be simplified for better readability

Consider using an if/elif/else block to make the logic more explicit and easier to maintain.

            else:
                if is_direct_transfer:
                    meth = self.dao.get_dt_upload
                else:
                    meth = self.dao.get_upload

Copy link

codecov bot commented Nov 19, 2024

Codecov Report

Attention: Patch coverage is 83.33333% with 2 lines in your changes missing coverage. Please review.

Project coverage is 52.06%. Comparing base (620f79a) to head (0582844).

Files with missing lines Patch % Lines
nxdrive/client/local/base.py 66.66% 1 Missing ⚠️
nxdrive/dao/base.py 83.33% 1 Missing ⚠️
Additional details and impacted files
@@                                   Coverage Diff                                    @@
##           wip-NXDRIVE-2929-upgrade-python-from-3.9.5-to-3.12.3    #5445      +/-   ##
========================================================================================
+ Coverage                                                 50.57%   52.06%   +1.48%     
========================================================================================
  Files                                                        96       96              
  Lines                                                     16116    16123       +7     
========================================================================================
+ Hits                                                       8151     8394     +243     
+ Misses                                                     7965     7729     -236     
Flag Coverage Δ
functional 42.85% <58.33%> (+<0.01%) ⬆️
integration 2.00% <0.00%> (-0.01%) ⬇️
unit 40.50% <75.00%> (+1.85%) ⬆️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@mr-shekhar
Copy link
Collaborator

@dependabot rebase

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants