#report #scope #error #environment #team #engineer

bin+lib dev-scope

A tool to help diagnose errors, setup machines, and report bugs to authors

16 stable releases

2024.2.21 Mar 14, 2024
2024.2.8 Mar 5, 2024
2024.2.7 Feb 15, 2024
2024.2.6 Feb 4, 2024

#467 in Debugging

BSD-3-Clause

150KB
3.5K SLoC

Scope

scope is a tool that allows developer experience teams to provide tooling for engineers. There are two tools engineers will use directly, scope doctor and scope report.

scope doctor runs a set of user-defined scripts to help configure, debug, and fix an engineers environment.

scope report is used to report local execution error. This is primarily used to generate a bug report, and upload it somewhere so that the responders have all the required into to respond.

For full documentation, please visit our website.

Install

Homebrew

brew install ethankhall/homebrew-formulas/dev-scope

Install Script

Review the latest release to find the install command.

Cargo

cargo install dev-scope

Manually

To install manually, download the correct archive for your platform from github release, extract it, and place the binaries on the PATH.

Commands

scope doctor

Environments are hard to maintain and can fall out of sync with exceptions quickly. scope doctor is a way to codify what a working environment means and tell the user how to fix it. The aim is to reduce the need for engineers to ask others to fix their environment and distribute what "working" means to everyone.

scope report

Sometimes you need to report an error to others. Often the responding team wants the output that failed, and some other useful debugging information.

By using scope report some-command.sh, scope will capture all the output with timestamps and then generate a "report" that can be uploaded to multiple destinations.

IMPORTANT: scope will redact anything it finds as "sensitive". This allows you to fetch env-vars, and no leak GH API tokens for example.

scope-intercept

scope-intercept is a shebang replacement for env. Behind the scene env -S is run to execute the script, however scope-intercept will watch all the output and then check for KnownErrors. This allows the engineer to see, in real time, suggestions for fixing errors. It also allows the engineer to upload a bug report immediately.

IMPORTANT: scope will redact anything it finds as "sensitive". This allows you to fetch env-vars, and no leak GH API tokens for example.

Special Thanks

We took our redaction string from sirwart/ripsecrets.

Dependencies

~33–51MB
~865K SLoC