1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131
|
.. role:: javascript(code)
:language: javascript
==================
Command Monitoring
==================
.. contents::
--------
Testing
=======
Tests in ``unified`` are implemented in the `Unified Test Format <../../unified-test-format/unified-test-format.rst>`__ and require
schema version 1.0. Tests in ``legacy`` should be run as described below.
Tests are provided in YML and JSON format to assert proper upconversion of commands.
Database and Collection Names
-----------------------------
The collection under test is specified in each test file with the fields
``database_name`` and ``collection_name``.
Data
----
The ``data`` at the beginning of each test file is the data that should exist in the
collection under test before each test run.
Expectations
------------
Fake Placeholder Values
```````````````````````
When an attribute in an expectation contains the value ``"42"``, ``42`` or ``""``, this is a fake
placeholder value indicating that a special case MUST be tested that could not be
expressed in a YAML or JSON test. These cases are as follows:
Cursor Matching
^^^^^^^^^^^^^^^
When encountering a ``cursor`` or ``getMore`` value of ``"42"`` in a test, the driver MUST assert
that the values are equal to each other and greater than zero.
Errors
^^^^^^
For write errors, ``code`` values of ``42`` MUST assert that the value is present and
greater than zero. ``errmsg`` values of ``""`` MUST assert that the value is not empty
(a string of length greater than 1).
OK Values
^^^^^^^^^
The server is inconsistent on whether the ok values returned are integers or doubles so
for simplicity the tests specify all expected values as doubles. Server 'ok' values of
integers MUST be converted to doubles for comparison with the expected values.
Additional Values
`````````````````
The expected events provide the minimum data that is required and can be tested. It is
possible for more values to be present in the events, such as extra data provided when
using sharded clusters or ``nModified`` field in updates. The driver MUST assert the
expected data is present and also MUST allow for additional data to be present as well
at the top level of the command document or reply document.
For example, say the client sends a causally-consistent "distinct" command with
readConcern level "majority", like::
{
"distinct": "collection",
"key": "key",
"readConcern":{
"afterClusterTime": {"$timestamp":{"t":1522336030,"i":1}},
"level":"majority"
},
"$clusterTime": {
"clusterTime": { "$timestamp": { "i": 1, "t": 1522335530 } },
"signature": {
"hash": { "$binary": "AAAAAAAAAAAAAAAAAAAAAAAAAAA=", "$type": "00" },
"keyId": { "$numberLong": "0" }
}
},
"lsid": {
"id": { "$binary": "RaigP3oASqu+galPvRAfcg==", "$type": "04" }
}
}
Then it would pass a command-started event like the following YAML, because the
fields not mentioned in the YAML are ignored::
command:
distinct: collection
key: key
However, if there are fields in command subdocuments that are not mentioned in
the YAML, then the command does *not* pass the test::
command:
distinct: collection
key: key
# Fails because the expected readConcern has no "afterClusterTime".
readConcern:
level: majority
Ignoring Tests Based On Server Version or Topology Type
```````````````````````````````````````````````````````
Due to variations in server behavior, some tests may not be valid and MUST NOT be run on
certain server versions or topology types. These tests are indicated with any of the
following fields, which will be optionally provided at the ``description`` level of each
test:
- ``ignore_if_server_version_greater_than`` (optional): If specified, the test MUST be
skipped if the minor version of the server is greater than this minor version. The
server's patch version MUST NOT be considered. For example, a value of ``3.0`` implies
that the test can run on server version ``3.0.15`` but not ``3.1.0``.
- ``ignore_if_server_version_less_than`` (optional): If specified, the test MUST be
skipped if the minor version of the server is less than this minor version. The
server's patch version MUST NOT be considered. For example, a value of ``3.2`` implies
that the test can run on server version ``3.2.0`` but not ``3.0.15``.
- ``ignore_if_topology_type`` (optional): An array of server topologies for which the test
MUST be skipped. Valid topologies are "single", "replicaset", and "sharded".
Tests that have none of these fields MUST be run on all supported server versions.
|