| ▲ | CoastalCoder 7 hours ago |
| > Always include some randomness in test values. If this isn't a joke, I'd be very interested in the reasoning behind that statement, and whether or not there are some qualifications on when it applies. |
|
| ▲ | dathinab 6 hours ago | parent | next [-] |
| humans are very good at overlooking edge cases, off by one errors etc. so if you generate test data randomly you have a higher chance of "accidentally" running into overlooked edge cases you could say there is a "adding more random -> cost" ladder like - no randomness, no cost, nothing gained - a bit of randomness, very small cost, very rarely beneficial (<- doable in unit tests) - (limited) prop testing, high cost (test runs multiple times with many random values), decent chance to find incorrect edge cases (<- can be barely doable in unit tests, if limited enough, often feature gates as too expensive) - (full) prop testing/fuzzing, very very high cost, very high chance incorrect edge cases are found IFF the domain isn't too large (<- a full test run might need days to complete) |
| |
| ▲ | ssdspoimdsjvv 6 hours ago | parent | next [-] | | I've learnt that if a test only fails sometimes, it can take a long time for somebody to actually investigate the cause,in the meantime it's written off as just another flaky test. If there really is a bug, it will probably surface sooner in production than it gets fixed. | | |
| ▲ | tomjakubowski 2 hours ago | parent | next [-] | | Flaky tests are a very strong signal of a bug, somewhere. Problem is it's not always easy to tell if the bug's in the test or in the code under test. The developer who would rather re-run the test to make it pass than investigate probably thinks it's the test which is buggy. | |
| ▲ | dathinab 5 hours ago | parent | prev [-] | | sadly yes people often take flaky test way less serious then they should I had multiple bigger production issues which had been caught by tests >1 month before they happened in production, but where written off as flaky tests (ironically this was also not related to any random test data but more load/race condition related things which failed when too many tests which created full separate tenants for isolation happened to run at the same time). And in some CI environments flaky test are too painful, so using "actual" random data isn't viable and a fixed seed has to be used on CI (that is if you can, because too much libs/tools/etc. do not allow that). At least for "merge approval" runs. That many CI systems suck badly the moment you project and team size isn't around the size of a toy project doesn't help either. |
| |
| ▲ | SkyBelow 4 hours ago | parent | prev [-] | | Can't one get randomness and determinism at the same time? Randomly generate the data, but do so when building the test, not when running the test. This way something that fails will consistently fail, but you also have better chances of finding the missed edge cases that humans would overlook. Seeded randomness might also be great, as it is far cleaner to generate and expand/update/redo, but still deterministic when it comes time to debug an issue. | | |
| ▲ | tomjakubowski 2 hours ago | parent [-] | | Most test frameworks I have seen that support non-determinism in some way print the random seed at the start of the run, and let you specify the seed when you run the tests yourself. It's a good practice for precisely the reasons you wrote. |
|
|
|
| ▲ | whynotmaybe 7 hours ago | parent | prev [-] |
| Must be some Mandela effect about some TDD documentation I read a long time ago. If you test math_add(1,2) and it returns 3, you don't know if the code does `return 3` or `return x+y`. It seems I might need to revise my view. |
| |
| ▲ | Izkata 6 hours ago | parent | next [-] | | I vaguely remember the same advice, it's pretty old. How you use the randomness is test specific, for example in math_add() it'd be something like: jitter = random(5)
assertEqual(3 + jitter, math_add(1, 2 + jitter))
If it was math_multiply(), then adding the jitter would fail - that would have to be multiplied in.Nowadays I think this would be done with fuzzing/constraint tests, where you define "this relation must hold true" in a more structured way so the framework can choose random values, test more at once, and give better failure messages. | | |
| ▲ | whynotmaybe 3 hours ago | parent [-] | | > it's pretty old. Damn, must be why only white hair is growing on my head now. >Nowadays I think this would be done with fuzzing/constraint tests, where you define "this relation must hold true" in a more structured way so the framework can choose random values, test more at once, and give better failure messages. So the concept of random is still there but expressed differently ? (= Am I partially right ?) |
| |
| ▲ | ajs1998 6 hours ago | parent | prev | next [-] | | Randomness is useful if you expect your code to do the correct thing with some probability. You test lots of different samples and if they fail more than you expect then you should review the code. You wouldn't test dynamic random samples of add(x, y) because you wouldn't expect it to always return 3, but in this case it wouldn't hurt. | |
| ▲ | brewmarche 3 hours ago | parent | prev [-] | | This sounds like the idea behind mutation testing |
|