Skip to main content

Generate safe T-SQL stored-procedure debug harness scripts (analyze + DML previews)

Project description

sql-sp-harness

PyPI version Python 3.10|3.12|3.13

sql-sp-harness

T-SQL Stored Procedure Debug Harness — turn SQL Server stored procedures into safe, runnable debug scripts you can execute on a pre-production database without writing to real tables.

Not a live debugger. This tool generates a static test harness (DML previews + variable traces), not breakpoints or step-into debugging.

Not affiliated with Microsoft. "SQL Server" and T-SQL are used descriptively only.

What it does

Command Purpose
analyze See what keyword elements that procedure contains along with counts — DML, TRY/CATCH, loops, SET, line-level detail
generate Create a debug harness: real-table DML → SELECT previews, PRINT traces on variables

Output includes a banner on the top of the procedure stating: DEBUG HARNESS — DO NOT RUN ON PRODUCTION.

Install

pip install sql-sp-harness

Requires Python 3.10+.

Verify:

sql-sp-harness version
python -m sql_sp_harness version

Quick start

sql-sp-harness analyze -i MyProc.sql
sql-sp-harness generate -i MyProc.sql -o MyProc_debug.sql

With traces in the Messages tab (default):

sql-sp-harness generate -i MyProc.sql -o MyProc_debug.sql --trace-style print

Development

git clone https://github.com/DeeprajDeveloper/sql-sp-harness.git
cd sql-sp-harness
pip install -e ".[dev]"
pytest

Build for PyPI:

./scripts/publish-pypi.sh
./scripts/publish-pypi.sh upload

File encoding

SSMS often saves scripts as UTF-16 LE (Unicode). Older Windows exports may use Windows-1252 (smart quotes, en-dashes). The CLI auto-detects these; output is always UTF-8. Override with --encoding if needed:

sql-sp-harness generate -i MyProc.sql -o MyProc_debug.sql --encoding utf-16-le

Limitations

Pattern Behavior
Dynamic SQL Not analyzed
Encrypted procedures No source
Cursors Not rewritten
DDL inside proc Not stubbed

Always review generated scripts before running them on the database server.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sql_sp_harness-1.0.1.tar.gz (22.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sql_sp_harness-1.0.1-py3-none-any.whl (24.8 kB view details)

Uploaded Python 3

File details

Details for the file sql_sp_harness-1.0.1.tar.gz.

File metadata

  • Download URL: sql_sp_harness-1.0.1.tar.gz
  • Upload date:
  • Size: 22.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for sql_sp_harness-1.0.1.tar.gz
Algorithm Hash digest
SHA256 2ea5940f7819113afb5a3d45dd5aef06cf518c7bb214f512e2b6e3ee0f4c1e38
MD5 b88912b7ea28281788ec9df12cfa1707
BLAKE2b-256 50e114612586a65cb5b52265698b05603e2df1d90333d0e5c07d45be5ab32715

See more details on using hashes here.

Provenance

The following attestation bundles were made for sql_sp_harness-1.0.1.tar.gz:

Publisher: publish-pypi.yml on DeeprajDeveloper/sql-sp-harness

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file sql_sp_harness-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: sql_sp_harness-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 24.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for sql_sp_harness-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 2d40e03866ec282f401b9513a30e092028f1518a3aac985791135a121774fb9d
MD5 2181dccc68e3b20703d35a3ebf924d71
BLAKE2b-256 e5c720285a78515dee4dda892077e69f20f1fd98c6db05f7d9c5952cb7ac79f7

See more details on using hashes here.

Provenance

The following attestation bundles were made for sql_sp_harness-1.0.1-py3-none-any.whl:

Publisher: publish-pypi.yml on DeeprajDeveloper/sql-sp-harness

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page