I was trying to brainstorm what a real test that currently exists might look like if converted to a lit-style test. Not even proposing we do this, just figured I would throw up what I came up with in case anyone wants to see something concrete. These tests come from lang/cpp/namespace. There is one .test file for each method in each existing .py file. This way everything gets run in parallel. A couple observations and musings:
- There is NO MAKEFILE. Usually this is going to be fine, as most Makefiles are trivial anyway and do nothing. If we wanted to take this idea further so that it works for our entire test suite, we would need a way to provide custom build settings. I envision happening through directives in each test file but there are some issues obviously. We'd have to figure it out.
- There are no skip / xfail directives. Again, we could design our own per-file directives for this.
- There's no manual invocation of the Python APIs. I actually think this is an advantage. It makes the tests easier to understand. Whether this is flexible enough to support everything that LLDB tests do is an open question. We could always provide a #script <label> directive and then embed some Python code below if we need to do something funky.
- The checks and directives are interspersed with the code. I think this makes it much easier to look at a test and digest what it does rather than having to click through many different files. Although sometimes a test is specifically testing something that has to do with multiple object files. I didn't try to address that here, but again, with the freedom to design whatever set of directives we need to, I think it's doable.
- Source code is reproduced in every file. This means every test will be compiling its own target. But in practice I think this will still be a speedup over our current state of affairs, where every test STILL recompiles its own target, but it does so serially. In the solution here, at least the compiler would be run in parallel for each test.
Again, this is just some very early high-level thoughts about what a test might look like. I mostly approached this from the angle of "what would allow this test to be the easiest to write and easiest to understand".