|
271 | 271 | end |
272 | 272 | end |
273 | 273 | end |
| 274 | + |
| 275 | + context 'Retries in a replica set' do |
| 276 | + require_topology :replica_set |
| 277 | + min_server_version '4.4' |
| 278 | + |
| 279 | + let(:subscriber) { Mrss::EventSubscriber.new } |
| 280 | + |
| 281 | + let(:find_failed_events) do |
| 282 | + subscriber.failed_events.select { |e| e.command_name == 'find' } |
| 283 | + end |
| 284 | + |
| 285 | + let(:find_succeeded_events) do |
| 286 | + subscriber.succeeded_events.select { |e| e.command_name == 'find' } |
| 287 | + end |
| 288 | + |
| 289 | + let(:options) { {} } |
| 290 | + |
| 291 | + after do |
| 292 | + authorized_client.use(:admin).command( |
| 293 | + configureFailPoint: 'failCommand', |
| 294 | + mode: 'off' |
| 295 | + ) |
| 296 | + client.close |
| 297 | + end |
| 298 | + |
| 299 | + context 'when error has SystemOverloadedError label' do |
| 300 | + let(:client) do |
| 301 | + authorized_client.with( |
| 302 | + retry_reads: true, |
| 303 | + read: { mode: :primary_preferred } |
| 304 | + ) |
| 305 | + end |
| 306 | + |
| 307 | + before do |
| 308 | + authorized_client.use(:admin).command( |
| 309 | + configureFailPoint: 'failCommand', |
| 310 | + mode: { times: 1 }, |
| 311 | + data: { |
| 312 | + failCommands: %w(find), |
| 313 | + errorCode: 6, |
| 314 | + errorLabels: %w(RetryableError SystemOverloadedError) |
| 315 | + } |
| 316 | + ) |
| 317 | + end |
| 318 | + |
| 319 | + it 'retries on a different server' do |
| 320 | + client.subscribe(Mongo::Monitoring::COMMAND, subscriber) |
| 321 | + subscriber.clear_events! |
| 322 | + expect { collection.find.first }.not_to raise_error |
| 323 | + expect(find_failed_events.length).to eq(1) |
| 324 | + expect(find_succeeded_events.length).to eq(1) |
| 325 | + expect(find_failed_events.first.address).not_to eq(find_succeeded_events.first.address) |
| 326 | + end |
| 327 | + end |
| 328 | + |
| 329 | + context 'when error does not have SystemOverloadedError label' do |
| 330 | + let(:client) do |
| 331 | + authorized_client.with( |
| 332 | + retry_reads: true, |
| 333 | + read: { mode: :primary_preferred } |
| 334 | + ) |
| 335 | + end |
| 336 | + |
| 337 | + before do |
| 338 | + authorized_client.use(:admin).command( |
| 339 | + configureFailPoint: 'failCommand', |
| 340 | + mode: { times: 1 }, |
| 341 | + data: { |
| 342 | + failCommands: %w(find), |
| 343 | + errorCode: 6, |
| 344 | + errorLabels: %w(RetryableError) |
| 345 | + } |
| 346 | + ) |
| 347 | + end |
| 348 | + |
| 349 | + it 'retries on the same server' do |
| 350 | + client.subscribe(Mongo::Monitoring::COMMAND, subscriber) |
| 351 | + subscriber.clear_events! |
| 352 | + expect { collection.find.first }.not_to raise_error |
| 353 | + expect(find_failed_events.length).to eq(1) |
| 354 | + expect(find_succeeded_events.length).to eq(1) |
| 355 | + expect(find_failed_events.first.address).to eq(find_succeeded_events.first.address) |
| 356 | + end |
| 357 | + end |
| 358 | + end |
274 | 359 | end |
0 commit comments