Colleague blocks change request in peer review because of perceived mistakes in code, but suggested improvements do not work



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty margin-bottom:0;







up vote
101
down vote

favorite
4












In the company I work for, change requests go through various steps, including a development step, a peer review step and a testing step. On this particular change request, I have been assigned as a developer and a colleague developer has been assigned as a reviewer.



This colleague is the one who trained me originally. He has been with the company for over 10 years, while I joined a year ago, just after university. He's got more years of experience as a developer than I am old. Despite that, he is still my peer as we are both "mid level" (no longer junior but not senior) developers.



This particular change request involves an old, complicated function. It is badly written according to any code standard, but it works. It took me a few hours to even find what I needed to change. The client wanted a different order of evaluation for determining the initial value of a field (e.g. check client.address before debtor.address instead of the other way around).



My colleague noticed I was taking long and looked at the source code with me. He pointed out some code and said, "You have to delete that". I had my doubts about that, but I tried it anyway. Trying it made me realise where the problem was, though. In the end, I had to switch two statements around.



I documented the change, tested it and it worked as intended. I forwarded the change request to my manager, who verified it worked and forwarded it to the reviewer. I received it back a few minutes later with the comments "that won't work, you changed the wrong code" and "you didn't do what I said".



I said that I tried what he said, but it didn't work. The code he referred to was unrelated to the change request, except that they were doing something with this same field. His response was that what he said was just a hint, because I need to be able to figure out things on my own.



Now he refuses to pass the change request to the testers until I fix my mistake. I asked him for more details, and he keeps saying I need to figure it out on my own, because I need to learn. I need to start with deleting the code he mentions, according to him. Since that code has nothing to do with the change request in question, I am very reluctant. I asked our manager, and he said to present my argument to the reviewer, since the manager doesn't know about programming. I tried that, but the reviewer is adamant in his point and dismisses me with "just do what I said".



Partially due to the age of this code, there are no unit tests and they cannot be written for them without rewriting half the codebase.



How do I fix this situation?







share|improve this question

















  • 7




    Just out of curiosity is this a corporate IT department or an IT dev shop?
    – Sentinel
    2 days ago

















up vote
101
down vote

favorite
4












In the company I work for, change requests go through various steps, including a development step, a peer review step and a testing step. On this particular change request, I have been assigned as a developer and a colleague developer has been assigned as a reviewer.



This colleague is the one who trained me originally. He has been with the company for over 10 years, while I joined a year ago, just after university. He's got more years of experience as a developer than I am old. Despite that, he is still my peer as we are both "mid level" (no longer junior but not senior) developers.



This particular change request involves an old, complicated function. It is badly written according to any code standard, but it works. It took me a few hours to even find what I needed to change. The client wanted a different order of evaluation for determining the initial value of a field (e.g. check client.address before debtor.address instead of the other way around).



My colleague noticed I was taking long and looked at the source code with me. He pointed out some code and said, "You have to delete that". I had my doubts about that, but I tried it anyway. Trying it made me realise where the problem was, though. In the end, I had to switch two statements around.



I documented the change, tested it and it worked as intended. I forwarded the change request to my manager, who verified it worked and forwarded it to the reviewer. I received it back a few minutes later with the comments "that won't work, you changed the wrong code" and "you didn't do what I said".



I said that I tried what he said, but it didn't work. The code he referred to was unrelated to the change request, except that they were doing something with this same field. His response was that what he said was just a hint, because I need to be able to figure out things on my own.



Now he refuses to pass the change request to the testers until I fix my mistake. I asked him for more details, and he keeps saying I need to figure it out on my own, because I need to learn. I need to start with deleting the code he mentions, according to him. Since that code has nothing to do with the change request in question, I am very reluctant. I asked our manager, and he said to present my argument to the reviewer, since the manager doesn't know about programming. I tried that, but the reviewer is adamant in his point and dismisses me with "just do what I said".



Partially due to the age of this code, there are no unit tests and they cannot be written for them without rewriting half the codebase.



How do I fix this situation?







share|improve this question

















  • 7




    Just out of curiosity is this a corporate IT department or an IT dev shop?
    – Sentinel
    2 days ago













up vote
101
down vote

favorite
4









up vote
101
down vote

favorite
4






4





In the company I work for, change requests go through various steps, including a development step, a peer review step and a testing step. On this particular change request, I have been assigned as a developer and a colleague developer has been assigned as a reviewer.



This colleague is the one who trained me originally. He has been with the company for over 10 years, while I joined a year ago, just after university. He's got more years of experience as a developer than I am old. Despite that, he is still my peer as we are both "mid level" (no longer junior but not senior) developers.



This particular change request involves an old, complicated function. It is badly written according to any code standard, but it works. It took me a few hours to even find what I needed to change. The client wanted a different order of evaluation for determining the initial value of a field (e.g. check client.address before debtor.address instead of the other way around).



My colleague noticed I was taking long and looked at the source code with me. He pointed out some code and said, "You have to delete that". I had my doubts about that, but I tried it anyway. Trying it made me realise where the problem was, though. In the end, I had to switch two statements around.



I documented the change, tested it and it worked as intended. I forwarded the change request to my manager, who verified it worked and forwarded it to the reviewer. I received it back a few minutes later with the comments "that won't work, you changed the wrong code" and "you didn't do what I said".



I said that I tried what he said, but it didn't work. The code he referred to was unrelated to the change request, except that they were doing something with this same field. His response was that what he said was just a hint, because I need to be able to figure out things on my own.



Now he refuses to pass the change request to the testers until I fix my mistake. I asked him for more details, and he keeps saying I need to figure it out on my own, because I need to learn. I need to start with deleting the code he mentions, according to him. Since that code has nothing to do with the change request in question, I am very reluctant. I asked our manager, and he said to present my argument to the reviewer, since the manager doesn't know about programming. I tried that, but the reviewer is adamant in his point and dismisses me with "just do what I said".



Partially due to the age of this code, there are no unit tests and they cannot be written for them without rewriting half the codebase.



How do I fix this situation?







share|improve this question













In the company I work for, change requests go through various steps, including a development step, a peer review step and a testing step. On this particular change request, I have been assigned as a developer and a colleague developer has been assigned as a reviewer.



This colleague is the one who trained me originally. He has been with the company for over 10 years, while I joined a year ago, just after university. He's got more years of experience as a developer than I am old. Despite that, he is still my peer as we are both "mid level" (no longer junior but not senior) developers.



This particular change request involves an old, complicated function. It is badly written according to any code standard, but it works. It took me a few hours to even find what I needed to change. The client wanted a different order of evaluation for determining the initial value of a field (e.g. check client.address before debtor.address instead of the other way around).



My colleague noticed I was taking long and looked at the source code with me. He pointed out some code and said, "You have to delete that". I had my doubts about that, but I tried it anyway. Trying it made me realise where the problem was, though. In the end, I had to switch two statements around.



I documented the change, tested it and it worked as intended. I forwarded the change request to my manager, who verified it worked and forwarded it to the reviewer. I received it back a few minutes later with the comments "that won't work, you changed the wrong code" and "you didn't do what I said".



I said that I tried what he said, but it didn't work. The code he referred to was unrelated to the change request, except that they were doing something with this same field. His response was that what he said was just a hint, because I need to be able to figure out things on my own.



Now he refuses to pass the change request to the testers until I fix my mistake. I asked him for more details, and he keeps saying I need to figure it out on my own, because I need to learn. I need to start with deleting the code he mentions, according to him. Since that code has nothing to do with the change request in question, I am very reluctant. I asked our manager, and he said to present my argument to the reviewer, since the manager doesn't know about programming. I tried that, but the reviewer is adamant in his point and dismisses me with "just do what I said".



Partially due to the age of this code, there are no unit tests and they cannot be written for them without rewriting half the codebase.



How do I fix this situation?









share|improve this question












share|improve this question




share|improve this question








edited yesterday









Peter Mortensen

45047




45047









asked 2 days ago









Belle-Sophie

1,61341124




1,61341124







  • 7




    Just out of curiosity is this a corporate IT department or an IT dev shop?
    – Sentinel
    2 days ago













  • 7




    Just out of curiosity is this a corporate IT department or an IT dev shop?
    – Sentinel
    2 days ago








7




7




Just out of curiosity is this a corporate IT department or an IT dev shop?
– Sentinel
2 days ago





