tree: 8f266e89df845e1de840d35012c437992efba0f3 [path history] [tgz]
  1. CMakeLists.txt
  2. gtest_assert_float_eq.h
  3. padded_buffer.cpp
  4. padded_buffer.h
  5. README.md
  6. test_approx.cpp
  7. test_aten.cpp
  8. test_base.h
  9. test_boundsinference.cpp
  10. test_conv.cpp
  11. test_cpp_codegen.cpp
  12. test_cuda.cpp
  13. test_dynamic_shapes.cpp
  14. test_expr.cpp
  15. test_external_calls.cpp
  16. test_graph_opt.cpp
  17. test_ir_printer.cpp
  18. test_ir_verifier.cpp
  19. test_kernel.cpp
  20. test_llvm.cpp
  21. test_loopnest.cpp
  22. test_memdependency.cpp
  23. test_memplanning.cpp
  24. test_ops.cpp
  25. test_quantization.cpp
  26. test_reductions.cpp
  27. test_registerizer.cpp
  28. test_simplify.cpp
  29. test_te_fuser_pass.cpp
  30. test_type.cpp
  31. test_type_specializations.cpp
  32. test_utils.h
  33. tutorial.cpp
test/cpp/tensorexpr/README.md

TensorExpr C++ Tests

How to add a new test

First, create a new test file. Test files should have be placed in this directory, with a name that starts with test_, like test_foo.cpp.

Here is an example test file you can copy-paste.

#include <test/cpp/tensorexpr/test_base.h>

// Tests go in torch::jit
namespace torch {
namespace jit {

// 1. Test cases are void() functions.
// 2. They start with the prefix `test`
void testCaseOne() {
    // ...
}

void testCaseTwo() {
    // ...
}
}
}

Then, register your test in tests.h:

// Add to TH_FORALL_TESTS_CUDA instead for CUDA-requiring tests
#define TH_FORALL_TESTS(_)             \
  _(ADFormulas)                        \
  _(Attributes)                        \
  ...
  _(CaseOne)  // note that the `test` prefix is omitted.
  _(CaseTwo)

We glob all the test files together in CMakeLists.txt so that you don't have to edit it every time you add a test. Unfortunately, this means that in order to get the build to pick up your new test file, you need to re-run cmake:

python setup.py build --cmake

How do I run the tests?

The following commands assume you are in PyTorch root.

# (re)build the test binary
ninja build/bin/test_tensorexpr
# run
build/bin/test_tensorexpr --gtest_filter='glob_style_filter*'