mongo-python-driver/test/test_comment.py
2024-06-06 09:01:24 -07:00

184 lines
6.8 KiB
Python

# Copyright 2022-present MongoDB, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Test the keyword argument 'comment' in various helpers."""
from __future__ import annotations
import inspect
import sys
sys.path[0:0] = [""]
from test import IntegrationTest, client_context, unittest
from test.utils import EventListener, rs_or_single_client
from bson.dbref import DBRef
from pymongo.synchronous.command_cursor import CommandCursor
from pymongo.synchronous.operations import IndexModel
class Empty:
def __getattr__(self, item):
try:
self.__dict__[item]
except KeyError:
return self.empty
def empty(self, *args, **kwargs):
return Empty()
class TestComment(IntegrationTest):
def _test_ops(
self,
helpers,
already_supported,
listener,
db=Empty(), # noqa: B008
coll=Empty(), # noqa: B008
):
for h, args in helpers:
c = "testing comment with " + h.__name__
with self.subTest("collection-" + h.__name__ + "-comment"):
for cc in [c, {"key": c}, ["any", 1]]:
listener.reset()
kwargs = {"comment": cc}
if h == coll.rename:
_ = db.get_collection("temp_temp_temp").drop()
destruct_coll = db.get_collection("test_temp")
destruct_coll.insert_one({})
maybe_cursor = destruct_coll.rename(*args, **kwargs)
destruct_coll.drop()
elif h == db.validate_collection:
coll = db.get_collection("test")
coll.insert_one({})
maybe_cursor = db.validate_collection(*args, **kwargs)
else:
coll.create_index("a")
maybe_cursor = h(*args, **kwargs)
self.assertIn(
"comment",
inspect.signature(h).parameters,
msg="Could not find 'comment' in the "
"signature of function %s" % (h.__name__),
)
self.assertEqual(
inspect.signature(h).parameters["comment"].annotation, "Optional[Any]"
)
if isinstance(maybe_cursor, CommandCursor):
maybe_cursor.close()
tested = False
# For some reason collection.list_indexes creates two commands and the first
# one doesn't contain 'comment'.
for i in listener.started_events:
if cc == i.command.get("comment", ""):
self.assertEqual(cc, i.command["comment"])
tested = True
self.assertTrue(tested)
if h not in [coll.aggregate_raw_batches]:
self.assertIn(
":param comment:",
h.__doc__,
)
if h not in already_supported:
self.assertIn(
"Added ``comment`` parameter",
h.__doc__,
)
else:
self.assertNotIn(
"Added ``comment`` parameter",
h.__doc__,
)
listener.reset()
@client_context.require_version_min(4, 7, -1)
@client_context.require_replica_set
def test_database_helpers(self):
listener = EventListener()
db = rs_or_single_client(event_listeners=[listener]).db
helpers = [
(db.watch, []),
(db.command, ["hello"]),
(db.list_collections, []),
(db.list_collection_names, []),
(db.drop_collection, ["hello"]),
(db.validate_collection, ["test"]),
(db.dereference, [DBRef("collection", 1)]),
]
already_supported = [db.command, db.list_collections, db.list_collection_names]
self._test_ops(helpers, already_supported, listener, db=db, coll=db.get_collection("test"))
@client_context.require_version_min(4, 7, -1)
@client_context.require_replica_set
def test_client_helpers(self):
listener = EventListener()
cli = rs_or_single_client(event_listeners=[listener])
helpers = [
(cli.watch, []),
(cli.list_databases, []),
(cli.list_database_names, []),
(cli.drop_database, ["test"]),
]
already_supported = [
cli.list_databases,
]
self._test_ops(helpers, already_supported, listener)
@client_context.require_version_min(4, 7, -1)
def test_collection_helpers(self):
listener = EventListener()
db = rs_or_single_client(event_listeners=[listener])[self.db.name]
coll = db.get_collection("test")
helpers = [
(coll.list_indexes, []),
(coll.drop, []),
(coll.index_information, []),
(coll.options, []),
(coll.aggregate, [[{"$set": {"x": 1}}]]),
(coll.aggregate_raw_batches, [[{"$set": {"x": 1}}]]),
(coll.rename, ["temp_temp_temp"]),
(coll.distinct, ["_id"]),
(coll.find_one_and_delete, [{}]),
(coll.find_one_and_replace, [{}, {}]),
(coll.find_one_and_update, [{}, {"$set": {"a": 1}}]),
(coll.estimated_document_count, []),
(coll.count_documents, [{}]),
(coll.create_indexes, [[IndexModel("a")]]),
(coll.create_index, ["a"]),
(coll.drop_index, [[("a", 1)]]),
(coll.drop_indexes, []),
]
already_supported = [
coll.estimated_document_count,
coll.count_documents,
coll.create_indexes,
coll.drop_indexes,
coll.options,
coll.find_one_and_replace,
coll.drop_index,
coll.rename,
coll.distinct,
coll.find_one_and_delete,
coll.find_one_and_update,
]
self._test_ops(helpers, already_supported, listener, coll=coll, db=db)
if __name__ == "__main__":
unittest.main()