Just out of curiosity is this a corporate IT department or an IT dev shop?
– Sentinel
2 days ago











7 Answers
7






active

oldest

votes

















up vote
165
down vote



accepted










He might be correct that the code needs fixing, but he's going about it the wrong way for any code review I've ever seen. Code reviews should fail for very specific, addressable points, eg:



  1. Inconsistent indentation in ScoreHandler.cpp, lines 45-50. Violates style guidline #8.


  2. getConsistentReview() in Foo.java is not thread safe as required, synchronizing on the wrong lock.


  3. getFoo() in Foo.java is iterating over a list to filter out results. Since our source level is now 8, this should use the stream API to filter instead, which is much more concise.

It sounds like you've got someone who's (badly) trying to mentor you by getting you to "fix" code in a way that he wants, without telling you exactly why it's broken or what's wrong with it. It's not even clear if the reason he wants you to change it is stylistic, or functional.



You could just refuse to play ball and push it back to him. Whether you think that will work overall, or whether it'll cause more problems depends on the culture.



If you want a softer approach, try writing back with more detail of what you tried, why that didn't work, and state exactly what you need to proceed:




Hi x,



I've previously tried deleting y code as you suggested, but that instead causes z to happen, resulting in the function failing (these) tests in (these) cases. I'm very unclear on the requirement here - is the change that you're asking for a stylistic one or a functional one? If it's stylistic, could you point out the specific style guidelines the code is violating, and if it's functional could you provide me with a test case that fails?




None of the above is unreasonable to ask for in a code review - it's more unreasonable that it wasn't provided to start with.



If he still says "just do what I tried" after that, you can then just push back with "As above, I'm afraid that didn't work and I'll need much more detail in order to solve the problem." If anyone comes down on you for taking a long time, show them the paper trail; it should become clear pretty quickly that he's the one dragging his feet and refusing to play ball.






share|improve this answer



















  • 188




    Update: just tried this and it worked. He ended up coming over to my desk and helped me improve my code. It was not wrong after all, but could be better. His solution was not complete, but was not as wrong as I thought it was. I guess we were both wrong.
    – Belle-Sophie
    2 days ago






  • 26




    @Belle-Sophie Perhaps he saw this post and realized you are really stuck.
    – Alex L
    2 days ago






  • 4




    @Belle-Sophie Great to hear, happy to help.
    – berry120
    2 days ago






  • 14




    @Belle-Sophie: I think it's a good lesson for the future; yes code-reviews are generally conducted asynchronously via tools... however whenever you find yourself confused by a question/answer in the code-review, it might be better to switch to phone/face-to-face communication to clear up misunderstandings quickly :)
    – Matthieu M.
    2 days ago










  • Still, was there any benefit to his changes? Or was it just a waste of everyone's time?
    – gnasher729
    2 days ago

















up vote
17
down vote













In the workflow at my company, that would be easy.



Mark the change request as “won’t fix” with a comment “correct fix rejected by reviewer”, then assign the change request to him. Obviously he knows how to fix it, so that should be a five minute job for him.



And actually, if he was correct, then that would be the right thing to do. No point in wasting your time. So there is nothing he can complain about.



With ancient and obscure code, two things can happen: I leave it unchanged, or I improve it and take responsibility if it breaks. The one thing that is not going to happen is that I order someone else to make those changes. And most definitely not during a code review.






share|improve this answer



















  • 3




    Tried that. He just throws it back at me.
    – Belle-Sophie
    2 days ago






  • 10




    Thats where you take it to your manager. Your manager doesn’t know about programming, but you say your colleagues suggestions don’t work, he says they work, so in that situation it would be obvious to your boss that he should do the job.
    – gnasher729
    2 days ago






  • 6




    @Belle-Sophie So... he insists you make his change under your name? That's not very cricket. I suggest adding this detail to your question since it highlights the guy's mentality
    – rath
    2 days ago






  • 4




    @rath Can you explain your use of the word 'cricket' in this context? I'm afraid I'm utterly lost.
    – Two-Bit Alchemist
    2 days ago






  • 7




    @Two-BitAlchemist its an English term to mean "just not the right way of going about things with honour", from cricket games where players were always expected to play with fairness and gentlemanly conduct.
    – gbjbaanb
    2 days ago

















up vote
6
down vote













This might not apply to you for technical or organizational reasons, but the general answer is:



Make a unit test



A unit test is proof a bug has been fixed. Every time you fix a bug, or every time you need to demonstrate a bug, unit testing saves a lot of arguments. See if there's a QA person you can talk to and get this one sorted out.



Remember he didn't reject your change because it didn't work, he rejected it because it wasn't his change. Having a unit test back you up strengthens your position.




Specifically for your situation: Remember that if he wants you to do what he said, he should do it himself. It's your task and you get to do what you say. That's your mentality, now for the dialog.



Call the developer over and talk with him. Demonstrate that your fix works, and if you're asked why you didn't do what he said you can say something like this:




This is not exactly what you said but it works and fixes the problem. I understand this solution in my head, the other way would probably work as well but would've taken me a lot more time to figure out. So I think we can mark this one as Passed in the code review?







share|improve this answer























  • I like this answer. Unforunately it won't work for me (I updated the question), but it's a good answer for people with a similar problem that is actually testable.
    – Belle-Sophie
    2 days ago










  • @Belle-Sophie I thought your situation might be a bit different :) The guy sounds like a colleague I wouldn't like to have
    – rath
    2 days ago










  • It sounds like you have a resolution, but for the next person in this situation - while it's usually impractical to unit test a chunky legacy function entirely, it's almost always possible to factor out each individual piece of logic to a testable function, then string them together, and often the act of doing this causes idea to spark around where the error is.
    – Jamie
    2 days ago

















up vote
2
down vote













I agree with berry120. However your review notes were




"that won't work, you changed the wrong code" and "you didn't do what I said"




My suggestion:



(Spend no more than half a day or so on this. Concisely document relevant code behavior, errors / warnings, your actions taken and reasons for doing so.)



  • make sure your new code works in Version X (no errors or warnings) according to client request

  • create a fork or a version of the code prior to your changes

  • do exactly as the notes state (attempt to fix errors if any), this is now Version Y

  • if these changes won't address the client request make special note of this and attempt to include Version X into Version Y

  • inform (email) your reviewer and manager:


I believe I have finished implementing the client requested changes in Version X.

To address the review notes I took the following additional steps for Version Y.




List here your progress and findings, include your documentation of this process (keep it short,5-10 lines max.).

If it helps readability, you also can have this list at the end of the email and refer to it accordingly.



If the review notes didn't address the client request:

(the following will explain your delay and initial non compliance with the notes)




As far as I could tell (see my report above/below) the review notes alone wouldn't address the clients request and I additionally implemented Version X.



I wrote Version X first to assure the clients request was addressed before adding other code changes.




Should Version Y still have errors you couldn't fix:
(It probably will be the review notes or the addition of Version X to the review notes - adjust wording below accordingly!)




I'm happy to continue working on Version Y.

Unfortunately integrating the review notes with Version X (the working client requested changes) is proving more complex than submitting Version X alone and I'll need more time allotted.




I'm on the fence about including the following to appease your reviewer somewhat while at the same time pointing out to management that his changes are causing the errors. It might also cause management to interpret it that you still need the reviewers supervision.




insert reviewer name, if you have a moment I'd greatly appreciate your guidance regarding the motivation behind (or possibly less inquisitive:"the nature of") your code changes and the resulting errors I'm getting for Version Y.




