Refactor client.py to reduce file size by 95%#24
Conversation
Remove kwargs passthrough to execute() to prevent HTTP client errors. Update convenience methods to only pass expected parameters. Update test to match new behavior where kwargs are not passed through.
Add 'reopened' to PR event types and condition check
|
Claude finished @knowlen's task —— View job PR Code ReviewThis is an impressive refactoring that successfully reduces Review Tasks:
✅ Strengths1. Excellent Architecture Design
2. Strong Backward Compatibility
3. Code Quality Improvements
4. Comprehensive Testing
|
|
Thank you for the thorough review @claude! I'll address the high priority issues: High Priority Fixes1. Type SafetyI'll fix the type checking issues by:
2. Error MessagesI'll improve error messages to show:
3. Method Registration DocumentationI'll add clear documentation explaining:
I'll also cache the regex patterns for performance as suggested in the medium priority items. Working on these fixes now... |
- Add Protocol for type safety with model_validate method - Cache regex patterns for performance improvement - Improve error messages to show available parameters - Add comprehensive documentation for method registration - Fix type annotations to satisfy mypy
Review Feedback Addressed ✅I've implemented all high-priority fixes suggested by @claude: 1. Type Safety (Fixed)
2. Error Messages (Improved)
3. Method Registration Documentation (Added)
4. Performance (Optimized)
All unit tests passing (105/105) ✅ The medium and low priority items can be addressed in follow-up PRs if needed. |
|
Claude finished @knowlen's task —— View job ✅ High-Priority Fixes Successfully VerifiedExcellent work! I've thoroughly reviewed the updated code and can confirm all high-priority fixes have been properly implemented: Todo List:
🎯 Verification Results1. Type Safety ✅ FULLY ADDRESSED
2. Error Messages ✅ SIGNIFICANTLY IMPROVED
3. Documentation ✅ COMPREHENSIVE
4. Performance ✅ OPTIMIZED
5. Test Coverage ✅ EXCELLENT
🏆 Overall AssessmentThe follow-up implementation is exemplary. All suggested improvements have been implemented with attention to detail:
The code quality has been significantly elevated while maintaining the excellent architectural foundation. This represents a mature, production-ready implementation. Status: ✅ All High-Priority Issues Successfully Resolved |
- Fix markdown formatting in architecture.md for proper rendering - Update test counts from 278 to 310 tests (105 unit tests) - Update project structure to reflect new modular architecture - Add method_factory.py and param_builders.py to unit test docs - Document new mixins directory structure
Update version across all project files: - pyproject.toml - esologs/__init__.py - README.md - CLAUDE.md - docs/index.md - docs/changelog.md (with release notes) - docs/development/architecture.md
* Refactor client.py to reduce file size by 95% (#24) * Reorganize generated code into _generated subdirectory * Fix remaining test imports for ValidationError and generated modules * Suppress websockets deprecation warnings from generated code * Refactor client.py using factory patterns and mixins * Fix test failures in refactored client * Fix remaining test failures and add UNSET export for backward compatibility * Update documentation to reflect client refactoring * Fix type annotations and pre-commit issues * Remove client_save.py backup file * Fix all mypy type errors for pre-commit compliance * Fix kwargs passthrough issue in report methods Remove kwargs passthrough to execute() to prevent HTTP client errors. Update convenience methods to only pass expected parameters. Update test to match new behavior where kwargs are not passed through. * Add dev branch to CI/CD workflow triggers * Trigger Claude Code Review [review] * Remove Claude review trigger file * Allow manual triggering of Claude Code Review workflow * Fix Claude review workflow to support reopened PRs [review] Add 'reopened' to PR event types and condition check * Address high-priority reviewer feedback - Add Protocol for type safety with model_validate method - Cache regex patterns for performance improvement - Improve error messages to show available parameters - Add comprehensive documentation for method registration - Fix type annotations to satisfy mypy * Update documentation for refactored architecture - Fix markdown formatting in architecture.md for proper rendering - Update test counts from 278 to 310 tests (105 unit tests) - Update project structure to reflect new modular architecture - Add method_factory.py and param_builders.py to unit test docs - Document new mixins directory structure * fix formatting * Bump version to 0.2.0a3 Update version across all project files: - pyproject.toml - esologs/__init__.py - README.md - CLAUDE.md - docs/index.md - docs/changelog.md (with release notes) - docs/development/architecture.md --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com> * Implement guild data endpoints - Add 4 new guild methods: get_guilds(), get_guild(), get_guild_attendance(), get_guild_members() - Create GraphQL queries for guild search, lookup, attendance, and members - Add parameter builder for guild attendance with proper defaults - Implement flexible get_guild() method supporting ID or name/server lookup - Add comprehensive unit tests (12 new tests) - Add integration tests (10 new tests) - Update guild-data.md documentation with examples for all new methods - Update API coverage from ~83% to ~90% (37/41 methods) * Fix unit test mocking for httpx.Response objects * Fix UNSET import in test_character_rankings.py * Address reviewer comments: fix self type annotation and import location * Fix guild documentation examples and add comprehensive tests * Convert relative imports to absolute imports for better maintainability * Add retry logic and resilience features for integration tests and API clients * Replace pilcrow (¶) with hash (#) for anchor links in documentation * Fix pytest configuration for retry logic in integration and docs tests --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com>
* Refactor client.py to reduce file size by 95% (#24) * Reorganize generated code into _generated subdirectory * Fix remaining test imports for ValidationError and generated modules * Suppress websockets deprecation warnings from generated code * Refactor client.py using factory patterns and mixins * Fix test failures in refactored client * Fix remaining test failures and add UNSET export for backward compatibility * Update documentation to reflect client refactoring * Fix type annotations and pre-commit issues * Remove client_save.py backup file * Fix all mypy type errors for pre-commit compliance * Fix kwargs passthrough issue in report methods Remove kwargs passthrough to execute() to prevent HTTP client errors. Update convenience methods to only pass expected parameters. Update test to match new behavior where kwargs are not passed through. * Add dev branch to CI/CD workflow triggers * Trigger Claude Code Review [review] * Remove Claude review trigger file * Allow manual triggering of Claude Code Review workflow * Fix Claude review workflow to support reopened PRs [review] Add 'reopened' to PR event types and condition check * Address high-priority reviewer feedback - Add Protocol for type safety with model_validate method - Cache regex patterns for performance improvement - Improve error messages to show available parameters - Add comprehensive documentation for method registration - Fix type annotations to satisfy mypy * Update documentation for refactored architecture - Fix markdown formatting in architecture.md for proper rendering - Update test counts from 278 to 310 tests (105 unit tests) - Update project structure to reflect new modular architecture - Add method_factory.py and param_builders.py to unit test docs - Document new mixins directory structure * fix formatting * Bump version to 0.2.0a3 Update version across all project files: - pyproject.toml - esologs/__init__.py - README.md - CLAUDE.md - docs/index.md - docs/changelog.md (with release notes) - docs/development/architecture.md --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com> * feat: Implement comprehensive guild data API endpoints (5 methods) (#27) * Implement guild data endpoints - Add 4 new guild methods: get_guilds(), get_guild(), get_guild_attendance(), get_guild_members() - Create GraphQL queries for guild search, lookup, attendance, and members - Add parameter builder for guild attendance with proper defaults - Implement flexible get_guild() method supporting ID or name/server lookup - Add comprehensive unit tests (12 new tests) - Add integration tests (10 new tests) - Update guild-data.md documentation with examples for all new methods - Update API coverage from ~83% to ~90% (37/41 methods) * Fix unit test mocking for httpx.Response objects * Fix UNSET import in test_character_rankings.py * Address reviewer comments: fix self type annotation and import location * Fix guild documentation examples and add comprehensive tests * Convert relative imports to absolute imports for better maintainability * Add retry logic and resilience features for integration tests and API clients * Replace pilcrow (¶) with hash (#) for anchor links in documentation * Fix pytest configuration for retry logic in integration and docs tests * Update README files to reflect current project status and guild endpoints * Fix API coverage metrics: guild endpoints provide ~88% coverage (37/42 methods) * Address reviewer feedback: fix import consistency and document validation strategy --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com> * Add progress race tracking API endpoint (#28) * Add progress race tracking API endpoint with 90% coverage * Fix progress race tests to handle 'No race supported' GraphQL errors * Update README files to reflect current project status with 90% API coverage * Add OAuth2 user authentication and UserData API methods (#29) * Add OAuth2 user authentication and UserData API methods * Fix type checking and linting issues * Add missing test dependencies (responses, pytest-xdist) * Add mkdocs to dev dependencies for complete test coverage * Fix test dependencies and user auth warnings - Add mkdocs-material and mkdocs-minify-plugin to dev dependencies - Fix user authentication warnings in test_user_data.py by using user_token parameter - Ensure all documentation build dependencies are available for tests * Consolidate docs dependencies in dev extras * fix precommit checks * Implement async OAuth2 support and address PR review concerns * Remove duplicate API status JavaScript files * Remove redundant scripts and add token files to gitignore * Remove redundant optimize_images_simple.py script * Add README.md documentation for scripts directory * Add README.md documentation for examples directory * Update README with output examples and current project state * Update README: remove NEW tags, normalize output formatting, add missing directories to project structure * Fix pre-commit checks: remove trailing whitespace and update formatting --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com> * Fix API status checker false positives by using correct favicon URL (#30) Co-authored-by: knowlen <knowlen@users.noreply.github.com> * Remove API status checker and improve documentation (#31) * Remove unreliable API status checker and add troubleshooting guide * Move troubleshooting to Getting Started section * Reorganize documentation structure for better navigation * Fix markdown formatting in authentication guide * Fix list formatting in authentication guide * Fix changelog - mark 0.2.0a3 as unreleased and correct dates * Address PR review comments - add OAuth2 error handling and fix Twitter handle * fix dates * Remove non-existent status.esologs.com references and fix future dates --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com> * Prepare v0.2.0b1 beta release * Add release branch verification workflow * Update README * moved to docs * Fix API method signatures in README to match implementation * Add return type information to API method documentation * Replace return type sub-bullets with documentation links * test formatting * Update API method documentation to use method names as links * Refine API docs: only method names are links, parameters are separate code snippets * Simplify API method list by removing parameters * clean up * formatting * formatting * formatting * formatting * formatting --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com>
* Release v0.2.0b1 - First Beta Release (#32) * Refactor client.py to reduce file size by 95% (#24) * Reorganize generated code into _generated subdirectory * Fix remaining test imports for ValidationError and generated modules * Suppress websockets deprecation warnings from generated code * Refactor client.py using factory patterns and mixins * Fix test failures in refactored client * Fix remaining test failures and add UNSET export for backward compatibility * Update documentation to reflect client refactoring * Fix type annotations and pre-commit issues * Remove client_save.py backup file * Fix all mypy type errors for pre-commit compliance * Fix kwargs passthrough issue in report methods Remove kwargs passthrough to execute() to prevent HTTP client errors. Update convenience methods to only pass expected parameters. Update test to match new behavior where kwargs are not passed through. * Add dev branch to CI/CD workflow triggers * Trigger Claude Code Review [review] * Remove Claude review trigger file * Allow manual triggering of Claude Code Review workflow * Fix Claude review workflow to support reopened PRs [review] Add 'reopened' to PR event types and condition check * Address high-priority reviewer feedback - Add Protocol for type safety with model_validate method - Cache regex patterns for performance improvement - Improve error messages to show available parameters - Add comprehensive documentation for method registration - Fix type annotations to satisfy mypy * Update documentation for refactored architecture - Fix markdown formatting in architecture.md for proper rendering - Update test counts from 278 to 310 tests (105 unit tests) - Update project structure to reflect new modular architecture - Add method_factory.py and param_builders.py to unit test docs - Document new mixins directory structure * fix formatting * Bump version to 0.2.0a3 Update version across all project files: - pyproject.toml - esologs/__init__.py - README.md - CLAUDE.md - docs/index.md - docs/changelog.md (with release notes) - docs/development/architecture.md --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com> * feat: Implement comprehensive guild data API endpoints (5 methods) (#27) * Implement guild data endpoints - Add 4 new guild methods: get_guilds(), get_guild(), get_guild_attendance(), get_guild_members() - Create GraphQL queries for guild search, lookup, attendance, and members - Add parameter builder for guild attendance with proper defaults - Implement flexible get_guild() method supporting ID or name/server lookup - Add comprehensive unit tests (12 new tests) - Add integration tests (10 new tests) - Update guild-data.md documentation with examples for all new methods - Update API coverage from ~83% to ~90% (37/41 methods) * Fix unit test mocking for httpx.Response objects * Fix UNSET import in test_character_rankings.py * Address reviewer comments: fix self type annotation and import location * Fix guild documentation examples and add comprehensive tests * Convert relative imports to absolute imports for better maintainability * Add retry logic and resilience features for integration tests and API clients * Replace pilcrow (¶) with hash (#) for anchor links in documentation * Fix pytest configuration for retry logic in integration and docs tests * Update README files to reflect current project status and guild endpoints * Fix API coverage metrics: guild endpoints provide ~88% coverage (37/42 methods) * Address reviewer feedback: fix import consistency and document validation strategy --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com> * Add progress race tracking API endpoint (#28) * Add progress race tracking API endpoint with 90% coverage * Fix progress race tests to handle 'No race supported' GraphQL errors * Update README files to reflect current project status with 90% API coverage * Add OAuth2 user authentication and UserData API methods (#29) * Add OAuth2 user authentication and UserData API methods * Fix type checking and linting issues * Add missing test dependencies (responses, pytest-xdist) * Add mkdocs to dev dependencies for complete test coverage * Fix test dependencies and user auth warnings - Add mkdocs-material and mkdocs-minify-plugin to dev dependencies - Fix user authentication warnings in test_user_data.py by using user_token parameter - Ensure all documentation build dependencies are available for tests * Consolidate docs dependencies in dev extras * fix precommit checks * Implement async OAuth2 support and address PR review concerns * Remove duplicate API status JavaScript files * Remove redundant scripts and add token files to gitignore * Remove redundant optimize_images_simple.py script * Add README.md documentation for scripts directory * Add README.md documentation for examples directory * Update README with output examples and current project state * Update README: remove NEW tags, normalize output formatting, add missing directories to project structure * Fix pre-commit checks: remove trailing whitespace and update formatting --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com> * Fix API status checker false positives by using correct favicon URL (#30) Co-authored-by: knowlen <knowlen@users.noreply.github.com> * Remove API status checker and improve documentation (#31) * Remove unreliable API status checker and add troubleshooting guide * Move troubleshooting to Getting Started section * Reorganize documentation structure for better navigation * Fix markdown formatting in authentication guide * Fix list formatting in authentication guide * Fix changelog - mark 0.2.0a3 as unreleased and correct dates * Address PR review comments - add OAuth2 error handling and fix Twitter handle * fix dates * Remove non-existent status.esologs.com references and fix future dates --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com> * Prepare v0.2.0b1 beta release * Add release branch verification workflow * Update README * moved to docs * Fix API method signatures in README to match implementation * Add return type information to API method documentation * Replace return type sub-bullets with documentation links * test formatting * Update API method documentation to use method names as links * Refine API docs: only method names are links, parameters are separate code snippets * Simplify API method list by removing parameters * clean up * formatting * formatting * formatting * formatting * formatting --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com> * fix * fix * fix * fix * Fix test count inconsistencies across documentation (#44) * Fix test count inconsistencies - update to 428 tests * Fix Test Pyramid Structure diagram with correct test counts --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com> * Update documentation for v0.2.0b1 beta release (#45) Co-authored-by: knowlen <knowlen@users.noreply.github.com> * Fix enum documentation accuracy and improve Advanced Usage formatting (#46) * docs: add Enums reference and Advanced Usage guide with filter expressions * fix: ensure proper list rendering in enums documentation * fix: correct relative links in enums documentation * Fix enum documentation links and add enum hyperlinks to parameter tables - Fixed broken links in enums.md that pointed to report-data instead of report-analysis - Added hyperlinks to enum types in character-data.md parameter tables - Added hyperlinks to enum types in report-analysis.md parameter tables - All enum references in API documentation now link to their definitions * Fix enum documentation accuracy and improve Advanced Usage formatting * Add Serena MCP cache files to .gitignore * Remove Serena cache files from version control * delete testfiles * Remove all Serena files from version control and ignore entire .serena directory * Fix enum documentation to match actual implementation values * Clarify why some enums aren't exposed - they're used by Zone.characterRankings which isn't a top-level API method * Add documentation for direct GraphQL access and explain nested field limitations * Fix incorrect GraphQL field reference: Zone.characterRankings → Encounter.characterRankings * remove this * Move Direct GraphQL Access to Getting Started section and remove Advanced Topics * simplify --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com> * Fix broken documentation links in README (#49) authored-by: knowlen <knowlen@users.noreply.github.com> * Create claude-dispatch.yml (#50) * Create claude-dispatch.yml * Fix trailing whitespace in workflow file --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com> --------- Co-authored-by: knowlen <knowlen@users.noreply.github.com>
Summary
Changes
Extracted method factory functions (
method_factory.py- 349 lines)create_simple_getterfor ID-based queriescreate_no_params_getterfor parameterless queriescreate_paginated_getterfor paginated queriescreate_complex_methodfor methods with many parameterscreate_method_with_builderfor methods using parameter buildersCreated parameter builders (
param_builders.py- 330 lines)Implemented mixin architecture (
mixins/- 5 files)GameDataMixin- abilities, items, classes, NPCs, etc.CharacterMixin- character data and rankingsWorldDataMixin- zones, regions, encountersGuildMixin- guild informationReportMixin- report search and analysisCentralized GraphQL queries (
queries.py- 770 lines)Technical Details
__init_subclass__hook for automatic method registrationTesting
Backward Compatibility
Performance