forked frompostgres/postgres
- Notifications
You must be signed in to change notification settings - Fork6
Commitab09679
committed
libpq: Fix sending queries in pipeline aborted state
When sending queries in pipeline mode, we were careless about leavingthe connection in the right state so that PQgetResult would behavecorrectly; trying to read further results after sending a query afterhaving read a result with an error would sometimes hang. Fix byensuring internal libpq state is changed properly. All the statechanges were being done by the callers of pqAppendCmdQueueEntry(); itwould have become too repetitious to have this logic in each of them, soinstead put it all in that function and relieve callers of theresponsibility.Add a test to verify this case. Without the code fix, this new testhangs sometimes.Also, document that PQisBusy() would return false when no queries arepending result. This is not intuitively obvious, and NULL would beobtained by calling PQgetResult() at that point, which is confusing.Wording by Boris Kolpackov.In passing, fix bogus use of "false" to mean "0", per Ranier Vilela.Backpatch to 14.Author: Álvaro Herrera <alvherre@alvh.no-ip.org>Reported-by: Boris Kolpackov <boris@codesynthesis.com>Discussion:https://postgr.es/m/boris.20210624103805@codesynthesis.com1 parent8e7811e commitab09679
File tree
3 files changed
+274
-14
lines changed- doc/src/sgml
- src
- interfaces/libpq
- test/modules/libpq_pipeline
3 files changed
+274
-14
lines changedLines changed: 4 additions & 1 deletion
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
5171 | 5171 |
| |
5172 | 5172 |
| |
5173 | 5173 |
| |
5174 |
| - | |
| 5174 | + | |
| 5175 | + | |
| 5176 | + | |
| 5177 | + | |
5175 | 5178 |
| |
5176 | 5179 |
| |
5177 | 5180 |
| |
|
Lines changed: 44 additions & 13 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
1223 | 1223 |
| |
1224 | 1224 |
| |
1225 | 1225 |
| |
1226 |
| - | |
| 1226 | + | |
| 1227 | + | |
1227 | 1228 |
| |
1228 | 1229 |
| |
1229 | 1230 |
| |
| |||
1239 | 1240 |
| |
1240 | 1241 |
| |
1241 | 1242 |
| |
| 1243 | + | |
| 1244 | + | |
| 1245 | + | |
| 1246 | + | |
| 1247 | + | |
| 1248 | + | |
| 1249 | + | |
| 1250 | + | |
| 1251 | + | |
| 1252 | + | |
| 1253 | + | |
| 1254 | + | |
| 1255 | + | |
| 1256 | + | |
| 1257 | + | |
| 1258 | + | |
| 1259 | + | |
| 1260 | + | |
| 1261 | + | |
| 1262 | + | |
| 1263 | + | |
| 1264 | + | |
| 1265 | + | |
| 1266 | + | |
| 1267 | + | |
| 1268 | + | |
| 1269 | + | |
| 1270 | + | |
| 1271 | + | |
| 1272 | + | |
| 1273 | + | |
| 1274 | + | |
1242 | 1275 |
| |
1243 | 1276 |
| |
1244 | 1277 |
| |
| |||
1375 | 1408 |
| |
1376 | 1409 |
| |
1377 | 1410 |
| |
1378 |
| - | |
1379 | 1411 |
| |
1380 | 1412 |
| |
1381 | 1413 |
| |
| |||
1510 | 1542 |
| |
1511 | 1543 |
| |
1512 | 1544 |
| |
1513 |
| - | |
1514 |
| - | |
1515 |
| - | |
1516 |
| - | |
1517 | 1545 |
| |
1518 | 1546 |
| |
1519 | 1547 |
| |
| |||
1522 | 1550 |
| |
1523 | 1551 |
| |
1524 | 1552 |
| |
| 1553 | + | |
| 1554 | + | |
| 1555 | + | |
1525 | 1556 |
| |
1526 | 1557 |
| |
1527 | 1558 |
| |
| |||
1815 | 1846 |
| |
1816 | 1847 |
| |
1817 | 1848 |
| |
1818 |
| - | |
| 1849 | + | |
1819 | 1850 |
| |
1820 | 1851 |
| |
1821 | 1852 |
| |
| |||
2445 | 2476 |
| |
2446 | 2477 |
| |
2447 | 2478 |
| |
2448 |
| - | |
| 2479 | + | |
2449 | 2480 |
| |
2450 | 2481 |
| |
2451 | 2482 |
| |
| |||
2948 | 2979 |
| |
2949 | 2980 |
| |
2950 | 2981 |
| |
2951 |
| - | |
| 2982 | + | |
2952 | 2983 |
| |
2953 | 2984 |
| |
2954 | 2985 |
| |
| |||
3072 | 3103 |
| |
3073 | 3104 |
| |
3074 | 3105 |
| |
3075 |
| - | |
3076 |
| - | |
3077 | 3106 |
| |
3078 | 3107 |
| |
3079 | 3108 |
| |
3080 | 3109 |
| |
3081 | 3110 |
| |
3082 | 3111 |
| |
3083 |
| - | |
| 3112 | + | |
| 3113 | + | |
| 3114 | + | |
3084 | 3115 |
| |
3085 | 3116 |
| |
3086 | 3117 |
| |
| |||
3115 | 3146 |
| |
3116 | 3147 |
| |
3117 | 3148 |
| |
3118 |
| - | |
| 3149 | + | |
3119 | 3150 |
| |
3120 | 3151 |
| |
3121 | 3152 |
| |
|
Lines changed: 226 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
28 | 28 |
| |
29 | 29 |
| |
30 | 30 |
| |
| 31 | + | |
| 32 | + | |
31 | 33 |
| |
32 | 34 |
| |
33 | 35 |
| |
| |||
1307 | 1309 |
| |
1308 | 1310 |
| |
1309 | 1311 |
| |
| 1312 | + | |
| 1313 | + | |
| 1314 | + | |
| 1315 | + | |
| 1316 | + | |
| 1317 | + | |
| 1318 | + | |
| 1319 | + | |
| 1320 | + | |
| 1321 | + | |
| 1322 | + | |
| 1323 | + | |
| 1324 | + | |
| 1325 | + | |
| 1326 | + | |
| 1327 | + | |
| 1328 | + | |
| 1329 | + | |
| 1330 | + | |
| 1331 | + | |
| 1332 | + | |
| 1333 | + | |
| 1334 | + | |
| 1335 | + | |
| 1336 | + | |
| 1337 | + | |
| 1338 | + | |
| 1339 | + | |
| 1340 | + | |
| 1341 | + | |
| 1342 | + | |
| 1343 | + | |
| 1344 | + | |
| 1345 | + | |
| 1346 | + | |
| 1347 | + | |
| 1348 | + | |
| 1349 | + | |
| 1350 | + | |
| 1351 | + | |
| 1352 | + | |
| 1353 | + | |
| 1354 | + | |
| 1355 | + | |
| 1356 | + | |
| 1357 | + | |
| 1358 | + | |
| 1359 | + | |
| 1360 | + | |
| 1361 | + | |
| 1362 | + | |
| 1363 | + | |
| 1364 | + | |
| 1365 | + | |
| 1366 | + | |
| 1367 | + | |
| 1368 | + | |
| 1369 | + | |
| 1370 | + | |
| 1371 | + | |
| 1372 | + | |
| 1373 | + | |
| 1374 | + | |
| 1375 | + | |
| 1376 | + | |
| 1377 | + | |
| 1378 | + | |
| 1379 | + | |
| 1380 | + | |
| 1381 | + | |
| 1382 | + | |
| 1383 | + | |
| 1384 | + | |
| 1385 | + | |
| 1386 | + | |
| 1387 | + | |
| 1388 | + | |
| 1389 | + | |
| 1390 | + | |
| 1391 | + | |
| 1392 | + | |
| 1393 | + | |
| 1394 | + | |
| 1395 | + | |
| 1396 | + | |
| 1397 | + | |
| 1398 | + | |
| 1399 | + | |
| 1400 | + | |
| 1401 | + | |
| 1402 | + | |
| 1403 | + | |
| 1404 | + | |
| 1405 | + | |
| 1406 | + | |
| 1407 | + | |
| 1408 | + | |
| 1409 | + | |
| 1410 | + | |
| 1411 | + | |
| 1412 | + | |
| 1413 | + | |
| 1414 | + | |
| 1415 | + | |
| 1416 | + | |
| 1417 | + | |
| 1418 | + | |
| 1419 | + | |
| 1420 | + | |
| 1421 | + | |
| 1422 | + | |
| 1423 | + | |
| 1424 | + | |
| 1425 | + | |
| 1426 | + | |
| 1427 | + | |
| 1428 | + | |
| 1429 | + | |
| 1430 | + | |
| 1431 | + | |
| 1432 | + | |
| 1433 | + | |
| 1434 | + | |
| 1435 | + | |
| 1436 | + | |
| 1437 | + | |
| 1438 | + | |
| 1439 | + | |
| 1440 | + | |
| 1441 | + | |
| 1442 | + | |
| 1443 | + | |
| 1444 | + | |
| 1445 | + | |
| 1446 | + | |
| 1447 | + | |
| 1448 | + | |
| 1449 | + | |
| 1450 | + | |
| 1451 | + | |
| 1452 | + | |
| 1453 | + | |
| 1454 | + | |
| 1455 | + | |
| 1456 | + | |
| 1457 | + | |
| 1458 | + | |
| 1459 | + | |
| 1460 | + | |
| 1461 | + | |
| 1462 | + | |
| 1463 | + | |
| 1464 | + | |
| 1465 | + | |
| 1466 | + | |
| 1467 | + | |
| 1468 | + | |
| 1469 | + | |
| 1470 | + | |
| 1471 | + | |
| 1472 | + | |
| 1473 | + | |
| 1474 | + | |
| 1475 | + | |
| 1476 | + | |
| 1477 | + | |
| 1478 | + | |
| 1479 | + | |
| 1480 | + | |
| 1481 | + | |
| 1482 | + | |
| 1483 | + | |
| 1484 | + | |
| 1485 | + | |
| 1486 | + | |
| 1487 | + | |
| 1488 | + | |
| 1489 | + | |
| 1490 | + | |
| 1491 | + | |
| 1492 | + | |
| 1493 | + | |
| 1494 | + | |
| 1495 | + | |
| 1496 | + | |
| 1497 | + | |
| 1498 | + | |
| 1499 | + | |
| 1500 | + | |
| 1501 | + | |
| 1502 | + | |
| 1503 | + | |
| 1504 | + | |
| 1505 | + | |
| 1506 | + | |
| 1507 | + | |
| 1508 | + | |
| 1509 | + | |
| 1510 | + | |
| 1511 | + | |
| 1512 | + | |
| 1513 | + | |
| 1514 | + | |
| 1515 | + | |
| 1516 | + | |
| 1517 | + | |
| 1518 | + | |
| 1519 | + | |
| 1520 | + | |
| 1521 | + | |
| 1522 | + | |
| 1523 | + | |
| 1524 | + | |
| 1525 | + | |
| 1526 | + | |
| 1527 | + | |
| 1528 | + | |
| 1529 | + | |
| 1530 | + | |
| 1531 | + | |
| 1532 | + | |
1310 | 1533 |
| |
1311 | 1534 |
| |
1312 | 1535 |
| |
| |||
1331 | 1554 |
| |
1332 | 1555 |
| |
1333 | 1556 |
| |
| 1557 | + | |
1334 | 1558 |
| |
1335 | 1559 |
| |
1336 | 1560 |
| |
| |||
1436 | 1660 |
| |
1437 | 1661 |
| |
1438 | 1662 |
| |
| 1663 | + | |
| 1664 | + | |
1439 | 1665 |
| |
1440 | 1666 |
| |
1441 | 1667 |
| |
|
0 commit comments
Comments
(0)