ROOTPLOIT
Server: LiteSpeed
System: Linux in-mum-web1878.main-hosting.eu 5.14.0-570.21.1.el9_6.x86_64 #1 SMP PREEMPT_DYNAMIC Wed Jun 11 07:22:35 EDT 2025 x86_64
User: u435929562 (435929562)
PHP: 7.4.33
Disabled: system, exec, shell_exec, passthru, mysql_list_dbs, ini_alter, dl, symlink, link, chgrp, leak, popen, apache_child_terminate, virtual, mb_send_mail
Upload Files
File: //opt/go/pkg/mod/go.mongodb.org/[email protected]/testdata/run-command/runCommand.yml
description: runCommand

schemaVersion: "1.3"

createEntities:
  - client:
      id: &client client
      useMultipleMongoses: false
      observeEvents: [commandStartedEvent]
  - database:
      id: &db db
      client: *client
      databaseName: *db
  - collection:
      id: &collection collection
      database: *db
      collectionName: *collection
  - database:
      id: &dbWithRC dbWithRC
      client: *client
      databaseName: *dbWithRC
      databaseOptions:
        readConcern: { level: 'local' }
  - database:
      id: &dbWithWC dbWithWC
      client: *client
      databaseName: *dbWithWC
      databaseOptions:
        writeConcern: { w: 0 }
  - session:
      id: &session session
      client: *client
  # Stable API test
  - client:
      id: &clientWithStableApi clientWithStableApi
      observeEvents: [commandStartedEvent]
      serverApi:
        version: "1"
        strict: true
  - database:
      id: &dbWithStableApi dbWithStableApi
      client: *clientWithStableApi
      databaseName: *dbWithStableApi

initialData:
- collectionName: *collection
  databaseName: *db
  documents: []

