Commit 0f16c7c
authored
fix: prevent duplicate WP users on checkout retry (GH#903) (#911)
On checkout retry, the elseif guard at maybe_create_customer() returned
'email_exists' for ANY existing WP user with that email — including users
whose checkout had previously failed before the customer record was saved
(orphaned WP user). This blocked all retries for those users.
Changes:
1. inc/checkout/class-checkout.php — narrow the block to only fire when the
existing WP user also has a customer record. When no customer record exists
(orphaned/partial state), pass the existing user's ID to wu_create_customer()
so it skips WP user creation and links the new customer to the existing user.
2. inc/functions/customer.php — sanitize the email before the get_user_by()
duplicate check so both the check and the subsequent wpmu_create_user() call
operate on the same normalized value, preventing format-based mismatches.
3. tests/WP_Ultimo/Functions/Customer_Functions_Test.php — two new tests:
- test_create_customer_reuses_existing_wp_user_on_retry: confirms that
wu_create_customer() reuses the pre-existing WP user and creates exactly
one wp_users row for a given email.
- test_create_customer_prevents_duplicate_customer_for_same_user: confirms
that a second wu_create_customer() call for the same user_id does not
create a second customer row.
Fixes #9031 parent 55b2722 commit 0f16c7c
3 files changed
Lines changed: 103 additions & 2 deletions
File tree
- inc
- checkout
- functions
- tests/WP_Ultimo/Functions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1096 | 1096 | | |
1097 | 1097 | | |
1098 | 1098 | | |
1099 | | - | |
1100 | | - | |
| 1099 | + | |
| 1100 | + | |
| 1101 | + | |
| 1102 | + | |
| 1103 | + | |
| 1104 | + | |
| 1105 | + | |
| 1106 | + | |
| 1107 | + | |
| 1108 | + | |
| 1109 | + | |
| 1110 | + | |
| 1111 | + | |
| 1112 | + | |
| 1113 | + | |
| 1114 | + | |
| 1115 | + | |
1101 | 1116 | | |
1102 | 1117 | | |
1103 | 1118 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
142 | 142 | | |
143 | 143 | | |
144 | 144 | | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
145 | 156 | | |
146 | 157 | | |
147 | 158 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
248 | 248 | | |
249 | 249 | | |
250 | 250 | | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
| 268 | + | |
| 269 | + | |
| 270 | + | |
| 271 | + | |
| 272 | + | |
| 273 | + | |
| 274 | + | |
| 275 | + | |
| 276 | + | |
| 277 | + | |
| 278 | + | |
| 279 | + | |
| 280 | + | |
| 281 | + | |
| 282 | + | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
| 309 | + | |
| 310 | + | |
| 311 | + | |
| 312 | + | |
| 313 | + | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
251 | 326 | | |
0 commit comments