Commit 1d21f9b
committed
fix(celery): coerce non-string values in CeleryGetter.get()
Celery's Context copies all message properties as instance attributes
via __dict__.update(), including non-string values like timelimit
(tuple of ints) and priority (int). The TextMapPropagator contract
requires string values from Getter.get(), but CeleryGetter returned
these non-string values as-is, causing TraceState.from_header() to
crash with TypeError when calling re.split() on an int.
Coerce all non-string values to strings before returning them.
See #43591 parent 822cd77 commit 1d21f9b
2 files changed
Lines changed: 43 additions & 2 deletions
File tree
- instrumentation/opentelemetry-instrumentation-celery
- src/opentelemetry/instrumentation/celery
- tests
Lines changed: 9 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
104 | 104 | | |
105 | 105 | | |
106 | 106 | | |
107 | | - | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
108 | 112 | | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
109 | 117 | | |
110 | 118 | | |
111 | 119 | | |
| |||
Lines changed: 34 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
36 | 36 | | |
37 | 37 | | |
38 | 38 | | |
39 | | - | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
40 | 73 | | |
41 | 74 | | |
42 | 75 | | |
| |||
0 commit comments