Skip to content

fix: route INFO logs to stdout so PowerShell doesn't raise NativeCommandError (#303)#413

Open
jacalata wants to merge 2 commits into
developmentfrom
jac/fix-303-stderr-to-stdout
Open

fix: route INFO logs to stdout so PowerShell doesn't raise NativeCommandError (#303)#413
jacalata wants to merge 2 commits into
developmentfrom
jac/fix-303-stderr-to-stdout

Conversation

@jacalata

@jacalata jacalata commented Jul 2, 2026

Copy link
Copy Markdown
Contributor

Summary

  • Fixes Eventhough tabcmd command ran successfully throwing error in powershell #303
  • Root cause: logging.StreamHandler() defaults to stderr; PowerShell treats all native command stderr output as a NativeCommandError even when the command succeeds
  • Splits the single console handler into two: INFO and below → stdout, WARNING and above → stderr
  • Named filter function _below_warning replaces inline lambda for debuggability
  • Adds tests verifying the split: two handlers attached, correct stream binding, INFO→stdout only, WARNING→stderr only, ERROR→stderr only, no double-print from sibling loggers

Test plan

  • python -m pytest tests/commands/test_logger_config.py -v — 11 tests pass
  • In PowerShell: tabcmd --help completes without NativeCommandError
  • tabcmd login --bad-arg produces error output on stderr

🤖 Generated with Claude Code

jacalata and others added 2 commits July 1, 2026 18:17
…andError

Python's logging.StreamHandler defaults to sys.stderr. PowerShell treats
any stderr output from a native command as a NativeCommandError, so a
successful tabcmd run would trigger error handling in PS scripts.

Now INFO and below goes to stdout (normal output), while WARNING and above
stays on stderr (real errors remain distinguishable).

Closes #303

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
… function

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
@github-actions

github-actions Bot commented Jul 2, 2026

Copy link
Copy Markdown

Coverage

Coverage Report
FileStmtsMissCoverMissing
tabcmd
   __main__.py101010 0%
   tabcmd.py151515 0%
   version.py622 67%
tabcmd/commands
   commands.py101010 0%
   constants.py771818 77%
   server.py1351818 87%
tabcmd/commands/auth
   session.py3814646 88%
tabcmd/commands/datasources_and_workbooks
   datasources_and_workbooks_command.py1571818 89%
   datasources_workbooks_views_url_parser.py14255 96%
   delete_command.py601616 73%
   export_command.py1202525 79%
   get_url_command.py1274747 63%
   publish_command.py1232828 77%
   runschedule_command.py2177 67%
tabcmd/commands/extracts
   create_extracts_command.py4288 81%
   decrypt_extracts_command.py2722 93%
   delete_extracts_command.py3766 84%
   encrypt_extracts_command.py2722 93%
   extracts.py2022 90%
   reencrypt_extracts_command.py2722 93%
   refresh_extracts_command.py481010 79%
tabcmd/commands/group
   create_group_command.py2955 83%
   delete_group_command.py2722 93%
tabcmd/commands/project
   create_project_command.py4688 83%
   delete_project_command.py3544 89%
   publish_samples_command.py3044 87%
tabcmd/commands/site
   create_site_command.py3455 85%
   delete_site_command.py2722 93%
   edit_site_command.py3822 95%
   list_command.py771212 84%
   list_sites_command.py2922 93%
tabcmd/commands/user
   add_users_command.py2955 83%
   create_site_users.py581111 81%
   create_users_command.py601010 83%
   delete_site_users_command.py4355 88%
   user_data.py2213131 86%
tabcmd/execution
   _version.py222 0%
   global_options.py12588 94%
   localize.py661111 83%
   logger_config.py5966 90%
   tabcmd_controller.py4277 83%
TOTAL284343985% 

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.

1 participant