From 5dd2538e1ad755ca313c72c3b19edf7fe3c2d084 Mon Sep 17 00:00:00 2001 From: Lester Haynes Date: Wed, 1 Nov 2023 08:23:59 -0700 Subject: [PATCH] Update Muzzle docs to describe VirtualField dependency (#9789) --- docs/contributing/muzzle.md | 4 ++++ docs/contributing/writing-instrumentation-module.md | 3 +++ 2 files changed, 7 insertions(+) diff --git a/docs/contributing/muzzle.md b/docs/contributing/muzzle.md index 61272d3a03da..6c20c5e2f5c1 100644 --- a/docs/contributing/muzzle.md +++ b/docs/contributing/muzzle.md @@ -9,6 +9,10 @@ symbols on the application classpath. Muzzle will prevent loading an instrumentation if it detects any mismatch or conflict. +Muzzle's dependency graph and class injection are encountered especially during the writing of +[`instrumentation modules`](writing-instrumentation-module.md). This functionality is required if +the packaged instrumentation utilizes `VirtualField`. + ## How it works Muzzle has two phases: diff --git a/docs/contributing/writing-instrumentation-module.md b/docs/contributing/writing-instrumentation-module.md index 53bba6831f6d..a5eb3a697268 100644 --- a/docs/contributing/writing-instrumentation-module.md +++ b/docs/contributing/writing-instrumentation-module.md @@ -341,6 +341,9 @@ limited: the `VirtualField#get()` method must receive class references as its pa work with variables, method params, etc. Both the owner class and the field class must be known at compile time for it to work. +Use of `VirtualField` requires the `muzzle-generation` gradle plugin. Failing to use the plugin will result in +ClassNotFoundException when trying to access the field. + ### Why we don't use ByteBuddy @Advice.Origin Method Instead of