go-ethereum/libevm
Jonathan Oppenheimer b4a7f35411
test: add log handler for error promotion to testing.TB (#259)
This adds a test logger for libevm, that treats errors as they _should_
be treated.

- Logs at `log.LevelWarn` and above trigger `t.Errorf()`, causing tests
to fail
- Critical logs fail immediately: Logs at `log.LevelCrit` trigger
`t.Fatalf()`
- Info/debug logs pass through: Lower severity logs use `t.Logf()` for
informational output

You can use the logger like this: 

```go
  import (
      "github.com/ava-labs/libevm/ethtest"
      "github.com/ava-labs/libevm/log"
  )

  func TestSomething(t *testing.T) {
     logger := log.NewLogger(ethtest.NewTBLogHandler(t, log.LevelDebug))

     // Or to set globally
     log.SetDefault(log.NewLogger(ethtest.NewTBLogHandler(t, log.LevelDebug))
  }
```

I was thinking about adding tests to show this works, but it seemed
silly to test a testing utility.

---------

Signed-off-by: Jonathan Oppenheimer <147infiniti@gmail.com>
Co-authored-by: Arran Schlosberg <519948+ARR4N@users.noreply.github.com>
2026-01-28 15:45:30 +00:00
..
cmd/internalise feat: internalise command (#90) 2024-12-17 17:20:02 +01:00
debug feat: expose internal debug API handler (#255) 2026-01-04 10:22:16 -05:00
ethapi feat: expose ethapi.RPCTransaction (#258) 2026-01-23 21:02:08 +00:00
ethtest test: add log handler for error promotion to testing.TB (#259) 2026-01-28 15:45:30 +00:00
hookstest test: add log handler for error promotion to testing.TB (#259) 2026-01-28 15:45:30 +00:00
legacy fix(libevm/legacy): PrecompiledStatefulContract gas and remaining gas handling (#114) 2025-02-07 14:29:33 +01:00
options feat: options.ApplyTo for default values (#225) 2025-09-09 15:11:33 +01:00
reentrancy feat: reentrancy.Guard for stateful precompiles (#212) 2025-10-03 19:56:29 +00:00
register refactor!: temporary extras require proof of global lock (#238) 2025-10-16 14:27:15 +00:00
set chore: logging (#151) 2025-02-24 16:53:21 +00:00
stateconf feat: state-key transformation w/ override (#205) 2025-07-22 13:08:53 -04:00
sync feat(core/state): async trie prefetching (#76) 2024-11-26 08:01:47 -08:00
testonly test: StateAccount.Extra via trie.StateTrie.{Update,Get}Account() (#45) 2024-10-02 09:45:02 -07:00
tooling chore: Go 1.24 (#232) 2025-10-13 14:07:33 -04:00
extraslock.go refactor!: temporary extras require proof of global lock (#238) 2025-10-16 14:27:15 +00:00
extraslock_test.go refactor!: temporary extras require proof of global lock (#238) 2025-10-16 14:27:15 +00:00
interfaces_test.go Merge branch 'auto-rename-module_source-2bd6bd01d2e8561dd7fc21b631f4a34ac16627a1_workflow-c1fc594f020d23958b641a4e5a856b6e52c49d3bece94b95594864db16c1b0fc-main' into arr4n/rename-module 2024-10-17 13:07:28 +11:00
libevm.go feat!: disambiguate EVM-semantic and raw caller/self addresses for precompiles (#211) 2025-08-07 23:48:32 +01:00