Obviously use the actual version numbers instead of X / Y (;



EDIT:



To make my answer more readable and concise I changed it.
Please leave comments if this is better. thanks.






share|improve this answer






























    up vote
    2
    down vote













    Something similar happened to me - my first job after college, a senior developer had to make a change to support something I was working on, but the change he made did not work. What ended up working for me, and what I suggest you do is the following:



    Get another senior developer involved, schedule a meeting with both of them and explain your view point. If at all possible demonstrate the tests you ran. Then let him explain his approach. Figure out what's the best fix is and do that.



    Make sure you don't come across as adversarial, something along the lines of:




    Hi Mike. It seems we keep talking past each other about bug #123. Do
    you have 30 min on Monday to go over it? I'll have Jim joint us since
    he's been working on that lately







    share|improve this answer




























      up vote
      1
      down vote













      At my last job we had a peer review type process. We were told by management not to tell the person how to solve it but only give them hints and guidance. As such I've been on the opposite end of OP situation where I am the senior dev training a new person who "fixed" a problem but the changes don't take into account of certain unique situations.



      The way I resolved it was directly explaining the unique situations and the person was able to code around that behavior but the overall code was error prone because it was a legacy repo. My thought is you should ask the developer if there is some sort of unique situation you're not realizing that he can foresee. If there are no one off cases, and he's saying it's "broken" because you didn't follow him, then put it back on him. Write in the ticket the code works, it was tested by management, and unfortunately you do not see any situation where the code would be wrong.






      share|improve this answer




























        up vote
        0
        down vote













        It does sounds odd that he's refusing your fix, and refusing to tell you details. So its time to escalate a little. That means popping the email he's sent you to your team lead saying that you don't understand why your fix was rejected and you don't understand the functionality enough to figure out what your colleague is saying, so you request help from the TL.



        I would phrase this in terms of "old functionality that you don't understand the history or implications of", but you might want to refine that, but you're going to the TL "for help with this task" knowing that he will see the trail of code changes (ie "show me what you've tried so far") which will highlight the lack of co-operation from your colleague. That should be enough to get this task some visibility around the team and a focus on getting it fixed, without artificial and unhelpful impediments from your colleague (who is acting unprofessionally).



        At no point do you need to complain, or even mention the colleague's unhelpfulness, that will be clear.



        If you don't have a team lead, then pop it back on the "todo" queue and mention (in a progress meeting?) that you don't understand the problem sufficiently to fix it past what you've already tried so you're leaving it for someone more experienced to fix.






        share|improve this answer





















          Your Answer







          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "423"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          convertImagesToLinks: false,
          noModals: false,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          noCode: true, onDemand: false,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );








           

          draft saved


          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fworkplace.stackexchange.com%2fquestions%2f117690%2fcolleague-blocks-change-request-in-peer-review-because-of-perceived-mistakes-in%23new-answer', 'question_page');

          );

          Post as a guest

























          StackExchange.ready(function ()
          $("#show-editor-button input, #show-editor-button button").click(function ()
          var showEditor = function()
          $("#show-editor-button").hide();
          $("#post-form").removeClass("dno");
          StackExchange.editor.finallyInit();
          ;

          var useFancy = $(this).data('confirm-use-fancy');
          if(useFancy == 'True')
          var popupTitle = $(this).data('confirm-fancy-title');
          var popupBody = $(this).data('confirm-fancy-body');
          var popupAccept = $(this).data('confirm-fancy-accept-button');

          $(this).loadPopup(
          url: '/post/self-answer-popup',
          loaded: function(popup)
          var pTitle = $(popup).find('h2');
          var pBody = $(popup).find('.popup-body');
          var pSubmit = $(popup).find('.popup-submit');

          pTitle.text(popupTitle);
          pBody.html(popupBody);
          pSubmit.val(popupAccept).click(showEditor);

          )
          else
          var confirmText = $(this).data('confirm-text');
          if (confirmText ? confirm(confirmText) : true)
          showEditor();


          );
          );






          7 Answers
          7






          active

          oldest

          votes








          7 Answers
          7






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes








          up vote
          165
          down vote



          accepted










          He might be correct that the code needs fixing, but he's going about it the wrong way for any code review I've ever seen. Code reviews should fail for very specific, addressable points, eg:



          1. Inconsistent indentation in ScoreHandler.cpp, lines 45-50. Violates style guidline #8.


          2. getConsistentReview() in Foo.java is not thread safe as required, synchronizing on the wrong lock.


          3. getFoo() in Foo.java is iterating over a list to filter out results. Since our source level is now 8, this should use the stream API to filter instead, which is much more concise.

          It sounds like you've got someone who's (badly) trying to mentor you by getting you to "fix" code in a way that he wants, without telling you exactly why it's broken or what's wrong with it. It's not even clear if the reason he wants you to change it is stylistic, or functional.



          You could just refuse to play ball and push it back to him. Whether you think that will work overall, or whether it'll cause more problems depends on the culture.



          If you want a softer approach, try writing back with more detail of what you tried, why that didn't work, and state exactly what you need to proceed:




          Hi x,



          I've previously tried deleting y code as you suggested, but that instead causes z to happen, resulting in the function failing (these) tests in (these) cases. I'm very unclear on the requirement here - is the change that you're asking for a stylistic one or a functional one? If it's stylistic, could you point out the specific style guidelines the code is violating, and if it's functional could you provide me with a test case that fails?




          None of the above is unreasonable to ask for in a code review - it's more unreasonable that it wasn't provided to start with.



          If he still says "just do what I tried" after that, you can then just push back with "As above, I'm afraid that didn't work and I'll need much more detail in order to solve the problem." If anyone comes down on you for taking a long time, show them the paper trail; it should become clear pretty quickly that he's the one dragging his feet and refusing to play ball.






          share|improve this answer



















          • 188




            Update: just tried this and it worked. He ended up coming over to my desk and helped me improve my code. It was not wrong after all, but could be better. His solution was not complete, but was not as wrong as I thought it was. I guess we were both wrong.
            – Belle-Sophie
            2 days ago






          • 26




            @Belle-Sophie Perhaps he saw this post and realized you are really stuck.
            – Alex L
            2 days ago






          • 4




            @Belle-Sophie Great to hear, happy to help.
            – berry120
            2 days ago






          • 14




            @Belle-Sophie: I think it's a good lesson for the future; yes code-reviews are generally conducted asynchronously via tools... however whenever you find yourself confused by a question/answer in the code-review, it might be better to switch to phone/face-to-face communication to clear up misunderstandings quickly :)
            – Matthieu M.
            2 days ago










          • Still, was there any benefit to his changes? Or was it just a waste of everyone's time?
            – gnasher729
            2 days ago














          up vote
          165
          down vote



          accepted










          He might be correct that the code needs fixing, but he's going about it the wrong way for any code review I've ever seen. Code reviews should fail for very specific, addressable points, eg:



          1. Inconsistent indentation in ScoreHandler.cpp, lines 45-50. Violates style guidline #8.


          2. getConsistentReview() in Foo.java is not thread safe as required, synchronizing on the wrong lock.


          3. getFoo() in Foo.java is iterating over a list to filter out results. Since our source level is now 8, this should use the stream API to filter instead, which is much more concise.

          It sounds like you've got someone who's (badly) trying to mentor you by getting you to "fix" code in a way that he wants, without telling you exactly why it's broken or what's wrong with it. It's not even clear if the reason he wants you to change it is stylistic, or functional.



          You could just refuse to play ball and push it back to him. Whether you think that will work overall, or whether it'll cause more problems depends on the culture.



          If you want a softer approach, try writing back with more detail of what you tried, why that didn't work, and state exactly what you need to proceed:




          Hi x,



          I've previously tried deleting y code as you suggested, but that instead causes z to happen, resulting in the function failing (these) tests in (these) cases. I'm very unclear on the requirement here - is the change that you're asking for a stylistic one or a functional one? If it's stylistic, could you point out the specific style guidelines the code is violating, and if it's functional could you provide me with a test case that fails?




          None of the above is unreasonable to ask for in a code review - it's more unreasonable that it wasn't provided to start with.



          If he still says "just do what I tried" after that, you can then just push back with "As above, I'm afraid that didn't work and I'll need much more detail in order to solve the problem." If anyone comes down on you for taking a long time, show them the paper trail; it should become clear pretty quickly that he's the one dragging his feet and refusing to play ball.






          share|improve this answer



















          • 188




            Update: just tried this and it worked. He ended up coming over to my desk and helped me improve my code. It was not wrong after all, but could be better. His solution was not complete, but was not as wrong as I thought it was. I guess we were both wrong.
            – Belle-Sophie
            2 days ago






          • 26




            @Belle-Sophie Perhaps he saw this post and realized you are really stuck.
            – Alex L
            2 days ago






          • 4




            @Belle-Sophie Great to hear, happy to help.
            – berry120
            2 days ago






          • 14




            @Belle-Sophie: I think it's a good lesson for the future; yes code-reviews are generally conducted asynchronously via tools... however whenever you find yourself confused by a question/answer in the code-review, it might be better to switch to phone/face-to-face communication to clear up misunderstandings quickly :)
            – Matthieu M.
            2 days ago










          • Still, was there any benefit to his changes? Or was it just a waste of everyone's time?
            – gnasher729
            2 days ago












          up vote
          165
          down vote



          accepted







          up vote
          165
          down vote



          accepted






          He might be correct that the code needs fixing, but he's going about it the wrong way for any code review I've ever seen. Code reviews should fail for very specific, addressable points, eg:



          1. Inconsistent indentation in ScoreHandler.cpp, lines 45-50. Violates style guidline #8.


          2. getConsistentReview() in Foo.java is not thread safe as required, synchronizing on the wrong lock.


          3. getFoo() in Foo.java is iterating over a list to filter out results. Since our source level is now 8, this should use the stream API to filter instead, which is much more concise.

          It sounds like you've got someone who's (badly) trying to mentor you by getting you to "fix" code in a way that he wants, without telling you exactly why it's broken or what's wrong with it. It's not even clear if the reason he wants you to change it is stylistic, or functional.



          You could just refuse to play ball and push it back to him. Whether you think that will work overall, or whether it'll cause more problems depends on the culture.



          If you want a softer approach, try writing back with more detail of what you tried, why that didn't work, and state exactly what you need to proceed:




          Hi x,



          I've previously tried deleting y code as you suggested, but that instead causes z to happen, resulting in the function failing (these) tests in (these) cases. I'm very unclear on the requirement here - is the change that you're asking for a stylistic one or a functional one? If it's stylistic, could you point out the specific style guidelines the code is violating, and if it's functional could you provide me with a test case that fails?




          None of the above is unreasonable to ask for in a code review - it's more unreasonable that it wasn't provided to start with.



          If he still says "just do what I tried" after that, you can then just push back with "As above, I'm afraid that didn't work and I'll need much more detail in order to solve the problem." If anyone comes down on you for taking a long time, show them the paper trail; it should become clear pretty quickly that he's the one dragging his feet and refusing to play ball.






          share|improve this answer















          He might be correct that the code needs fixing, but he's going about it the wrong way for any code review I've ever seen. Code reviews should fail for very specific, addressable points, eg:



          1. Inconsistent indentation in ScoreHandler.cpp, lines 45-50. Violates style guidline #8.


          2. getConsistentReview() in Foo.java is not thread safe as required, synchronizing on the wrong lock.


          3. getFoo() in Foo.java is iterating over a list to filter out results. Since our source level is now 8, this should use the stream API to filter instead, which is much more concise.

          It sounds like you've got someone who's (badly) trying to mentor you by getting you to "fix" code in a way that he wants, without telling you exactly why it's broken or what's wrong with it. It's not even clear if the reason he wants you to change it is stylistic, or functional.



          You could just refuse to play ball and push it back to him. Whether you think that will work overall, or whether it'll cause more problems depends on the culture.



          If you want a softer approach, try writing back with more detail of what you tried, why that didn't work, and state exactly what you need to proceed:




          Hi x,



          I've previously tried deleting y code as you suggested, but that instead causes z to happen, resulting in the function failing (these) tests in (these) cases. I'm very unclear on the requirement here - is the change that you're asking for a stylistic one or a functional one? If it's stylistic, could you point out the specific style guidelines the code is violating, and if it's functional could you provide me with a test case that fails?




          None of the above is unreasonable to ask for in a code review - it's more unreasonable that it wasn't provided to start with.



          If he still says "just do what I tried" after that, you can then just push back with "As above, I'm afraid that didn't work and I'll need much more detail in order to solve the problem." If anyone comes down on you for taking a long time, show them the paper trail; it should become clear pretty quickly that he's the one dragging his feet and refusing to play ball.







          share|improve this answer















          share|improve this answer



          share|improve this answer








          edited 2 days ago


























          answered 2 days ago









          berry120

          6,7683729




          6,7683729







          • 188




            Update: just tried this and it worked. He ended up coming over to my desk and helped me improve my code. It was not wrong after all, but could be better. His solution was not complete, but was not as wrong as I thought it was. I guess we were both wrong.
            – Belle-Sophie
            2 days ago






          • 26




            @Belle-Sophie Perhaps he saw this post and realized you are really stuck.
            – Alex L
            2 days ago






          • 4




            @Belle-Sophie Great to hear, happy to help.
            – berry120
            2 days ago






          • 14




            @Belle-Sophie: I think it's a good lesson for the future; yes code-reviews are generally conducted asynchronously via tools... however whenever you find yourself confused by a question/answer in the code-review, it might be better to switch to phone/face-to-face communication to clear up misunderstandings quickly :)
            – Matthieu M.
            2 days ago










          • Still, was there any benefit to his changes? Or was it just a waste of everyone's time?
            – gnasher729
            2 days ago












          • 188




            Update: just tried this and it worked. He ended up coming over to my desk and helped me improve my code. It was not wrong after all, but could be better. His solution was not complete, but was not as wrong as I thought it was. I guess we were both wrong.
            – Belle-Sophie
            2 days ago






          • 26




            @Belle-Sophie Perhaps he saw this post and realized you are really stuck.
            – Alex L
            2 days ago






          • 4




            @Belle-Sophie Great to hear, happy to help.
            – berry120
            2 days ago






          • 14




            @Belle-Sophie: I think it's a good lesson for the future; yes code-reviews are generally conducted asynchronously via tools... however whenever you find yourself confused by a question/answer in the code-review, it might be better to switch to phone/face-to-face communication to clear up misunderstandings quickly :)
            – Matthieu M.
            2 days ago










          • Still, was there any benefit to his changes? Or was it just a waste of everyone's time?
            – gnasher729
            2 days ago







          188




          188




          Update: just tried this and it worked. He ended up coming over to my desk and helped me improve my code. It was not wrong after all, but could be better. His solution was not complete, but was not as wrong as I thought it was. I guess we were both wrong.
          – Belle-Sophie
          2 days ago




          Update: just tried this and it worked. He ended up coming over to my desk and helped me improve my code. It was not wrong after all, but could be better. His solution was not complete, but was not as wrong as I thought it was. I guess we were both wrong.
          – Belle-Sophie
          2 days ago




          26




          26




          @Belle-Sophie Perhaps he saw this post and realized you are really stuck.
          – Alex L
          2 days ago




          @Belle-Sophie Perhaps he saw this post and realized you are really stuck.
          – Alex L
          2 days ago




          4




          4




          @Belle-Sophie Great to hear, happy to help.
          – berry120
          2 days ago




          @Belle-Sophie Great to hear, happy to help.
          – berry120
          2 days ago




          14




          14




          @Belle-Sophie: I think it's a good lesson for the future; yes code-reviews are generally conducted asynchronously via tools... however whenever you find yourself confused by a question/answer in the code-review, it might be better to switch to phone/face-to-face communication to clear up misunderstandings quickly :)
          – Matthieu M.
          2 days ago




          @Belle-Sophie: I think it's a good lesson for the future; yes code-reviews are generally conducted asynchronously via tools... however whenever you find yourself confused by a question/answer in the code-review, it might be better to switch to phone/face-to-face communication to clear up misunderstandings quickly :)
          – Matthieu M.
          2 days ago












          Still, was there any benefit to his changes? Or was it just a waste of everyone's time?
          – gnasher729
          2 days ago




          Still, was there any benefit to his changes? Or was it just a waste of everyone's time?
          – gnasher729
          2 days ago












          up vote
          17
          down vote













          In the workflow at my company, that would be easy.



          Mark the change request as “won’t fix” with a comment “correct fix rejected by reviewer”, then assign the change request to him. Obviously he knows how to fix it, so that should be a five minute job for him.



          And actually, if he was correct, then that would be the right thing to do. No point in wasting your time. So there is nothing he can complain about.



          With ancient and obscure code, two things can happen: I leave it unchanged, or I improve it and take responsibility if it breaks. The one thing that is not going to happen is that I order someone else to make those changes. And most definitely not during a code review.






          share|improve this answer



















          • 3




            Tried that. He just throws it back at me.
            – Belle-Sophie
            2 days ago






          • 10




            Thats where you take it to your manager. Your manager doesn’t know about programming, but you say your colleagues suggestions don’t work, he says they work, so in that situation it would be obvious to your boss that he should do the job.
            – gnasher729
            2 days ago






          • 6




            @Belle-Sophie So... he insists you make his change under your name? That's not very cricket. I suggest adding this detail to your question since it highlights the guy's mentality
            – rath
            2 days ago






          • 4




            @rath Can you explain your use of the word 'cricket' in this context? I'm afraid I'm utterly lost.
            – Two-Bit Alchemist
            2 days ago






          • 7




            @Two-BitAlchemist its an English term to mean "just not the right way of going about things with honour", from cricket games where players were always expected to play with fairness and gentlemanly conduct.
            – gbjbaanb
            2 days ago














          up vote
          17
          down vote













          In the workflow at my company, that would be easy.



          Mark the change request as “won’t fix” with a comment “correct fix rejected by reviewer”, then assign the change request to him. Obviously he knows how to fix it, so that should be a five minute job for him.



          And actually, if he was correct, then that would be the right thing to do. No point in wasting your time. So there is nothing he can complain about.



          With ancient and obscure code, two things can happen: I leave it unchanged, or I improve it and take responsibility if it breaks. The one thing that is not going to happen is that I order someone else to make those changes. And most definitely not during a code review.






          share|improve this answer



















          • 3




            Tried that. He just throws it back at me.
            – Belle-Sophie
            2 days ago






          • 10




            Thats where you take it to your manager. Your manager doesn’t know about programming, but you say your colleagues suggestions don’t work, he says they work, so in that situation it would be obvious to your boss that he should do the job.
            – gnasher729
            2 days ago






          • 6




            @Belle-Sophie So... he insists you make his change under your name? That's not very cricket. I suggest adding this detail to your question since it highlights the guy's mentality
            – rath
            2 days ago






          • 4




            @rath Can you explain your use of the word 'cricket' in this context? I'm afraid I'm utterly lost.
            – Two-Bit Alchemist
            2 days ago






          • 7




            @Two-BitAlchemist its an English term to mean "just not the right way of going about things with honour", from cricket games where players were always expected to play with fairness and gentlemanly conduct.
            – gbjbaanb
            2 days ago












          up vote
          17
          down vote










          up vote
          17
          down vote









          In the workflow at my company, that would be easy.



          Mark the change request as “won’t fix” with a comment “correct fix rejected by reviewer”, then assign the change request to him. Obviously he knows how to fix it, so that should be a five minute job for him.



          And actually, if he was correct, then that would be the right thing to do. No point in wasting your time. So there is nothing he can complain about.



          With ancient and obscure code, two things can happen: I leave it unchanged, or I improve it and take responsibility if it breaks. The one thing that is not going to happen is that I order someone else to make those changes. And most definitely not during a code review.






          share|improve this answer















          In the workflow at my company, that would be easy.



          Mark the change request as “won’t fix” with a comment “correct fix rejected by reviewer”, then assign the change request to him. Obviously he knows how to fix it, so that should be a five minute job for him.



          And actually, if he was correct, then that would be the right thing to do. No point in wasting your time. So there is nothing he can complain about.



          With ancient and obscure code, two things can happen: I leave it unchanged, or I improve it and take responsibility if it breaks. The one thing that is not going to happen is that I order someone else to make those changes. And most definitely not during a code review.







          share|improve this answer















          share|improve this answer



          share|improve this answer








          edited 2 days ago


























          answered 2 days ago









          gnasher729

          70.3k31131219




          70.3k31131219







          • 3




            Tried that. He just throws it back at me.
            – Belle-Sophie
            2 days ago






          • 10




            Thats where you take it to your manager. Your manager doesn’t know about programming, but you say your colleagues suggestions don’t work, he says they work, so in that situation it would be obvious to your boss that he should do the job.
            – gnasher729
            2 days ago






          • 6




            @Belle-Sophie So... he insists you make his change under your name? That's not very cricket. I suggest adding this detail to your question since it highlights the guy's mentality
            – rath
            2 days ago






          • 4




            @rath Can you explain your use of the word 'cricket' in this context? I'm afraid I'm utterly lost.
            – Two-Bit Alchemist
            2 days ago






          • 7




            @Two-BitAlchemist its an English term to mean "just not the right way of going about things with honour", from cricket games where players were always expected to play with fairness and gentlemanly conduct.
            – gbjbaanb
            2 days ago












          • 3




            Tried that. He just throws it back at me.
            – Belle-Sophie
            2 days ago






          • 10




            Thats where you take it to your manager. Your manager doesn’t know about programming, but you say your colleagues suggestions don’t work, he says they work, so in that situation it would be obvious to your boss that he should do the job.
            – gnasher729
            2 days ago






          • 6




            @Belle-Sophie So... he insists you make his change under your name? That's not very cricket. I suggest adding this detail to your question since it highlights the guy's mentality
            – rath
            2 days ago






          • 4




            @rath Can you explain your use of the word 'cricket' in this context? I'm afraid I'm utterly lost.
            – Two-Bit Alchemist
            2 days ago






          • 7




            @Two-BitAlchemist its an English term to mean "just not the right way of going about things with honour", from cricket games where players were always expected to play with fairness and gentlemanly conduct.
            – gbjbaanb
            2 days ago







          3




          3




          Tried that. He just throws it back at me.
          – Belle-Sophie
          2 days ago




          Tried that. He just throws it back at me.
          – Belle-Sophie
          2 days ago




          10




          10




          Thats where you take it to your manager. Your manager doesn’t know about programming, but you say your colleagues suggestions don’t work, he says they work, so in that situation it would be obvious to your boss that he should do the job.
          – gnasher729
          2 days ago




          Thats where you take it to your manager. Your manager doesn’t know about programming, but you say your colleagues suggestions don’t work, he says they work, so in that situation it would be obvious to your boss that he should do the job.
          – gnasher729
          2 days ago




          6




          6




          @Belle-Sophie So... he insists you make his change under your name? That's not very cricket. I suggest adding this detail to your question since it highlights the guy's mentality
          – rath
          2 days ago




          @Belle-Sophie So... he insists you make his change under your name? That's not very cricket. I suggest adding this detail to your question since it highlights the guy's mentality
          – rath
          2 days ago




          4




          4




          @rath Can you explain your use of the word 'cricket' in this context? I'm afraid I'm utterly lost.
          – Two-Bit Alchemist
          2 days ago




          @rath Can you explain your use of the word 'cricket' in this context? I'm afraid I'm utterly lost.
          – Two-Bit Alchemist
          2 days ago




          7




          7




          @Two-BitAlchemist its an English term to mean "just not the right way of going about things with honour", from cricket games where players were always expected to play with fairness and gentlemanly conduct.
          – gbjbaanb
          2 days ago




          @Two-BitAlchemist its an English term to mean "just not the right way of going about things with honour", from cricket games where players were always expected to play with fairness and gentlemanly conduct.
          – gbjbaanb
          2 days ago










          up vote
          6
          down vote













          This might not apply to you for technical or organizational reasons, but the general answer is:



          Make a unit test



          A unit test is proof a bug has been fixed. Every time you fix a bug, or every time you need to demonstrate a bug, unit testing saves a lot of arguments. See if there's a QA person you can talk to and get this one sorted out.



          Remember he didn't reject your change because it didn't work, he rejected it because it wasn't his change. Having a unit test back you up strengthens your position.




          Specifically for your situation: Remember that if he wants you to do what he said, he should do it himself. It's your task and you get to do what you say. That's your mentality, now for the dialog.



          Call the developer over and talk with him. Demonstrate that your fix works, and if you're asked why you didn't do what he said you can say something like this:




          This is not exactly what you said but it works and fixes the problem. I understand this solution in my head, the other way would probably work as well but would've taken me a lot more time to figure out. So I think we can mark this one as Passed in the code review?







          share|improve this answer























          • I like this answer. Unforunately it won't work for me (I updated the question), but it's a good answer for people with a similar problem that is actually testable.
            – Belle-Sophie
            2 days ago










          • @Belle-Sophie I thought your situation might be a bit different :) The guy sounds like a colleague I wouldn't like to have
            – rath
            2 days ago










          • It sounds like you have a resolution, but for the next person in this situation - while it's usually impractical to unit test a chunky legacy function entirely, it's almost always possible to factor out each individual piece of logic to a testable function, then string them together, and often the act of doing this causes idea to spark around where the error is.
            – Jamie
            2 days ago














          up vote
          6
          down vote













          This might not apply to you for technical or organizational reasons, but the general answer is:



          Make a unit test



          A unit test is proof a bug has been fixed. Every time you fix a bug, or every time you need to demonstrate a bug, unit testing saves a lot of arguments. See if there's a QA person you can talk to and get this one sorted out.



          Remember he didn't reject your change because it didn't work, he rejected it because it wasn't his change. Having a unit test back you up strengthens your position.




          Specifically for your situation: Remember that if he wants you to do what he said, he should do it himself. It's your task and you get to do what you say. That's your mentality, now for the dialog.



          Call the developer over and talk with him. Demonstrate that your fix works, and if you're asked why you didn't do what he said you can say something like this:




          This is not exactly what you said but it works and fixes the problem. I understand this solution in my head, the other way would probably work as well but would've taken me a lot more time to figure out. So I think we can mark this one as Passed in the code review?







          share|improve this answer























          • I like this answer. Unforunately it won't work for me (I updated the question), but it's a good answer for people with a similar problem that is actually testable.
            – Belle-Sophie
            2 days ago










          • @Belle-Sophie I thought your situation might be a bit different :) The guy sounds like a colleague I wouldn't like to have
            – rath
            2 days ago










          • It sounds like you have a resolution, but for the next person in this situation - while it's usually impractical to unit test a chunky legacy function entirely, it's almost always possible to factor out each individual piece of logic to a testable function, then string them together, and often the act of doing this causes idea to spark around where the error is.
            – Jamie
            2 days ago












          up vote
          6
          down vote










          up vote
          6
          down vote









          This might not apply to you for technical or organizational reasons, but the general answer is:



          Make a unit test



          A unit test is proof a bug has been fixed. Every time you fix a bug, or every time you need to demonstrate a bug, unit testing saves a lot of arguments. See if there's a QA person you can talk to and get this one sorted out.



          Remember he didn't reject your change because it didn't work, he rejected it because it wasn't his change. Having a unit test back you up strengthens your position.




          Specifically for your situation: Remember that if he wants you to do what he said, he should do it himself. It's your task and you get to do what you say. That's your mentality, now for the dialog.



          Call the developer over and talk with him. Demonstrate that your fix works, and if you're asked why you didn't do what he said you can say something like this:




          This is not exactly what you said but it works and fixes the problem. I understand this solution in my head, the other way would probably work as well but would've taken me a lot more time to figure out. So I think we can mark this one as Passed in the code review?







          share|improve this answer















          This might not apply to you for technical or organizational reasons, but the general answer is:



          Make a unit test



          A unit test is proof a bug has been fixed. Every time you fix a bug, or every time you need to demonstrate a bug, unit testing saves a lot of arguments. See if there's a QA person you can talk to and get this one sorted out.



          Remember he didn't reject your change because it didn't work, he rejected it because it wasn't his change. Having a unit test back you up strengthens your position.




          Specifically for your situation: Remember that if he wants you to do what he said, he should do it himself. It's your task and you get to do what you say. That's your mentality, now for the dialog.



          Call the developer over and talk with him. Demonstrate that your fix works, and if you're asked why you didn't do what he said you can say something like this:




          This is not exactly what you said but it works and fixes the problem. I understand this solution in my head, the other way would probably work as well but would've taken me a lot more time to figure out. So I think we can mark this one as Passed in the code review?








          share|improve this answer















          share|improve this answer



          share|improve this answer








          edited 2 days ago


























          answered 2 days ago









          rath

          12.1k74368




          12.1k74368











          • I like this answer. Unforunately it won't work for me (I updated the question), but it's a good answer for people with a similar problem that is actually testable.
            – Belle-Sophie
            2 days ago










          • @Belle-Sophie I thought your situation might be a bit different :) The guy sounds like a colleague I wouldn't like to have
            – rath
            2 days ago










          • It sounds like you have a resolution, but for the next person in this situation - while it's usually impractical to unit test a chunky legacy function entirely, it's almost always possible to factor out each individual piece of logic to a testable function, then string them together, and often the act of doing this causes idea to spark around where the error is.
            – Jamie
            2 days ago
















          • I like this answer. Unforunately it won't work for me (I updated the question), but it's a good answer for people with a similar problem that is actually testable.
            – Belle-Sophie
            2 days ago










          • @Belle-Sophie I thought your situation might be a bit different :) The guy sounds like a colleague I wouldn't like to have
            – rath
            2 days ago










          • It sounds like you have a resolution, but for the next person in this situation - while it's usually impractical to unit test a chunky legacy function entirely, it's almost always possible to factor out each individual piece of logic to a testable function, then string them together, and often the act of doing this causes idea to spark around where the error is.
            – Jamie
            2 days ago















          I like this answer. Unforunately it won't work for me (I updated the question), but it's a good answer for people with a similar problem that is actually testable.
          – Belle-Sophie
          2 days ago




          I like this answer. Unforunately it won't work for me (I updated the question), but it's a good answer for people with a similar problem that is actually testable.
          – Belle-Sophie
          2 days ago












          @Belle-Sophie I thought your situation might be a bit different :) The guy sounds like a colleague I wouldn't like to have
          – rath
          2 days ago




          @Belle-Sophie I thought your situation might be a bit different :) The guy sounds like a colleague I wouldn't like to have
          – rath
          2 days ago












          It sounds like you have a resolution, but for the next person in this situation - while it's usually impractical to unit test a chunky legacy function entirely, it's almost always possible to factor out each individual piece of logic to a testable function, then string them together, and often the act of doing this causes idea to spark around where the error is.
          – Jamie
          2 days ago




          It sounds like you have a resolution, but for the next person in this situation - while it's usually impractical to unit test a chunky legacy function entirely, it's almost always possible to factor out each individual piece of logic to a testable function, then string them together, and often the act of doing this causes idea to spark around where the error is.
          – Jamie
          2 days ago










          up vote
          2
          down vote













          I agree with berry120. However your review notes were




          "that won't work, you changed the wrong code" and "you didn't do what I said"




          My suggestion:



          (Spend no more than half a day or so on this. Concisely document relevant code behavior, errors / warnings, your actions taken and reasons for doing so.)



          • make sure your new code works in Version X (no errors or warnings) according to client request

          • create a fork or a version of the code prior to your changes

          • do exactly as the notes state (attempt to fix errors if any), this is now Version Y

          • if these changes won't address the client request make special note of this and attempt to include Version X into Version Y

          • inform (email) your reviewer and manager:


          I believe I have finished implementing the client requested changes in Version X.

          To address the review notes I took the following additional steps for Version Y.




          List here your progress and findings, include your documentation of this process (keep it short,5-10 lines max.).

          If it helps readability, you also can have this list at the end of the email and refer to it accordingly.



          If the review notes didn't address the client request:

          (the following will explain your delay and initial non compliance with the notes)




          As far as I could tell (see my report above/below) the review notes alone wouldn't address the clients request and I additionally implemented Version X.



          I wrote Version X first to assure the clients request was addressed before adding other code changes.




          Should Version Y still have errors you couldn't fix:
          (It probably will be the review notes or the addition of Version X to the review notes - adjust wording below accordingly!)




          I'm happy to continue working on Version Y.

          Unfortunately integrating the review notes with Version X (the working client requested changes) is proving more complex than submitting Version X alone and I'll need more time allotted.




          I'm on the fence about including the following to appease your reviewer somewhat while at the same time pointing out to management that his changes are causing the errors. It might also cause management to interpret it that you still need the reviewers supervision.




          insert reviewer name, if you have a moment I'd greatly appreciate your guidance regarding the motivation behind (or possibly less inquisitive:"the nature of") your code changes and the resulting errors I'm getting for Version Y.




          Obviously use the actual version numbers instead of X / Y (;



          EDIT:



          To make my answer more readable and concise I changed it.
          Please leave comments if this is better. thanks.






          share|improve this answer



























            up vote
            2
            down vote













            I agree with berry120. However your review notes were




            "that won't work, you changed the wrong code" and "you didn't do what I said"




            My suggestion:



            (Spend no more than half a day or so on this. Concisely document relevant code behavior, errors / warnings, your actions taken and reasons for doing so.)



            • make sure your new code works in Version X (no errors or warnings) according to client request

            • create a fork or a version of the code prior to your changes

            • do exactly as the notes state (attempt to fix errors if any), this is now Version Y

            • if these changes won't address the client request make special note of this and attempt to include Version X into Version Y

            • inform (email) your reviewer and manager:


            I believe I have finished implementing the client requested changes in Version X.

            To address the review notes I took the following additional steps for Version Y.




            List here your progress and findings, include your documentation of this process (keep it short,5-10 lines max.).

            If it helps readability, you also can have this list at the end of the email and refer to it accordingly.



            If the review notes didn't address the client request:

            (the following will explain your delay and initial non compliance with the notes)




            As far as I could tell (see my report above/below) the review notes alone wouldn't address the clients request and I additionally implemented Version X.



            I wrote Version X first to assure the clients request was addressed before adding other code changes.




            Should Version Y still have errors you couldn't fix:
            (It probably will be the review notes or the addition of Version X to the review notes - adjust wording below accordingly!)




            I'm happy to continue working on Version Y.

            Unfortunately integrating the review notes with Version X (the working client requested changes) is proving more complex than submitting Version X alone and I'll need more time allotted.




            I'm on the fence about including the following to appease your reviewer somewhat while at the same time pointing out to management that his changes are causing the errors. It might also cause management to interpret it that you still need the reviewers supervision.




            insert reviewer name, if you have a moment I'd greatly appreciate your guidance regarding the motivation behind (or possibly less inquisitive:"the nature of") your code changes and the resulting errors I'm getting for Version Y.




            Obviously use the actual version numbers instead of X / Y (;



            EDIT:



            To make my answer more readable and concise I changed it.
            Please leave comments if this is better. thanks.






            share|improve this answer

























              up vote
              2
              down vote










              up vote
              2
              down vote









              I agree with berry120. However your review notes were




              "that won't work, you changed the wrong code" and "you didn't do what I said"




              My suggestion:



              (Spend no more than half a day or so on this. Concisely document relevant code behavior, errors / warnings, your actions taken and reasons for doing so.)



              • make sure your new code works in Version X (no errors or warnings) according to client request

              • create a fork or a version of the code prior to your changes

              • do exactly as the notes state (attempt to fix errors if any), this is now Version Y

              • if these changes won't address the client request make special note of this and attempt to include Version X into Version Y

              • inform (email) your reviewer and manager:


              I believe I have finished implementing the client requested changes in Version X.

              To address the review notes I took the following additional steps for Version Y.




              List here your progress and findings, include your documentation of this process (keep it short,5-10 lines max.).

              If it helps readability, you also can have this list at the end of the email and refer to it accordingly.



              If the review notes didn't address the client request:

              (the following will explain your delay and initial non compliance with the notes)




              As far as I could tell (see my report above/below) the review notes alone wouldn't address the clients request and I additionally implemented Version X.



              I wrote Version X first to assure the clients request was addressed before adding other code changes.




              Should Version Y still have errors you couldn't fix:
              (It probably will be the review notes or the addition of Version X to the review notes - adjust wording below accordingly!)




              I'm happy to continue working on Version Y.

              Unfortunately integrating the review notes with Version X (the working client requested changes) is proving more complex than submitting Version X alone and I'll need more time allotted.




              I'm on the fence about including the following to appease your reviewer somewhat while at the same time pointing out to management that his changes are causing the errors. It might also cause management to interpret it that you still need the reviewers supervision.




              insert reviewer name, if you have a moment I'd greatly appreciate your guidance regarding the motivation behind (or possibly less inquisitive:"the nature of") your code changes and the resulting errors I'm getting for Version Y.




              Obviously use the actual version numbers instead of X / Y (;



              EDIT:



              To make my answer more readable and concise I changed it.
              Please leave comments if this is better. thanks.






              share|improve this answer















              I agree with berry120. However your review notes were




              "that won't work, you changed the wrong code" and "you didn't do what I said"




              My suggestion:



              (Spend no more than half a day or so on this. Concisely document relevant code behavior, errors / warnings, your actions taken and reasons for doing so.)



              • make sure your new code works in Version X (no errors or warnings) according to client request

              • create a fork or a version of the code prior to your changes

              • do exactly as the notes state (attempt to fix errors if any), this is now Version Y

              • if these changes won't address the client request make special note of this and attempt to include Version X into Version Y

              • inform (email) your reviewer and manager:


              I believe I have finished implementing the client requested changes in Version X.

              To address the review notes I took the following additional steps for Version Y.




              List here your progress and findings, include your documentation of this process (keep it short,5-10 lines max.).

              If it helps readability, you also can have this list at the end of the email and refer to it accordingly.



              If the review notes didn't address the client request:

              (the following will explain your delay and initial non compliance with the notes)




              As far as I could tell (see my report above/below) the review notes alone wouldn't address the clients request and I additionally implemented Version X.



              I wrote Version X first to assure the clients request was addressed before adding other code changes.




              Should Version Y still have errors you couldn't fix:
              (It probably will be the review notes or the addition of Version X to the review notes - adjust wording below accordingly!)




              I'm happy to continue working on Version Y.

              Unfortunately integrating the review notes with Version X (the working client requested changes) is proving more complex than submitting Version X alone and I'll need more time allotted.




              I'm on the fence about including the following to appease your reviewer somewhat while at the same time pointing out to management that his changes are causing the errors. It might also cause management to interpret it that you still need the reviewers supervision.




              insert reviewer name, if you have a moment I'd greatly appreciate your guidance regarding the motivation behind (or possibly less inquisitive:"the nature of") your code changes and the resulting errors I'm getting for Version Y.




              Obviously use the actual version numbers instead of X / Y (;



              EDIT:



              To make my answer more readable and concise I changed it.
              Please leave comments if this is better. thanks.







              share|improve this answer















              share|improve this answer



              share|improve this answer








              edited yesterday


























              answered 2 days ago









              DigitalBlade969

              8908




              8908




















                  up vote
                  2
                  down vote













                  Something similar happened to me - my first job after college, a senior developer had to make a change to support something I was working on, but the change he made did not work. What ended up working for me, and what I suggest you do is the following:



                  Get another senior developer involved, schedule a meeting with both of them and explain your view point. If at all possible demonstrate the tests you ran. Then let him explain his approach. Figure out what's the best fix is and do that.



                  Make sure you don't come across as adversarial, something along the lines of:




                  Hi Mike. It seems we keep talking past each other about bug #123. Do
                  you have 30 min on Monday to go over it? I'll have Jim joint us since
                  he's been working on that lately







                  share|improve this answer

























                    up vote
                    2
                    down vote













                    Something similar happened to me - my first job after college, a senior developer had to make a change to support something I was working on, but the change he made did not work. What ended up working for me, and what I suggest you do is the following:



                    Get another senior developer involved, schedule a meeting with both of them and explain your view point. If at all possible demonstrate the tests you ran. Then let him explain his approach. Figure out what's the best fix is and do that.



                    Make sure you don't come across as adversarial, something along the lines of:




                    Hi Mike. It seems we keep talking past each other about bug #123. Do
                    you have 30 min on Monday to go over it? I'll have Jim joint us since
                    he's been working on that lately







                    share|improve this answer























                      up vote
                      2
                      down vote










                      up vote
                      2
                      down vote









                      Something similar happened to me - my first job after college, a senior developer had to make a change to support something I was working on, but the change he made did not work. What ended up working for me, and what I suggest you do is the following:



                      Get another senior developer involved, schedule a meeting with both of them and explain your view point. If at all possible demonstrate the tests you ran. Then let him explain his approach. Figure out what's the best fix is and do that.



                      Make sure you don't come across as adversarial, something along the lines of:




                      Hi Mike. It seems we keep talking past each other about bug #123. Do
                      you have 30 min on Monday to go over it? I'll have Jim joint us since
                      he's been working on that lately







                      share|improve this answer













                      Something similar happened to me - my first job after college, a senior developer had to make a change to support something I was working on, but the change he made did not work. What ended up working for me, and what I suggest you do is the following:



                      Get another senior developer involved, schedule a meeting with both of them and explain your view point. If at all possible demonstrate the tests you ran. Then let him explain his approach. Figure out what's the best fix is and do that.



                      Make sure you don't come across as adversarial, something along the lines of:




                      Hi Mike. It seems we keep talking past each other about bug #123. Do
                      you have 30 min on Monday to go over it? I'll have Jim joint us since
                      he's been working on that lately








                      share|improve this answer













                      share|improve this answer



                      share|improve this answer











                      answered yesterday









                      ventsyv

                      1,243313




                      1,243313




















                          up vote
                          1
                          down vote













                          At my last job we had a peer review type process. We were told by management not to tell the person how to solve it but only give them hints and guidance. As such I've been on the opposite end of OP situation where I am the senior dev training a new person who "fixed" a problem but the changes don't take into account of certain unique situations.



                          The way I resolved it was directly explaining the unique situations and the person was able to code around that behavior but the overall code was error prone because it was a legacy repo. My thought is you should ask the developer if there is some sort of unique situation you're not realizing that he can foresee. If there are no one off cases, and he's saying it's "broken" because you didn't follow him, then put it back on him. Write in the ticket the code works, it was tested by management, and unfortunately you do not see any situation where the code would be wrong.






                          share|improve this answer

























                            up vote
                            1
                            down vote













                            At my last job we had a peer review type process. We were told by management not to tell the person how to solve it but only give them hints and guidance. As such I've been on the opposite end of OP situation where I am the senior dev training a new person who "fixed" a problem but the changes don't take into account of certain unique situations.



                            The way I resolved it was directly explaining the unique situations and the person was able to code around that behavior but the overall code was error prone because it was a legacy repo. My thought is you should ask the developer if there is some sort of unique situation you're not realizing that he can foresee. If there are no one off cases, and he's saying it's "broken" because you didn't follow him, then put it back on him. Write in the ticket the code works, it was tested by management, and unfortunately you do not see any situation where the code would be wrong.






                            share|improve this answer























                              up vote
                              1
                              down vote










                              up vote
                              1
                              down vote









                              At my last job we had a peer review type process. We were told by management not to tell the person how to solve it but only give them hints and guidance. As such I've been on the opposite end of OP situation where I am the senior dev training a new person who "fixed" a problem but the changes don't take into account of certain unique situations.



                              The way I resolved it was directly explaining the unique situations and the person was able to code around that behavior but the overall code was error prone because it was a legacy repo. My thought is you should ask the developer if there is some sort of unique situation you're not realizing that he can foresee. If there are no one off cases, and he's saying it's "broken" because you didn't follow him, then put it back on him. Write in the ticket the code works, it was tested by management, and unfortunately you do not see any situation where the code would be wrong.






                              share|improve this answer













                              At my last job we had a peer review type process. We were told by management not to tell the person how to solve it but only give them hints and guidance. As such I've been on the opposite end of OP situation where I am the senior dev training a new person who "fixed" a problem but the changes don't take into account of certain unique situations.



                              The way I resolved it was directly explaining the unique situations and the person was able to code around that behavior but the overall code was error prone because it was a legacy repo. My thought is you should ask the developer if there is some sort of unique situation you're not realizing that he can foresee. If there are no one off cases, and he's saying it's "broken" because you didn't follow him, then put it back on him. Write in the ticket the code works, it was tested by management, and unfortunately you do not see any situation where the code would be wrong.







                              share|improve this answer













                              share|improve this answer



                              share|improve this answer











                              answered yesterday









                              Dan

                              3,7901617




                              3,7901617




















                                  up vote
                                  0
                                  down vote













                                  It does sounds odd that he's refusing your fix, and refusing to tell you details. So its time to escalate a little. That means popping the email he's sent you to your team lead saying that you don't understand why your fix was rejected and you don't understand the functionality enough to figure out what your colleague is saying, so you request help from the TL.



                                  I would phrase this in terms of "old functionality that you don't understand the history or implications of", but you might want to refine that, but you're going to the TL "for help with this task" knowing that he will see the trail of code changes (ie "show me what you've tried so far") which will highlight the lack of co-operation from your colleague. That should be enough to get this task some visibility around the team and a focus on getting it fixed, without artificial and unhelpful impediments from your colleague (who is acting unprofessionally).



                                  At no point do you need to complain, or even mention the colleague's unhelpfulness, that will be clear.



                                  If you don't have a team lead, then pop it back on the "todo" queue and mention (in a progress meeting?) that you don't understand the problem sufficiently to fix it past what you've already tried so you're leaving it for someone more experienced to fix.






                                  share|improve this answer

























                                    up vote
                                    0
                                    down vote













                                    It does sounds odd that he's refusing your fix, and refusing to tell you details. So its time to escalate a little. That means popping the email he's sent you to your team lead saying that you don't understand why your fix was rejected and you don't understand the functionality enough to figure out what your colleague is saying, so you request help from the TL.



                                    I would phrase this in terms of "old functionality that you don't understand the history or implications of", but you might want to refine that, but you're going to the TL "for help with this task" knowing that he will see the trail of code changes (ie "show me what you've tried so far") which will highlight the lack of co-operation from your colleague. That should be enough to get this task some visibility around the team and a focus on getting it fixed, without artificial and unhelpful impediments from your colleague (who is acting unprofessionally).



                                    At no point do you need to complain, or even mention the colleague's unhelpfulness, that will be clear.



                                    If you don't have a team lead, then pop it back on the "todo" queue and mention (in a progress meeting?) that you don't understand the problem sufficiently to fix it past what you've already tried so you're leaving it for someone more experienced to fix.






                                    share|improve this answer























                                      up vote
                                      0
                                      down vote










                                      up vote
                                      0
                                      down vote









                                      It does sounds odd that he's refusing your fix, and refusing to tell you details. So its time to escalate a little. That means popping the email he's sent you to your team lead saying that you don't understand why your fix was rejected and you don't understand the functionality enough to figure out what your colleague is saying, so you request help from the TL.



                                      I would phrase this in terms of "old functionality that you don't understand the history or implications of", but you might want to refine that, but you're going to the TL "for help with this task" knowing that he will see the trail of code changes (ie "show me what you've tried so far") which will highlight the lack of co-operation from your colleague. That should be enough to get this task some visibility around the team and a focus on getting it fixed, without artificial and unhelpful impediments from your colleague (who is acting unprofessionally).



                                      At no point do you need to complain, or even mention the colleague's unhelpfulness, that will be clear.



                                      If you don't have a team lead, then pop it back on the "todo" queue and mention (in a progress meeting?) that you don't understand the problem sufficiently to fix it past what you've already tried so you're leaving it for someone more experienced to fix.






                                      share|improve this answer













                                      It does sounds odd that he's refusing your fix, and refusing to tell you details. So its time to escalate a little. That means popping the email he's sent you to your team lead saying that you don't understand why your fix was rejected and you don't understand the functionality enough to figure out what your colleague is saying, so you request help from the TL.



                                      I would phrase this in terms of "old functionality that you don't understand the history or implications of", but you might want to refine that, but you're going to the TL "for help with this task" knowing that he will see the trail of code changes (ie "show me what you've tried so far") which will highlight the lack of co-operation from your colleague. That should be enough to get this task some visibility around the team and a focus on getting it fixed, without artificial and unhelpful impediments from your colleague (who is acting unprofessionally).



                                      At no point do you need to complain, or even mention the colleague's unhelpfulness, that will be clear.



                                      If you don't have a team lead, then pop it back on the "todo" queue and mention (in a progress meeting?) that you don't understand the problem sufficiently to fix it past what you've already tried so you're leaving it for someone more experienced to fix.







                                      share|improve this answer













                                      share|improve this answer



                                      share|improve this answer











                                      answered 2 days ago









                                      gbjbaanb

                                      2,2261019




                                      2,2261019






















                                           

                                          draft saved


                                          draft discarded


























                                           


                                          draft saved


                                          draft discarded














                                          StackExchange.ready(
                                          function ()
                                          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fworkplace.stackexchange.com%2fquestions%2f117690%2fcolleague-blocks-change-request-in-peer-review-because-of-perceived-mistakes-in%23new-answer', 'question_page');

                                          );

                                          Post as a guest


















































































                                          Popular posts from this blog

                                          ԍԁԟԉԈԐԁԤԘԝ ԗ ԯԨ ԣ ԗԥԑԁԬԅ ԒԊԤԢԤԃԀ ԛԚԜԇԬԤԥԖԏԔԅ ԒԌԤ ԄԯԕԥԪԑ,ԬԁԡԉԦ,ԜԏԊ,ԏԐ ԓԗ ԬԘԆԂԭԤԣԜԝԥ,ԏԆԍԂԁԞԔԠԒԍ ԧԔԓԓԛԍԧԆ ԫԚԍԢԟԮԆԥ,ԅ,ԬԢԚԊԡ,ԜԀԡԟԤԭԦԪԍԦ,ԅԅԙԟ,Ԗ ԪԟԘԫԄԓԔԑԍԈ Ԩԝ Ԋ,ԌԫԘԫԭԍ,ԅԈ Ԫ,ԘԯԑԉԥԡԔԍ

                                          How to change the default border color of fbox? [duplicate]

                                          Avoiding race conditions in Kotlin, Smartcast is impossible runtime exception