{
  "runOn": [
    {
      "minServerVersion": "4.0",
      "topology": [
        "single",
        "replicaset"
      ]
    },
    {
      "minServerVersion": "4.1.7",
      "topology": [
        "sharded",
        "load-balanced"
      ]
    }
  ],
  "database_name": "retryable-reads-tests",
  "bucket_name": "fs",
  "data": {
    "fs.files": [
      {
        "_id": {
          "$oid": "000000000000000000000001"
        },
        "length": 1,
        "chunkSize": 4,
        "uploadDate": {
          "$date": "1970-01-01T00:00:00.000Z"
        },
        "filename": "abc",
        "metadata": {}
      }
    ],
    "fs.chunks": [
      {
        "_id": {
          "$oid": "000000000000000000000002"
        },
        "files_id": {
          "$oid": "000000000000000000000001"
        },
        "n": 0,
        "data": {
          "$binary": {
            "base64": "EQ==",
            "subType": "00"
          }
        }
      }
    ]
  },
  "tests": [
    {
      "description": "Download succeeds after InterruptedAtShutdown",
      "failPoint": {
        "configureFailPoint": "failCommand",
        "mode": {
          "times": 1
        },
        "data": {
          "failCommands": [
            "find"
          ],
          "errorCode": 11600
        }
      },
      "operations": [
        {
          "name": "download",
          "object": "gridfsbucket",
          "arguments": {
            "id": {
              "$oid": "000000000000000000000001"
            }
          }
        }
      ],
      "expectations": [
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.chunks",
              "filter": {
                "files_id": {
                  "$oid": "000000000000000000000001"
                }
              },
              "sort": {
                "n": 1
              }
            },
            "database_name": "retryable-reads-tests"
          }
        }
      ]
    },
    {
      "description": "Download succeeds after InterruptedDueToReplStateChange",
      "failPoint": {
        "configureFailPoint": "failCommand",
        "mode": {
          "times": 1
        },
        "data": {
          "failCommands": [
            "find"
          ],
          "errorCode": 11602
        }
      },
      "operations": [
        {
          "name": "download",
          "object": "gridfsbucket",
          "arguments": {
            "id": {
              "$oid": "000000000000000000000001"
            }
          }
        }
      ],
      "expectations": [
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.chunks",
              "filter": {
                "files_id": {
                  "$oid": "000000000000000000000001"
                }
              },
              "sort": {
                "n": 1
              }
            },
            "database_name": "retryable-reads-tests"
          }
        }
      ]
    },
    {
      "description": "Download succeeds after NotWritablePrimary",
      "failPoint": {
        "configureFailPoint": "failCommand",
        "mode": {
          "times": 1
        },
        "data": {
          "failCommands": [
            "find"
          ],
          "errorCode": 10107
        }
      },
      "operations": [
        {
          "name": "download",
          "object": "gridfsbucket",
          "arguments": {
            "id": {
              "$oid": "000000000000000000000001"
            }
          }
        }
      ],
      "expectations": [
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.chunks",
              "filter": {
                "files_id": {
                  "$oid": "000000000000000000000001"
                }
              },
              "sort": {
                "n": 1
              }
            },
            "database_name": "retryable-reads-tests"
          }
        }
      ]
    },
    {
      "description": "Download succeeds after NotPrimaryNoSecondaryOk",
      "failPoint": {
        "configureFailPoint": "failCommand",
        "mode": {
          "times": 1
        },
        "data": {
          "failCommands": [
            "find"
          ],
          "errorCode": 13435
        }
      },
      "operations": [
        {
          "name": "download",
          "object": "gridfsbucket",
          "arguments": {
            "id": {
              "$oid": "000000000000000000000001"
            }
          }
        }
      ],
      "expectations": [
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.chunks",
              "filter": {
                "files_id": {
                  "$oid": "000000000000000000000001"
                }
              },
              "sort": {
                "n": 1
              }
            },
            "database_name": "retryable-reads-tests"
          }
        }
      ]
    },
    {
      "description": "Download succeeds after NotPrimaryOrSecondary",
      "failPoint": {
        "configureFailPoint": "failCommand",
        "mode": {
          "times": 1
        },
        "data": {
          "failCommands": [
            "find"
          ],
          "errorCode": 13436
        }
      },
      "operations": [
        {
          "name": "download",
          "object": "gridfsbucket",
          "arguments": {
            "id": {
              "$oid": "000000000000000000000001"
            }
          }
        }
      ],
      "expectations": [
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.chunks",
              "filter": {
                "files_id": {
                  "$oid": "000000000000000000000001"
                }
              },
              "sort": {
                "n": 1
              }
            },
            "database_name": "retryable-reads-tests"
          }
        }
      ]
    },
    {
      "description": "Download succeeds after PrimarySteppedDown",
      "failPoint": {
        "configureFailPoint": "failCommand",
        "mode": {
          "times": 1
        },
        "data": {
          "failCommands": [
            "find"
          ],
          "errorCode": 189
        }
      },
      "operations": [
        {
          "name": "download",
          "object": "gridfsbucket",
          "arguments": {
            "id": {
              "$oid": "000000000000000000000001"
            }
          }
        }
      ],
      "expectations": [
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.chunks",
              "filter": {
                "files_id": {
                  "$oid": "000000000000000000000001"
                }
              },
              "sort": {
                "n": 1
              }
            },
            "database_name": "retryable-reads-tests"
          }
        }
      ]
    },
    {
      "description": "Download succeeds after ShutdownInProgress",
      "failPoint": {
        "configureFailPoint": "failCommand",
        "mode": {
          "times": 1
        },
        "data": {
          "failCommands": [
            "find"
          ],
          "errorCode": 91
        }
      },
      "operations": [
        {
          "name": "download",
          "object": "gridfsbucket",
          "arguments": {
            "id": {
              "$oid": "000000000000000000000001"
            }
          }
        }
      ],
      "expectations": [
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.chunks",
              "filter": {
                "files_id": {
                  "$oid": "000000000000000000000001"
                }
              },
              "sort": {
                "n": 1
              }
            },
            "database_name": "retryable-reads-tests"
          }
        }
      ]
    },
    {
      "description": "Download succeeds after HostNotFound",
      "failPoint": {
        "configureFailPoint": "failCommand",
        "mode": {
          "times": 1
        },
        "data": {
          "failCommands": [
            "find"
          ],
          "errorCode": 7
        }
      },
      "operations": [
        {
          "name": "download",
          "object": "gridfsbucket",
          "arguments": {
            "id": {
              "$oid": "000000000000000000000001"
            }
          }
        }
      ],
      "expectations": [
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.chunks",
              "filter": {
                "files_id": {
                  "$oid": "000000000000000000000001"
                }
              },
              "sort": {
                "n": 1
              }
            },
            "database_name": "retryable-reads-tests"
          }
        }
      ]
    },
    {
      "description": "Download succeeds after HostUnreachable",
      "failPoint": {
        "configureFailPoint": "failCommand",
        "mode": {
          "times": 1
        },
        "data": {
          "failCommands": [
            "find"
          ],
          "errorCode": 6
        }
      },
      "operations": [
        {
          "name": "download",
          "object": "gridfsbucket",
          "arguments": {
            "id": {
              "$oid": "000000000000000000000001"
            }
          }
        }
      ],
      "expectations": [
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.chunks",
              "filter": {
                "files_id": {
                  "$oid": "000000000000000000000001"
                }
              },
              "sort": {
                "n": 1
              }
            },
            "database_name": "retryable-reads-tests"
          }
        }
      ]
    },
    {
      "description": "Download succeeds after NetworkTimeout",
      "failPoint": {
        "configureFailPoint": "failCommand",
        "mode": {
          "times": 1
        },
        "data": {
          "failCommands": [
            "find"
          ],
          "errorCode": 89
        }
      },
      "operations": [
        {
          "name": "download",
          "object": "gridfsbucket",
          "arguments": {
            "id": {
              "$oid": "000000000000000000000001"
            }
          }
        }
      ],
      "expectations": [
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.chunks",
              "filter": {
                "files_id": {
                  "$oid": "000000000000000000000001"
                }
              },
              "sort": {
                "n": 1
              }
            },
            "database_name": "retryable-reads-tests"
          }
        }
      ]
    },
    {
      "description": "Download succeeds after SocketException",
      "failPoint": {
        "configureFailPoint": "failCommand",
        "mode": {
          "times": 1
        },
        "data": {
          "failCommands": [
            "find"
          ],
          "errorCode": 9001
        }
      },
      "operations": [
        {
          "name": "download",
          "object": "gridfsbucket",
          "arguments": {
            "id": {
              "$oid": "000000000000000000000001"
            }
          }
        }
      ],
      "expectations": [
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.chunks",
              "filter": {
                "files_id": {
                  "$oid": "000000000000000000000001"
                }
              },
              "sort": {
                "n": 1
              }
            },
            "database_name": "retryable-reads-tests"
          }
        }
      ]
    },
    {
      "description": "Download fails after two NotWritablePrimary errors",
      "failPoint": {
        "configureFailPoint": "failCommand",
        "mode": {
          "times": 2
        },
        "data": {
          "failCommands": [
            "find"
          ],
          "errorCode": 10107
        }
      },
      "operations": [
        {
          "name": "download",
          "object": "gridfsbucket",
          "arguments": {
            "id": {
              "$oid": "000000000000000000000001"
            }
          },
          "error": true
        }
      ],
      "expectations": [
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        },
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        }
      ]
    },
    {
      "description": "Download fails after NotWritablePrimary when retryReads is false",
      "clientOptions": {
        "retryReads": false
      },
      "failPoint": {
        "configureFailPoint": "failCommand",
        "mode": {
          "times": 1
        },
        "data": {
          "failCommands": [
            "find"
          ],
          "errorCode": 10107
        }
      },
      "operations": [
        {
          "name": "download",
          "object": "gridfsbucket",
          "arguments": {
            "id": {
              "$oid": "000000000000000000000001"
            }
          },
          "error": true
        }
      ],
      "expectations": [
        {
          "command_started_event": {
            "command": {
              "find": "fs.files",
              "filter": {
                "_id": {
                  "$oid": "000000000000000000000001"
                }
              }
            },
            "database_name": "retryable-reads-tests"
          }
        }
      ]
    }
  ]
}