README.md

[![Hex.pm Version](https://img.shields.io/hexpm/v/smart_tracer?style=for-the-badge)](https://hex.pm/packages/smart_tracer)

# SmartTracer

A simple tracer with recording capabilities that would help you in a live debugging session.

## Installation

To use SmartTracer, update the `mix.exs` to include it on your dependencies.

```elixir
def deps do
  [
    {:smart_tracer, "~> 0.2.0"}
  ]
end
```

Documentation can be viewed here: [https://hexdocs.pm/smart_tracer](https://hexdocs.pm/smart_tracer).

## Usage

When connected to a live remote console, issue the `trace/2` passing the function reference and rate limit.

### Tracing a global function

```elixir
    iex> SmartTracer.trace(&FakeModule.hello/1, 5)
    1
    iex> FakeModule.hello("Vince")
    Elixir.SmartTracer.Support.FakeModule.hello/1 is being called with:
      ["Vince"]
```

### Tracing a local function

```elixir
    iex> SmartTracer.trace(&FakeModule.get_name/1, 5, scope: :local)
    1
    iex> FakeModule.hello("Vince")
    Elixir.SmartTracer.Support.FakeModule.get_name/1 is being called with:
      ["Vince"]
```

### Tracing a function and getting it's return value (possible also for local tracing)

```elixir
    iex> SmartTracer.trace(&FakeModulne.hello/1, 5, return: true)
    1
    iex> FakeModule.hello("Vince")
    Elixir.SmartTracer.Support.FakeModule.hello/1 is being called with:
      ["Vince"]
    Elixir.SmartTracer.Support.FakeModule.hello/1 returns:
      "Hello, my name is NAME-Vince"
```

### Tracing a function and recording calls and returns

```elixir
    iex> SmartTracer.trace(&FakeModulne.hello/1, 5, return: true, record: true)
    1
```

To playback all the recordings, use `playback/0`

```elixir
    iex> SmartTracer.playback()
    [%SmartTracer.Utils.Recorder.Call{
      args: ["Vince"],
      arity: 1,
      datetime: #DateTime<2020-02-01 18:13:04Z>,
      function: :hello,
      module: SmartTracer.Support.FakeModule,
      type: :call
    },
    %SmartTracer.Utils.Recorder.Return{
      arity: 1,
      datetime: #DateTime<2020-02-01 18:13:04Z>,
      function: :hello,
      module: SmartTracer.Support.FakeModule,
      return_value: "Hello, my name is NAME-Vince",
      type: :return
    }]
```