Commit 7e3e6a8
authored
fix: resolve 'bytes' object has no attribute 'decoded' for large CODEOWNERS files (#379)
Fixes #378
## What
Normalize CODEOWNERS file contents to bytes before processing, so both
the normal path (Contents object with .decoded) and the large-file path
(raw bytes from blob().decode_content()) use the same type downstream.
## Why
When a CODEOWNERS file is large enough that the GitHub API returns null
content, the code fetches it via blob().decode_content() which returns
raw bytes. The code then called .decoded on that bytes object, crashing
with "'bytes' object has no attribute 'decoded'" and preventing PR
creation for user removal.
## Notes
- The isinstance check in get_usernames_from_codeowners handles both bytes lines and str lines, since the function now accepts raw bytes or str directly
- Existing tests updated to pass bytes/str directly instead of mocking .decoded, matching the new contract
Signed-off-by: jmeridth <jmeridth@gmail.com>1 parent 4597504 commit 7e3e6a8
2 files changed
Lines changed: 24 additions & 12 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
133 | 133 | | |
134 | 134 | | |
135 | 135 | | |
136 | | - | |
| 136 | + | |
137 | 137 | | |
138 | 138 | | |
| 139 | + | |
| 140 | + | |
139 | 141 | | |
140 | 142 | | |
141 | | - | |
| 143 | + | |
142 | 144 | | |
143 | 145 | | |
144 | 146 | | |
| |||
160 | 162 | | |
161 | 163 | | |
162 | 164 | | |
163 | | - | |
164 | | - | |
165 | | - | |
166 | | - | |
| 165 | + | |
| 166 | + | |
167 | 167 | | |
168 | 168 | | |
169 | 169 | | |
| |||
291 | 291 | | |
292 | 292 | | |
293 | 293 | | |
294 | | - | |
| 294 | + | |
295 | 295 | | |
296 | | - | |
| 296 | + | |
297 | 297 | | |
298 | 298 | | |
299 | 299 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
103 | 103 | | |
104 | 104 | | |
105 | 105 | | |
106 | | - | |
107 | | - | |
| 106 | + | |
108 | 107 | | |
109 | 108 | | |
110 | 109 | | |
| |||
120 | 119 | | |
121 | 120 | | |
122 | 121 | | |
123 | | - | |
124 | | - | |
| 122 | + | |
125 | 123 | | |
126 | 124 | | |
127 | 125 | | |
| |||
135 | 133 | | |
136 | 134 | | |
137 | 135 | | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
138 | 150 | | |
139 | 151 | | |
140 | 152 | | |
| |||
0 commit comments