Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: TEST_DL_PATHS to multi-args #2825

Merged
merged 2 commits into from
Mar 26, 2024
Merged

Conversation

LecrisUT
Copy link
Contributor

@LecrisUT LecrisUT commented Feb 26, 2024

Description

As @daniel-slater mentioned in #2736, the issue was that TEST_DL_PATHS in CatchAddTests.cmake should be a multi-argument variable. I have tested it against a generator-expression input like:

	list(APPEND extra_args
			DL_PATHS "$<TARGET_RUNTIME_DLL_DIRS:test-suite>"
	)

example_run

I did not add proper tests to check for this issue because I couldn't find any functional tests that run ctest --build-and-test, and that would require some discussion on how to structure and place these.

Also note that there is a much cleaner approach by automatically adding TARGET_RUNTIME_DLL_DIRS, which I will try to do in another PR.

GitHub Issues

Closes #2736

Copy link

codecov bot commented Feb 26, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 91.20%. Comparing base (ed6ac8a) to head (2558001).
Report is 17 commits behind head on devel.

❗ Current head 2558001 differs from pull request most recent head a6627f8. Consider uploading reports for the commit a6627f8 to get more accurate results

Additional details and impacted files
@@            Coverage Diff             @@
##            devel    #2825      +/-   ##
==========================================
+ Coverage   91.19%   91.20%   +0.01%     
==========================================
  Files         197      197              
  Lines        8374     8374              
==========================================
+ Hits         7636     7637       +1     
+ Misses        738      737       -1     

@LecrisUT LecrisUT changed the title Try to switch TEST_DL_PATHS to multi-args fix: TEST_DL_PATHS to multi-args Feb 26, 2024
@horenmar horenmar added the Extras Touches utility scripts outside of Catch2 proper, e.g. CMake integration. label Feb 27, 2024
@horenmar
Copy link
Member

Re tests: I am not sure whether the DL_PATHS property shows up under --show-only=json-v1. If the answer is yes, then we can just inspect the CTest configuration to see whether there are indeed multiple dl paths shown.

There is already a test that configures build, runs catch_discover_tests and then inspects the output from ctest, in tests/TestScripts/DiscoverTests/. This could be slotted in there easily.

@LecrisUT
Copy link
Contributor Author

There is already a test that configures build, runs catch_discover_tests and then inspects the output from ctest, in tests/TestScripts/DiscoverTests/. This could be slotted in there easily.

Cool I can add the test-case there. By default I think it should be using 2 DLLs, unless we need to add a dummy library target. I think functional tests like that should use the built-in ctest --build-and-test since it can more easily forward the generator, compilers, etc. and does not require any installation of catch. A complex framework that can do all checks and everything would be how upstream CMake does it, but for this project a simple run and test ctest should be fine.

@LecrisUT LecrisUT force-pushed the fix/dl_paths branch 2 times, most recently from 8d5d93e to b133498 Compare February 28, 2024 10:53
@horenmar
Copy link
Member

I see you added the setting to the CMakeLists for the tests, but there is no check in the script that runs the test. Do you intend to pursue this further?

@LecrisUT
Copy link
Contributor Author

It is partly implicitly added, i.e. by TARGET_RUNTIME_DLL_DIRS:tests should contain the DLL_DIRS for tests.exe and catch.dll. I did not double-check this though, but if I am wrong, we can fix it by adding a dummy lib.cpp and library target to link it to where we put a simple 1+1=2 test or something.

@horenmar horenmar merged commit 3cd90c5 into catchorg:devel Mar 26, 2024
70 of 71 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Extras Touches utility scripts outside of Catch2 proper, e.g. CMake integration.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

catch_discover_tests() DL_PATHS can't handle two or more paths
2 participants