-
Notifications
You must be signed in to change notification settings - Fork 83
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
Change randomize? at any level #272
Comments
Thank you for your thorough proposal! Two more alternatives to consider:
However, I think your proposed PR is still potentially useful. Even if my alternatives work in your case, your solution might be better if there are many expensive operations, if you have a namespace you don't have time to rewrite so it can be randomized yet, or if test randomization isn't worth the implementation costs. In all of those cases, you probably don't want to disable randomization for the sake of a weird namespace. This also provides a migration path for gradually fixing test suites that cannot be randomized yet. What do you think, @plexus? Randomizing all tests and using |
Thanks for the reply @alysbrooks. A fixture does not feel like the right fit in this case because the expensive operation is the one being tested. As a result, if the expensive operation fails (e.g., throws), it would first fail in the fixture, rather than in the actual test. That feels like a mismatch. Certainly something that can be worked around, though. |
@kennyjwilli What about option 4, memoization? The downside is that if it does fail, memoization will keep trying the expensive operation. But if the expensive operation tends to fail early on or you have |
For sure -- there's definitely ways to workaround it 🙂 Still interested in the feature proposal though. |
@kennyjwilli I wrote a plugin which de-sorts (or rather natural-sorts based on line number of functions) https://github.com/oxalorg/kaocha-plugin-examples/blob/main/test/hello_test.clj This is probably a very bad & incomplete solution but I started repl hacking to explore and just ended up with this 🙈 Making this configurable in kaocha itself probably makes more sense! Also ended up with a |
Hey @kennyjwilli, nice to see you here 👋 I think there's merit to the idea, even though it's a fairly niche use case, and relying on ordering is still somewhat of an anti-pattern. But being able to configure things on the testable level, or via a testable's metadata is very kaocha-y. It's a pattern we use elsewhere as well, maximally allow steering Kaocha's behavior through data, which lends more power to plugins and hooks, and opens the door for potentially other use cases as well. Some details of how I think this would work
In practice, for
So you could for instance (case 1)
Or the inverse (case 2)
There's one special case, in that passing This issue did make me realize that we should better document how to swap out core plugins. It's trivial to copy #kaocha/v1
{:plugins ^:replace [...]} to set it up instead of the default randomize plugin. |
Problem
The majority of the time, I like running my tests with
randomize? true
. Rarely, I will have a case where running tests for a specific test suite or namespace would be beneficial. Typically, this is because an earlier test(s) do an expensive, mutative operation that I do not want to redo. This might feel close to a:once
fixture. However, there can be an important difference -- the expensive operation is the thing we actually want to test. As such, a:once
fixture does not feel like a good fit.Proposal
I propose adding support for setting
:kaocha.plugin.randomize/randomize?
on a test suite map and namespace.Suggested implementation path
See relevant code. If the
test-plan
has:kaocha.plugin.randomize/randomize?
set as a top-level key or in the[:kaocha.testable/meta :kaocha.plugin.randomize/randomize?]
path, do not sort the:kaocha.test-plan/tests
, but still continue the recursion, allowing the toggle to be on/off at any level.If the above sounds good, I can provide a PR.
Alternatives
:kaocha.plugin.randomize/randomize? false
directly in tests.edn for all tests that use that config. This is not ideal because most often you wantrandomize? true
.--no-randomize
to the CLI when running the tests. This is not ideal because it requires the caller to know they must pass that flag for tests to be idempotent.The text was updated successfully, but these errors were encountered: