Skip to content

Commit

Permalink
add readme (#11535)
Browse files Browse the repository at this point in the history
  • Loading branch information
shileiwill authored Dec 14, 2023
1 parent 917b74f commit 7a0704f
Show file tree
Hide file tree
Showing 2 changed files with 94 additions and 3 deletions.
91 changes: 91 additions & 0 deletions core/scripts/chaincli/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -122,3 +122,94 @@ You can use the `grep` and `grepv` flags to filter log lines, e.g. to only show
```shell
./chaincli keeper logs --grep keepers-plugin
```

---

## ChainCLI Automation Debugging Script

### Context

The debugging script is a tool within ChainCLI designed to facilitate the debugging of upkeeps in Automation v21, covering both conditional and log-based scenarios.

### Configuration

#### Mandatory Fields

Ensure the following fields are provided in your `.env` file:

- `NODE_URL`: Archival node URL
- `KEEPER_REGISTRY_ADDRESS`: Address of the Keeper Registry contract. Refer to the [Supported Networks](https://docs.chain.link/chainlink-automation/overview/supported-networks#configurations) doc for addresses.

#### Additional Fields (Streams Lookup)

If your targeted upkeep involves streams lookup, include the following information:

- `MERCURY_ID`
- `MERCURY_KEY`
- `MERCURY_LEGACY_URL`
- `MERCURY_URL`

#### Tenderly Integration

For detailed transaction simulation logs, set up Tenderly credentials. Refer to the [Tenderly Documentation](https://docs.tenderly.co/other/platform-access/how-to-generate-api-access-tokens) for creating an API key, account name, and project name.

- `TENDERLY_KEY`
- `TENDERLY_ACCOUNT_NAME`
- `TENDERLY_PROJECT_NAME`

### Usage

Execute the following command based on your upkeep type:

- For conditional upkeep:

```bash
go run main.go keeper debug UPKEEP_ID
```

- For log trigger upkeep:

```bash
go run main.go keeper debug UPKEEP_ID TX_HASH LOG_INDEX
```

### Checks Performed by the Debugging Script

1. **Fetch and Sanity Check Upkeep:**
- Verify upkeep status: active, paused, or canceled
- Check upkeep balance

2. **For Conditional Upkeep:**
- Check conditional upkeep
- Simulate `performUpkeep`

3. **For Log Trigger Upkeep:**
- Check if the upkeep has already run for log-trigger-based upkeep
- Verify if log matches trigger configuration
- Check upkeep
- If check result indicates a streams lookup is required (TargetCheckReverted):
- Verify if the upkeep is allowed to use Mercury
- Execute Mercury request
- Execute check callback

- Simulate `performUpkeep`

### Examples
- Eligible and log trigger based and using mercury lookup v0.3:

```bash
go run main.go keeper debug 5591498142036749453487419299781783197030971023186134955311257372668222176389 0xdc6d0e547a5aa85fefa5b0f3a37e3493eafb5aeba8b5f3071ce53c9e9a539e9c 0
```

- Ineligible and conditional upkeep:

```bash
go run main.go keeper debug 52635131310730056105456985154251306793887717546629785340977553840883117540096
```

- Ineligible and Log does not match trigger config:

```bash
go run main.go keeper debug 5591498142036749453487419299781783197030971023186134955311257372668222176389 0xc0686ae85d2a7a976ef46df6c613517b9fd46f23340ac583be4e44f5c8b7a186 1
```
---
6 changes: 3 additions & 3 deletions core/scripts/chaincli/handler/debug.go
Original file line number Diff line number Diff line change
Expand Up @@ -111,8 +111,8 @@ func (k *Keeper) Debug(ctx context.Context, args []string) {
if (upkeepInfo.Target == gethcommon.Address{}) {
failCheckArgs("this upkeep does not exist on this registry", nil)
}
addLink("upkeep", common.UpkeepLink(chainID, upkeepID))
addLink("target", common.ContractExplorerLink(chainID, upkeepInfo.Target))
addLink("upkeep link", common.UpkeepLink(chainID, upkeepID))
addLink("upkeep contract address", common.ContractExplorerLink(chainID, upkeepInfo.Target))
if upkeepInfo.Paused {
resolveIneligible("upkeep is paused")
}
Expand Down Expand Up @@ -180,7 +180,7 @@ func (k *Keeper) Debug(ctx context.Context, args []string) {
if err != nil {
failCheckArgs("failed to fetch tx receipt", err)
}
addLink("trigger", common.ExplorerLink(chainID, txHash))
addLink("trigger transaction", common.ExplorerLink(chainID, txHash))
blockNum = receipt.BlockNumber.Uint64()
// find matching log event in tx
var triggeringEvent *types.Log
Expand Down

0 comments on commit 7a0704f

Please sign in to comment.