Skip to main content

When Do I Refactor?

When do I know it's time to refactor code?


Refactoring is different for every person but for me I follow these guidelines:
- If I don't know / understand the code, I don't refactor.  Period!
- Is the code broken?  If not then I generally don't refactor
- Can the code be made much simpler?  If the amount of code can be reduced by 2x and made cleaner / simpler then I may refactor.
- Can the existing code handle the new feature / bug fix?  If not then I may refactor.
- I will not refactor the code if I think I have a better way.  Better my be for me but not other developers.  I leave working code working.

Tests:
I never assume that tests for existing code:
-  Has complete code coverage (I've never seen this yet).  I've seen 100% coverage but not all combinations of logic or possible side effects of API changes, etc.
- That the tests are even correct.  The tests only test what the developer wanted to test, not what could / should happen.  Tests are never free from bugs just like the code that is being tested.  If there are x% of bugs for every 1,000 lines of code then the tests will also contain basically the same rate of bugs.

For these reasons, I never rely on tests for catch bugs when I refactoring code.  I need to fully understand the logic and intension of the code before I refactor.  Otherwise I'll just create additional bugs and duplicate failed logic in the new code.

For me, I try to make sure that my code is as solid, understandable and as simple as possible.  If code is not understandable then it's at rick of being churned by refactoring.

Comments

Popular posts from this blog

There is no "Right" way.

It's not that your way is not the right way, it's that everyone has their own right way.  So which is the right way?  Is there a right way? Software development is full of discussions that revolve about the "right" way of doing something. The terms used in discussing software design, tools and implementation are so undefined as to make them meaningless.  Code is not designed and written in a vacuum, it's designed by real people in real companies, each with their own constraints and issues.  Code that may look like a hack could have been the result of an employee dragged out of bed at 2am by a company shirt that only cared that they they did not lose their personal client the next morning.  Everything must be looked at in context.  A project written to "Best Practices" may never be finished before development funding dries up.   Goals, vision, constraints and thoughts should be somewhat aligned for project to be successful (or at least enjoyable ...

3rd Try is a Charm

I've been trying to draw / paint these barns for a couple of years but never felt or got them right.  This time I think they turned out right. So What went wrong before and what's right now with this drawing?  This time, the light was right.  It's coming from the upper right and the shadows just looked right.  The other thing is the corn field on the left had to "be in season", otherwise it's just a plowed field.  I had taken other photos from different angles but they never felt right.  This angle has the road, power lines, corn field, etc. all leading to the right.  The shadows on the lower right helps fill in that corner (don't forget about the corners!).  The last part is trying to draw (ink paint maybe) the trees in the background.  Not so easy when they are kind of a blob is green shades. So yeah, it's composition that is king.  Many times I just don't see it until the drawing / painting is finished and when it's right it feels goo...

So THIS is My Style?

 If I play around long enough my style will appear.  I'm guessing that this is kind of it.  I'll keep working on other techniques in watercolor but for now this appears to be my style. I do like it and others appear (to my face) to also like this.  Not every one of my paintings is a success.  About 1/3 so far, but when they do I am rather pleased that anything good comes out of it at all. I do love color.  Color is happy and outdoors is full of color, be it the west or back east with the greens.  Color color color. Also doing some painting on hot press paper and see how that goes. Later......