Jump to the navigation menu

Are missing tests a blocker to refactoring?

Is having automated tests a prerequisite for refactoring a piece of code?

Without passing tests for that code, any changes made could introduce a regression, and bugs can be accidentally introduced.

When refactoring with tests, you run them before making any changes to ensure they pass. The tests are rerun after every change to ensure that they still pass and that the change didn't introduce a regression that caused the test to fail. If a test fails, the change is reverted and re-attempted.

If I need to refactor some code without tests, the first thing that I'll do is add some initial tests before the main work.

Whilst nothing is stopping me from refactoring without the tests, the risk isn't something that I'd want to take on, and I'd much prefer to have some tests in place - just in case!

- Oliver

Was this interesting?

Sign up here and get more like this delivered straight to your inbox every day.

About me

Picture of Oliver

I'm an Acquia-certified Drupal Triple Expert with 18 years of experience, an open-source software maintainer and Drupal core contributor, public speaker, live streamer, and host of the Beyond Blocks podcast.