-
Notifications
You must be signed in to change notification settings - Fork 267
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
[SR-1944] [corelibs-xctest] Replace xctest-checker with FileCheck #383
Comments
@ddunbar has also talked about distributing some of the LLVM tools in the development snapshot packages. |
Yes, I even have a patch for putting FileCheck in, but its gotten buried under other stuff unfortunately. |
Yeah, that'd be great, too. I wouldn't mind doing this as an intermediary step. Once FileCheck is included in the Swift toolchain, we can use its location as a default value for the |
Thanks for writing this up, @modocache! xctest-checker has served us well, but I think we will end up appreciating the lightened maintenance burden of using the standard tooling. One further consideration before doing away with xctest-checker is that it does have a small amount of extra Xcode integration which we wouldn't get from FileCheck as far as I know. Discussion here. I would love to see us put together a patch adding this to FileCheck! Still, I wouldn't consider that a blocker for moving ahead with the migration proposed here. @ddunbar is your patch available in a PR or branch somewhere? Is it just a matter of someone having time to follow up on getting it merged? |
For reference on the topic of Xcode-friendly output in FileCheck, here's FileCheck's current output: /path/to/FileName.m:13:16: error: expected string not found in input
// CHECK-NEXT: Tsdasdaest Case '-[FailureTestCase test_fails]' started.
^
<stdin>:4:1: note: scanning from here
Test Case '-[FailureTestCase test_fails]' started.
^ To get this to display properly in Xcode, I think we'd need something like this: /path/to/FileName.m:13:16: error: expected string not found in input
Actual: Test Case '-[FailureTestCase test_fails]' started.
Expected: // CHECK-NEXT: Tsdasdaest Case '-[FailureTestCase test_fails]' started. This seems like a big change – should FileCheck take a |
@ddunbar: Does your patch include the LLVM utility // RUN: %{swiftc} %s -o %T/SingleFailingTestCase
// NOTE: The following line prevents us from verifying the `SingleFailingTestCase` executable's exit code.
// RUN: %T/SingleFailingTestCase > %t || true
// RUN: %{xctest_checker} %t %s Using // RUN: %{swiftc} %s -o %T/SingleFailingTestCase
// RUN: not %T/SingleFailingTestCase | %{FileCheck} %s |
Additional Detail from JIRA
md5: 961cab0c1de40e4880f026d33ac12047
Issue Description:
xctest-checker was originally added in #20 as a replacement for FileCheck. At that time, it was easy to build swift-corelibs-xctest without first building apple/swift from source. As we continued to develop xctest-checker into a more fully-featured FileCheck replacement, @briancroom wondered whether it would make sense to switch to FileCheck completely: #94 (comment) I argued against this because it would mean completely coupling the corelibs-xctest build to the overall apple/swift build.
However, as its dependencies on other projects such as swift-corelibs-foundation have expanded, swift-corelibs-xctest has been encouraging contributors to use the Swift build script to build and test the project for a long while now:
The Swift build script has access to the LLVM bin directory, and as such it knows where to find FileCheck.
Is it time to replace xctest-checker with FileCheck? I think the answer is yes. We can migrate using the following steps:
XCTest's build_script.py test subcommand should take an optional path to a FileCheck executable to use when testing. At first, the option will do nothing.
The apple/swift build script should be modified to pass the path to FileCheck to the build script.
XCTest's lit.cfg should provide a
%{FileCheck}
substitution to the tests.Tests should migrate over from using the
%{xctest_checker}
substitution to the%{FileCheck}
substitution.Once all tests have been migrated, xctest-checker should be deleted.
The text was updated successfully, but these errors were encountered: