Lunderberg commented on a change in pull request #8532:
URL: https://github.com/apache/tvm/pull/8532#discussion_r693098290



##########
File path: python/tvm/testing/plugin.py
##########
@@ -0,0 +1,82 @@
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements.  See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership.  The ASF licenses this file
+# to you 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.
+
+"""Pytest plugin for using tvm testing extensions.
+
+TVM provides utilities for testing across all supported targets, and
+to more easily parametrize across many inputs.  For more information
+on usage of these features, see documentation in the tvm.testing
+module.
+
+These are enabled by default in all pytests provided by tvm, but may
+be useful externally for one-off testing.  To enable, add the
+following line to the test script, or to the conftest.py in the same
+directory as the test scripts.
+
+     pytest_plugins = ['tvm.testing.plugin']
+
+"""
+
+import pytest
+
+import tvm.testing.testing
+
+
+def pytest_configure(config):
+    """Runs at pytest configure time, defines marks to be used later."""
+    markers = {
+        "gpu": "mark a test as requiring a gpu",
+        "tensorcore": "mark a test as requiring a tensorcore",
+        "cuda": "mark a test as requiring cuda",
+        "opencl": "mark a test as requiring opencl",
+        "rocm": "mark a test as requiring rocm",
+        "vulkan": "mark a test as requiring vulkan",
+        "metal": "mark a test as requiring metal",
+        "llvm": "mark a test as requiring llvm",
+    }
+    for markername, desc in markers.items():
+        config.addinivalue_line("markers", "{}: {}".format(markername, desc))
+
+    print("enabled targets:", "; ".join(map(lambda x: x[0], 
tvm.testing.enabled_targets())))
+    print("pytest marker:", config.option.markexpr)
+
+
+def pytest_generate_tests(metafunc):
+    """Called once per unit test, modifies/parametrizes it as needed."""
+    tvm.testing.testing._auto_parametrize_target(metafunc)
+    tvm.testing.testing._parametrize_correlated_parameters(metafunc)
+
+
+def pytest_collection_modifyitems(config, items):
+    """Called after all tests are chosen, currently used for bookkeeping."""
+    # pylint: disable=unused-argument
+    tvm.testing.testing._count_num_fixture_uses(items)
+    tvm.testing.testing._remove_global_fixture_definitions(items)
+
+
+@pytest.fixture
+def dev(target):
+    """Give access to the device to tests that need it."""
+    return tvm.device(target)
+
+
+def pytest_sessionfinish(session, exitstatus):
+    # Don't exit with an error if we select a subset of tests that doesn't
+    # include anything
+    if session.config.option.markexpr != "":

Review comment:
       That's correct, yes.  This behavior predates the refactoring, and would 
have that effect.  Looking into the history, it looks like it was added in 
#6331.
   
   I'm not sure exactly what the desired behavior should be.  On the one hand, 
I agree that having an accidental mismatch between the calling scripts and the 
unit tests could erroneously say that the tests pass.  On the other hand, 
treating "no tests selected" as passing tests means that "for each environment, 
run all tests possible" is a valid strategy, and is something I'd want to move 
towards.




-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: commits-unsubscr...@tvm.apache.org

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org


Reply via email to