Commit 7260278
committed
RF-aware load imbalance, exclude gateway-only consoles, fix AP tie-breaking (#512)
* RF-aware load imbalance rule, extend roaming topology to 72h
Load Imbalance: When APs are placed on the Signal Map, use RF propagation
modeling to check if the overloaded and underloaded APs are in separate
coverage zones. If they are distant and all clients on the busy AP have
strong signal, suppress the warning entirely. If distant but some clients
are weak, downgrade to Info. Hints users to place APs on the map when
propagation context isn't available.
Roaming Topology: Pass within=259200 (72h) to the UniFi roaming topology
API for a broader view of roaming failures instead of the default 24h.
* Exclude gateway-only consoles from Wi-Fi Optimizer, revert roaming to 24h
UDM-Pro, UDM-SE, UDM-Pro-Max, and EFG report radio_table entries in the
UniFi API but have no actual Wi-Fi radios. Filter them out using the
FriendlyModelName: exclude gateways starting with "UDM-" or equal to "EFG".
The original UDM (Dream Machine) passes through since it has real Wi-Fi.
Also reverts the roaming topology lookback from 72h back to the default 24h.
* Also exclude EFG-Core and future EFG variants from Wi-Fi Optimizer
* Fix load imbalance picking same AP for both max and min
When multiple APs have the same client count, OrderByDescending and
OrderBy could non-deterministically pick the same AP for both maxAp
and minAp, producing messages like "X has 8 clients while X has only 8".
Fix: use opposite MAC tie-breaking (ThenBy vs ThenByDescending) to
guarantee different APs, plus a MAC equality guard as a safety net.
* Add tests for load imbalance rule and gateway AP exclusion
LoadImbalanceRuleTests (13 tests):
- Basic threshold behavior (single AP, no clients, balanced, imbalanced)
- Tie-breaking: ensures maxAp != minAp when client counts are equal
- RF distance: suppressed when far apart + strong signal, Info when weak
- Propagation context edge cases (one AP not placed, null signal)
GatewayApExclusionTests (18 tests):
- UDM-Pro, UDM-SE, UDM-Pro-Max excluded (start with "UDM-")
- EFG and EFG-Core excluded (start with "EFG")
- UDM, UDR, UDR7, UX, UX7, UDW, UDR-5G-Max allowed (have real Wi-Fi)
- Device model/shortname values match real API responses
* Adjust AP radio card column widths in Wi-Fi Optimizer
* Adjust radio-channel width to 45px in AP cards1 parent 7645ea0 commit 7260278
5 files changed
Lines changed: 671 additions & 7 deletions
File tree
- src
- NetworkOptimizer.UniFi
- NetworkOptimizer.Web/wwwroot/css
- NetworkOptimizer.WiFi/Rules
- tests
- NetworkOptimizer.UniFi.Tests
- NetworkOptimizer.WiFi.Tests
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
126 | 126 | | |
127 | 127 | | |
128 | 128 | | |
| 129 | + | |
| 130 | + | |
129 | 131 | | |
130 | 132 | | |
131 | 133 | | |
132 | 134 | | |
133 | 135 | | |
134 | 136 | | |
135 | 137 | | |
136 | | - | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
137 | 154 | | |
138 | 155 | | |
139 | 156 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
7665 | 7665 | | |
7666 | 7666 | | |
7667 | 7667 | | |
7668 | | - | |
| 7668 | + | |
7669 | 7669 | | |
7670 | 7670 | | |
7671 | 7671 | | |
7672 | 7672 | | |
7673 | 7673 | | |
7674 | 7674 | | |
7675 | | - | |
| 7675 | + | |
7676 | 7676 | | |
7677 | 7677 | | |
7678 | 7678 | | |
7679 | 7679 | | |
7680 | 7680 | | |
7681 | | - | |
| 7681 | + | |
7682 | 7682 | | |
7683 | 7683 | | |
7684 | 7684 | | |
| |||
7688 | 7688 | | |
7689 | 7689 | | |
7690 | 7690 | | |
| 7691 | + | |
7691 | 7692 | | |
7692 | 7693 | | |
7693 | 7694 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
| 2 | + | |
2 | 3 | | |
3 | 4 | | |
4 | 5 | | |
5 | 6 | | |
6 | 7 | | |
7 | 8 | | |
| 9 | + | |
| 10 | + | |
8 | 11 | | |
9 | 12 | | |
10 | 13 | | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
11 | 21 | | |
12 | 22 | | |
13 | 23 | | |
14 | 24 | | |
15 | 25 | | |
16 | 26 | | |
17 | 27 | | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
18 | 33 | | |
19 | 34 | | |
20 | 35 | | |
| |||
35 | 50 | | |
36 | 51 | | |
37 | 52 | | |
38 | | - | |
39 | | - | |
| 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 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
40 | 141 | | |
41 | 142 | | |
42 | 143 | | |
| |||
46 | 147 | | |
47 | 148 | | |
48 | 149 | | |
49 | | - | |
| 150 | + | |
50 | 151 | | |
51 | 152 | | |
52 | 153 | | |
| |||
Lines changed: 174 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 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 | + | |
| 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 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
0 commit comments