Skip to content

tashirosota/stacktrace_cleaner

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

hex.pm version CI GitHub code size in bytes

StacktraceCleaner

Stacktraces often include many lines that are not relevant for the context under review. This makes it hard to find the signal amongst many noise, and adds debugging time. StacktraceCleaner is a module to remove those noises and make them easier to see. Inspired by ActiveSupport::BacktraceCleaner

Installation

def deps do
  [
    {:stacktrace_cleaner, "~> 0.1.1"}
  ]
end

Usage

docs

iex(1)> StacktraceCleaner.current_stacktrace
{StacktraceCleaner, :current_stacktraces, 1, [file: 'lib/stacktrace_cleaner.ex', line: 26]}
iex(2)> StacktraceCleaner.current_stacktraces
[
  {StacktraceCleaner, :current_stacktraces, 1,
  [file: 'lib/stacktrace_cleaner.ex', line: 26]},
  {StacktraceCleanerTest, :"test current_stacktraces", 1,
  [file: 'test/stacktrace_cleaner_test.exs', line: 16]}
]
iex(3)> StacktraceCleaner.clean(stacktraces)
[
  {StacktraceCleanerTest, :"test clean", 1,
  [file: 'test/stacktrace_cleaner_test.exs', line: 30]}
]
iex(4)> try do
...(4)>   raise "Oh no!"
...(4)> rescue
...(4)>   e in RuntimeError -> __STACKTRACE__ |> StacktraceCleaner.clean |> IO.inspect
...(4)> end
[
  {StacktraceCleanerTest, :"test ", 1,
   [
     file: 'test/stacktrace_cleaner_test.exs',
     line: 42,
     error_info: %{module: Exception}
   ]}
]

About

Stacktrace’s noises and make it easier to see.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages