|
25 | 25 | from bson.son import SON
|
26 | 26 | from pymongo import CursorType, monitoring, InsertOne, UpdateOne, DeleteOne
|
27 | 27 | from pymongo.command_cursor import CommandCursor
|
28 |
| -from pymongo.errors import NotMasterError, OperationFailure |
| 28 | +from pymongo.errors import (AutoReconnect, |
| 29 | + NotMasterError, |
| 30 | + OperationFailure) |
29 | 31 | from pymongo.read_preferences import ReadPreference
|
30 | 32 | from pymongo.write_concern import WriteConcern
|
31 | 33 | from test import (client_context,
|
|
34 | 36 | sanitize_cmd,
|
35 | 37 | unittest)
|
36 | 38 | from test.utils import (EventListener,
|
| 39 | + get_pool, |
37 | 40 | rs_or_single_client,
|
38 | 41 | single_client,
|
39 | 42 | wait_until)
|
@@ -1172,6 +1175,78 @@ def test_bulk_write(self):
|
1172 | 1175 | ('limit', 1)])])])
|
1173 | 1176 | self.assertEqualCommand(expected, started[2].command)
|
1174 | 1177 |
|
| 1178 | + @client_context.require_failCommand_fail_point |
| 1179 | + def test_bulk_write_command_network_error(self): |
| 1180 | + coll = self.client.pymongo_test.test |
| 1181 | + self.listener.results.clear() |
| 1182 | + |
| 1183 | + insert_network_error = { |
| 1184 | + 'configureFailPoint': 'failCommand', |
| 1185 | + 'mode': {'times': 1}, |
| 1186 | + 'data': { |
| 1187 | + 'failCommands': ['insert'], |
| 1188 | + 'closeConnection': True, |
| 1189 | + }, |
| 1190 | + } |
| 1191 | + with self.fail_point(insert_network_error): |
| 1192 | + with self.assertRaises(AutoReconnect): |
| 1193 | + coll.bulk_write([InsertOne({'_id': 1})]) |
| 1194 | + failed = self.listener.results['failed'] |
| 1195 | + self.assertEqual(1, len(failed)) |
| 1196 | + event = failed[0] |
| 1197 | + self.assertEqual(event.command_name, 'insert') |
| 1198 | + self.assertIsInstance(event.failure, dict) |
| 1199 | + self.assertEqual(event.failure['errtype'], 'AutoReconnect') |
| 1200 | + self.assertTrue(event.failure['errmsg']) |
| 1201 | + |
| 1202 | + @client_context.require_failCommand_fail_point |
| 1203 | + def test_bulk_write_command_error(self): |
| 1204 | + coll = self.client.pymongo_test.test |
| 1205 | + self.listener.results.clear() |
| 1206 | + |
| 1207 | + insert_command_error = { |
| 1208 | + 'configureFailPoint': 'failCommand', |
| 1209 | + 'mode': {'times': 1}, |
| 1210 | + 'data': { |
| 1211 | + 'failCommands': ['insert'], |
| 1212 | + 'closeConnection': False, |
| 1213 | + 'errorCode': 10107, # NotMaster |
| 1214 | + }, |
| 1215 | + } |
| 1216 | + with self.fail_point(insert_command_error): |
| 1217 | + with self.assertRaises(NotMasterError): |
| 1218 | + coll.bulk_write([InsertOne({'_id': 1})]) |
| 1219 | + failed = self.listener.results['failed'] |
| 1220 | + self.assertEqual(1, len(failed)) |
| 1221 | + event = failed[0] |
| 1222 | + self.assertEqual(event.command_name, 'insert') |
| 1223 | + self.assertIsInstance(event.failure, dict) |
| 1224 | + self.assertEqual(event.failure['code'], 10107) |
| 1225 | + self.assertTrue(event.failure['errmsg']) |
| 1226 | + |
| 1227 | + @client_context.require_version_max(3, 4, 99) |
| 1228 | + def test_bulk_write_legacy_network_error(self): |
| 1229 | + self.listener.results.clear() |
| 1230 | + |
| 1231 | + # Make the delete operation run on a closed connection. |
| 1232 | + self.client.admin.command('ping') |
| 1233 | + pool = get_pool(self.client) |
| 1234 | + sock_info = pool.sockets[0] |
| 1235 | + sock_info.sock.close() |
| 1236 | + |
| 1237 | + # Test legacy unacknowledged write network error. |
| 1238 | + coll = self.client.pymongo_test.get_collection( |
| 1239 | + 'test', write_concern=WriteConcern(w=0)) |
| 1240 | + with self.assertRaises(AutoReconnect): |
| 1241 | + coll.bulk_write([InsertOne({'_id': 1})], ordered=False) |
| 1242 | + failed = self.listener.results['failed'] |
| 1243 | + self.assertEqual(1, len(failed)) |
| 1244 | + event = failed[0] |
| 1245 | + self.assertEqual(event.command_name, 'insert') |
| 1246 | + self.assertIsInstance(event.failure, dict) |
| 1247 | + self.assertEqual(event.failure['errtype'], 'AutoReconnect') |
| 1248 | + self.assertTrue(event.failure['errmsg']) |
| 1249 | + |
1175 | 1250 | def test_write_errors(self):
|
1176 | 1251 | coll = self.client.pymongo_test.test
|
1177 | 1252 | coll.drop()
|
|
0 commit comments