tree: 7163b2c9a091c08728461f4f9166d7b4c79532c4 [path history] [tgz]
  1. CMakeLists.txt
  2. README.md
  3. test_cl.h.c
  4. test_cl_egl.h.c
  5. test_cl_ext.h.c
  6. test_cl_ext_intel.h.c
  7. test_cl_gl.h.c
  8. test_cl_gl_ext.h.c
  9. test_cl_icd.h.c
  10. test_cl_platform.h.c
  11. test_cl_version.h.c
  12. test_headers.c
  13. test_opencl.h.c
tests/README.md

OpenCL-Headers/tests README

The test_headers.c test is designed to make sure that the various cl_typen types work and conform to expectation for recent versions of cl_platform.h. Conforming to these expectations make use of these types practical for developers writing portable code.

The various tests ending in .h.c are there to verify that the various OpenCL headers can compile stand alone. That is to ensure that they may be used a la carte. This provides developers a lifeline in the case that some unneeded part of OpenCL (e.g. cl/gl sharing) brings in a pile of symbols (e.g. all of OpenGL) that collides with other headers needed by the application. It is also poor form to require headers to be included in a particular order, especially if multiple systems require they be included in mutually incompatible order. So, here we require that each header can be used standalone so that the order is irrelevant.

We also check to make sure that the headers don't cause spurious warnings. These tests are intended to be compiled using the most stringent compiler flags available for the platform, within reason. All warnings should be errors and extra warnings that it is expected developers are likely to use should be turned on.