Commit a978b1d
fix(server): correct Kubernetes label key length validation
The previous implementation of _is_valid_label_key checked whether the
total key length exceeded 253 characters. This incorrectly rejected
valid label keys where the prefix portion was within the allowed 253-char
limit but the combined prefix+"/"+name exceeded 253 characters.
According to Kubernetes label key constraints:
- The optional prefix must be a DNS subdomain with at most 253 characters
- The name segment must be at most 63 characters
- There is no constraint on the combined total length (max: 253+1+63=317)
This commit removes the total-length check and replaces it with a direct
prefix-length check, which matches the Kubernetes specification.
Regression coverage is added for:
- Valid key rejected by the old check (prefix=251 chars, total>253)
- Prefix that exceeds 253 chars (should be rejected)
- Invalid prefix format
- Name that exceeds 63 chars
- Value that exceeds 63 chars
- Non-string metadata keys
- Key with empty prefix (starts with '/')1 parent ec7e7c2 commit a978b1d
2 files changed
Lines changed: 71 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
59 | 59 | | |
60 | 60 | | |
61 | 61 | | |
62 | | - | |
63 | | - | |
64 | 62 | | |
65 | 63 | | |
66 | 64 | | |
67 | 65 | | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
68 | 72 | | |
69 | 73 | | |
70 | 74 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
48 | 48 | | |
49 | 49 | | |
50 | 50 | | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
51 | 116 | | |
52 | 117 | | |
53 | 118 | | |
| |||
0 commit comments