tests:
  - description: always attaches $db and implicit lsid to given command and omits default readPreference
    operations:
      - name: runCommand
        object: *db
        arguments:
          commandName: ping
          command: { ping: 1 }
        expectResult: { ok: 1 }
    expectEvents:
      - client: *client
        events:
          - commandStartedEvent:
              command:
                ping: 1
                $db: *db
                lsid: { $$exists: true }
                $readPreference: { $$exists: false }
              commandName: ping

  - description: always gossips the $clusterTime on the sent command
    runOnRequirements:
      # Only replicasets and sharded clusters have a $clusterTime
      - topologies: [ replicaset, sharded ]
    operations:
      # We have to run one command to obtain a clusterTime to gossip
      - name: runCommand
        object: *db
        arguments:
          commandName: ping
          command: { ping: 1 }
        expectResult: { ok: 1 }
      - name: runCommand
        object: *db
        arguments:
          commandName: ping
          command: { ping: 1 }
        expectResult: { ok: 1 }
    expectEvents:
      - client: *client
        events:
          - commandStartedEvent:
              commandName: ping
          # Only check the shape of the second ping which should have the $clusterTime received from the first operation
          - commandStartedEvent:
              command:
                ping: 1
                $clusterTime: { $$exists: true }
              commandName: ping

  - description: attaches the provided session lsid to given command
    operations:
      - name: runCommand
        object: *db
        arguments:
          commandName: ping
          command: { ping: 1 }
          session: *session
        expectResult: { ok: 1 }
    expectEvents:
      - client: *client
        events:
          - commandStartedEvent:
              command:
                ping: 1
                lsid: { $$sessionLsid: *session }
                $db: *db
              commandName: ping

  - description: attaches the provided $readPreference to given command
    runOnRequirements:
      # Exclude single topology, which is most likely a standalone server
      - topologies: [ replicaset, sharded-replicaset, load-balanced, sharded ]
    operations:
      - name: runCommand
        object: *db
        arguments:
          commandName: ping
          command: { ping: 1 }
          readPreference:  &readPreference { mode: 'nearest' }
        expectResult: { ok: 1 }
    expectEvents:
      - client: *client
        events:
          - commandStartedEvent:
              command:
                ping: 1
                $readPreference: *readPreference
                $db: *db
              commandName: ping

  - description: does not attach $readPreference to given command on standalone
    runOnRequirements:
      # This test assumes that the single topology contains a standalone server;
      # however, it is possible for a single topology to contain a direct
      # connection to another server type.
      # See: https://github.com/mongodb/specifications/blob/master/source/server-selection/server-selection.rst#topology-type-single
      - topologies: [ single ]
    operations:
      - name: runCommand
        object: *db
        arguments:
          commandName: ping
          command: { ping: 1 }
          readPreference: { mode: 'nearest' }
        expectResult: { ok: 1 }
    expectEvents:
      - client: *client
        events:
          - commandStartedEvent:
              command:
                ping: 1
                $readPreference: { $$exists: false }
                $db: *db
              commandName: ping

  - description: does not attach primary $readPreference to given command
    operations:
      - name: runCommand
        object: *db
        arguments:
          commandName: ping
          command: { ping: 1 }
          readPreference: { mode: 'primary' }
        expectResult: { ok: 1 }
    expectEvents:
      - client: *client
        events:
          - commandStartedEvent:
              command:
                ping: 1
                $readPreference: { $$exists: false }
                $db: *db
              commandName: ping

  - description: does not inherit readConcern specified at the db level
    operations:
      - name: runCommand
        object: *dbWithRC
        # Test with a command that supports a readConcern option.
        # expectResult is intentionally omitted because some drivers
        # may automatically convert command responses into cursors.
        arguments:
          commandName: aggregate
          command: { aggregate: *collection, pipeline: [], cursor: {} }
    expectEvents:
      - client: *client
        events:
          - commandStartedEvent:
              command:
                aggregate: *collection
                readConcern: { $$exists: false }
                $db: *dbWithRC
              commandName: aggregate

  - description: does not inherit writeConcern specified at the db level
    operations:
      - name: runCommand
        object: *dbWithWC
        arguments:
          commandName: insert
          command:
            insert: *collection
            documents: [ { foo: 'bar' } ]
            ordered: true
        expectResult: { ok: 1 }
    expectEvents:
      - client: *client
        events:
          - commandStartedEvent:
              command:
                insert: *collection
                writeConcern: { $$exists: false }
                $db: *dbWithWC
              commandName: insert

  - description: does not retry retryable errors on given command
    runOnRequirements:
      - minServerVersion: "4.2"
    operations:
      - name: failPoint
        object: testRunner
        arguments:
          client: *client
          failPoint:
            configureFailPoint: failCommand
            mode: { times: 1 }
            data:
              failCommands: [ping]
              closeConnection: true
      - name: runCommand
        object: *db
        arguments:
          commandName: ping
          command: { ping: 1 }
        expectError:
          isClientError: true

  - description: attaches transaction fields to given command
    runOnRequirements:
      - minServerVersion: "4.0"
        topologies: [ replicaset ]
      - minServerVersion: "4.2"
        topologies: [ sharded-replicaset, load-balanced ]
    operations:
      - name: withTransaction
        object: *session
        arguments:
          callback:
            - name: runCommand
              object: *db
              arguments:
                session: *session
                commandName: insert
                command:
                  insert: *collection
                  documents: [ { foo: 'transaction' } ]
                  ordered: true
              expectResult: { $$unsetOrMatches: { insertedId: { $$unsetOrMatches: 1 } } }
    expectEvents:
      - client: *client
        events:
          - commandStartedEvent:
              command:
                insert: *collection
                documents: [ { foo: 'transaction' } ]
                ordered: true
                lsid: { $$sessionLsid: *session }
                txnNumber: 1
                startTransaction: true
                autocommit: false
                # omitted fields
                readConcern: { $$exists: false }
                writeConcern: { $$exists: false }
              commandName: insert
              databaseName: *db
          - commandStartedEvent:
              command:
                commitTransaction: 1
                lsid: { $$sessionLsid: *session }
                txnNumber: 1
                autocommit: false
                # omitted fields
                writeConcern: { $$exists: false }
                readConcern: { $$exists: false }
              commandName: commitTransaction
              databaseName: admin

  - description: attaches apiVersion fields to given command when stableApi is configured on the client
    runOnRequirements:
      - minServerVersion: "5.0"
    operations:
      - name: runCommand
        object: *dbWithStableApi
        arguments:
          commandName: ping
          command:
            ping: 1
        expectResult: { ok: 1 }
    expectEvents:
      - client: *clientWithStableApi
        events:
          - commandStartedEvent:
              command:
                ping: 1
                $db: *dbWithStableApi
                apiVersion: "1"
                apiStrict: true
                apiDeprecationErrors: { $$unsetOrMatches: false }
              commandName: ping