qixuan 36147b10f5 test: Add insert and upsert related cases for null and default value support (#36932) 14 小时之前
..
assets fcd71930c8 [skip e2e]Add recall test (#18562) 2 年之前
base cfd636ed5b test: add different language tests and modify some cases (#36465) 3 周之前
bulk_insert 571f0bc054 test: fix bulk insert case (#31738) 6 月之前
chaos a08000cfbf enhance:[skip e2e]update one pod mode resource (#34196) 3 月之前
check 0d57ff01a6 test: add null and default test cases (#36612) 2 周之前
common d566b0ceff test: add stats task feature cases and DefaultVectorSearchParams (#36768) 1 周之前
config 2f32623d16 [test]Fix occasional FileExistsError triggered when concurrently executing pytest (#26867) 1 年之前
customize 3336b91ce6 test: add channel exclusive balance test and resource group test (#33093) 4 月之前
deploy 241c71fdde enhance: use docker compose instead of docker-compose (#35208) 2 月之前
graphs 8f68b0f42b [skip ci]Update flow chart in chaos test readme (#13537) 2 年之前
load 5bb672d70d test: Add a new range search test for all indexes and align some index params (#32724) 5 月之前
loadbalance 6efb7afd3f test: add more request type checker for test (#29210) 10 月之前
milvus_client d17135d3bc test: Add alias test with rename collection (#36978) 4 天之前
rate_limit 4c1e7bc1bd Update rate limit test file (#18942) 2 年之前
resource_group 3336b91ce6 test: add channel exclusive balance test and resource group test (#33093) 4 月之前
scale 56693836ae [test] Add load balance verify in querynode scale test (#19028) (#19054) 2 年之前
standby 8c71e2bd64 Update milvs helm repo for ci (#28042) 11 月之前
testcases 36147b10f5 test: Add insert and upsert related cases for null and default value support (#36932) 14 小时之前
utils 3336b91ce6 test: add channel exclusive balance test and resource group test (#33093) 4 月之前
.dockerignore eff75c7701 Replace sdk source and merge tests and tests20 (#7182) 3 年之前
.gitignore 05fbbf2e33 [test]Update bulk insert test case and skip calc_distance testcases (#19855) 2 年之前
Dockerfile bb9bed64a3 enhance: new nightly ci to support testing distributed-streaming (#35672) 1 月之前
README.md 8394b3a1ec Block creating new error from status reason (#27426) 1 年之前
README_CN.md 506e0f6f7d [skip ci]Fix image size in readme (#13462) 2 年之前
conftest.py ba3b2a91a0 test: Remove useless common types and refine error assert in negative cases (#33023) 5 月之前
pytest.ini ca1f7ab019 test: update import test case to support different dim (#33709) 4 月之前
requirements.txt c96bbe19ba test: Add upsert in rows tests (#36820) 1 周之前
run.sh eff75c7701 Replace sdk source and merge tests and tests20 (#7182) 3 年之前

README.md

Guidelines for Test Framework

This document guides you through the Pytest-based PyMilvus test framework.

You can find the test code on GitHub.

Quick Start

Deploy Milvus

To accommodate the variety of requirements, Milvus offers as many as four deployment methods. PyMilvus supports Milvus deployed with any of the methods below:

  1. Build from source code
  2. Install with Docker Compose

  3. Install on Kunernetes

  4. Install with KinD

For test purposes, we recommend installing Milvus with KinD. KinD supports the ClickOnce deployment of Milvus and its test client. KinD deployment is tailored for scenarios with small data scale, such as development/debugging test cases and functional verification.

  • Prerequisites

  • Install KinD with script

    1. Enter the local directory of the code */milvus/tests/scripts/
    2. Build the KinD environment, and execute CI Regression test cases automatically:
   $ ./e2e-k8s.sh 
  • By default, KinD environment will be automatically cleaned up after the execution of the test case. If you need to keep the KinD environment:
   $ ./e2e-k8s.sh --skip-cleanup
  • Skip the automatic test case execution and keep the KinD environment:
   $ ./e2e-k8s.sh --skip-cleanup --skip-test --manual

Note: You need to log in to the containers of the test client to proceed manual execution and debugging of the test case.

  • See more script parameters:
$ ./e2e-k8s.sh --help
  • Export cluster logs:
$ kind export logs .

PyMilvus Test Environment Deployment and Case Execution

We recommend using Python 3 (3.8 or higher), consistent with the version supported by PyMilvus.

Note: Procedures listed below will be completed automatically if you deployed Milvus using KinD.

  1. Install the Python package prerequisite for the test, enter */milvus/tests/python_client/, and execute:
   $ pip install -r requirements.txt
  1. The default test log path is /tmp/ci_logs/ under the config directory. You can add environment variables to change the path before booting up test cases:
   $ export CI_LOG_PATH=/tmp/ci_logs/test/
Log Level Log File
debug ci_test_log.debug
info ci_test_log.log
error ci_test_log.err
  1. You can configure default parameters in pytest.ini under the root path. For instance:
   addopts = --host *.*.*.*  --html=/tmp/ci_logs/report.html

where host should be set as the IP address of the Milvus service, and *.html is the report generated for the test.

  1. Enter testcases directory, run following command, which is consistent with the command under the pytest framework, to execute the test case:
   $ python3 -W ignore -m pytest <test_file_name>

An Introduction to Test Modules

Module Overview

Module Overview

SDK Test Flow Chart

Working directories and files

  • base: stores the encapsulated PyMilvus module files, and setup & teardown functions for pytest framework.
  • check: stores the check module files for returned results from interface.
  • common: stores the files of common methods and parameters for test cases.
  • config: stores the basic configuration file.
  • testcases: stores test case scripts.
  • utils: stores utility programs, such as utility log and environment detection methods.
  • requirements.txt: specifies the python package required for executing test cases
  • conftest.py: you can compile fixture functions or local plugins in this file. These functions and plugins implement within the current folder and its subfolder.
  • pytest.ini: the main configuration file for pytest.

Critical design ideas

  • base/*_wrapper.py encapsulates the tested interface, uniformly processes requests from the interface, abstracts the returned results, and passes the results to check/func_check.py module for checking.
  • check/func_check.py encompasses result checking methods for each interface for invocation from test cases.
  • base/client_base.py uses pytest framework to process setup/teardown functions correspondingly.
  • Test case files in testcases folder should be compiled inheriting the TestcaseBase module from base/client_base.py. Compile the common methods and parameters used by test cases into the Common module for invocation.
  • Add global configurations under config directory, such as log path, etc.
  • Add global implementation methods under utils directory, such as utility log module.

Adding codes

This section specifies references while adding new test cases or framework tools.

Notice and best practices

  1. Coding style
  • Test files: each SDK category corresponds to a test file. So do load and search methods.

  • Test categories: test files fall into two categories

    • TestObjectParams:
    • Indicates the parameter test of corresponding interface. For instance, TestPartitionParams represents the parameter test for Partition interface.
    • Tests the target category/method under different parameter inputs. The parameter test will cover default, empty, none, datatype, maxsize, etc.
    • TestObjectOperations:
    • Indicates the function/operation test of corresponding interface. For instance, TestPartitionOperations represents the function/operation test for Partition interface.
    • Tests the target category/method with legit parameter inputs and interaction with other interfaces.
  • Testcase naming

    • TestObjectParams:

    • Name after the parameter input of the test case. For instance, test_partition_empty_name() represents test on performance with the empty string as the name parameter input.

    • TestObjectOperations

    • Name after the operation procedure of the test case. For instance, test_partition_drop_partition_twice() represents the test on the performance when dropping partitions twice consecutively.

    • Name after assertions. For instance, test_partition_maximum_partitions() represents test on the maximum number of partitions that can be created.

  1. Notice
  • Do not initialize PyMilvus objects in the test case files.
  • Generally, do not add log IDs to test case files.
  • Directly call the encapsulated methods or attributes in test cases, as shown below:

To create multiple partitions objects, call self.init_partition_wrap(), which returns the newly created partition objects. Call self.partition_wrap instead when you do not need multiple objects.

# create partition  -Call the default initialization method
partition_w = self.init_partition_wrap()
assert partition_w.is_empty
# create partition    -Directly call the encapsulated object
self.partition_wrap.init_partition(collection=collection_name, name=partition_name)
assert self.partition_wrap.is_empty
  • To test on the error or exception returned from interfaces:
    • Call check_task=CheckTasks.err_res.
    • Input the expected error ID and message.
  # create partition with collection is None
  self.partition_wrap.init_partition(collection=None, name=partition_name, check_task=CheckTasks.err_res, check_items={ct.err_code: 1, ct.err_msg: "'NoneType' object has no attribute"})
  • To test on the normal value returned from interfaces:
    • Call check_task=CheckTasks.check_partition_property. You can build new test methods in CheckTasks for invocation in test cases.
    • Input the expected result for test methods.
  # create partition
  partition_w = self.init_partition_wrap(collection_w, partition_name, check_task=CheckTasks.check_partition_property, check_items={"name": partition_name, "description": description, "is_empty": True, "num_entities": 0})
  1. Adding test cases
  • Find the encapsulated tested interface with the same name in the *_wrapper.py files under base directory. Each interface returns a list with two values, among which one is interface returned results of PyMilvus, and the other is the assertion of normal/abnormal results, i.e. True/False. The returned judgment can be used in the extra result checking of test cases.
  • Add the test cases in the corresponding test file of the tested interface in testcases folder. You can refer to all test files under this directory to create your own test cases as shown below:
   @pytest.mark.tags(CaseLabel.L1)
   @pytest.mark.parametrize("partition_name", [cf.gen_unique_str(prefix)])
   def test_partition_dropped_collection(self, partition_name):
       """
       target: verify create partition against a dropped collection
       method: 1. create collection1
               2. drop collection1
               3. create partition in collection1
       expected: raise exception
       """
       # create collection
       collection_w = self.init_collection_wrap()
       # drop collection
       collection_w.drop()
       # create partition failed
       self.partition_wrap.init_partition(collection_w.collection, partition_name, check_task=CheckTasks.err_res, check_items={ct.err_code: 4, ct.err_msg: "collection not found"})
  • Tips

    • Case comments encompass three parts: object, test method, and expected result. You should specify each part.
    • Initialize the tested category in the setup method of the Base category in the base/client_base.py file, as shown below:

      self.connection_wrap = ApiConnectionsWrapper()
      self.utility_wrap = ApiUtilityWrapper()
      self.collection_wrap = ApiCollectionWrapper()
      self.partition_wrap = ApiPartitionWrapper()
      self.index_wrap = ApiIndexWrapper()
      self.collection_schema_wrap = ApiCollectionSchemaWrapper()
      self.field_schema_wrap = ApiFieldSchemaWrapper()
      
      • Pass the parameters with corresponding encapsulated methods when calling the interface you need to test on. As shown below, align all parameters with those in PyMilvus interfaces except for check_task and check_items. python def init_partition(self, collection, name, description="", check_task=None, check_items=None, **kwargs)
    • check_task is used to select the corresponding interface test method in the ResponseChecker check category in the check/func_check.py file. You can choose methods under the CheckTasks category in the common/common_type.py file.

    • The specific content of check_items passed to the test method is determined by the implemented test method check_task.

    • The tested interface can return normal results when CheckTasks and check_items are not passed.

  1. Adding framework functions
  • Add global methods or tools under utils directory.

  • Add corresponding configurations under config directory.