Day 22

For Next Time

READMEs

Every project should have a README file explaining what it does, how to run it, etc. On GitHub in particular, this is your project’s landing page and the first impression people will have of your work.

Exercise:

With your team, share your list of important README elements from the previous Reading Journal. Combine these with the guidelines from the final project README rubric and use them to improve your project’s README.

Even though you are not yet done with your project and thus may not be able to complete every section of the project README, we’d like you to update your draft of the README today to help provide context for the code review exercise.


Code Reviews

For some motivation from everyone’s favorite site, please check out this quote from Jeff Atwood.

I believe that peer code reviews are the single biggest thing you can do to improve your code.

    – Jeff Atwood, Co-Founder of Stack Overflow

Source: http://blog.codinghorror.com/code-reviews-just-do-it/

Code reviews are widely used in industry as a means to improve code quality. Often, code reviews will be required before finalizing any contributions to a software repository. For instance, a very common workflow for code reviews is to use Git branches for feature development, which are merged into the master branch only after detailed comments are provided and any issues are resolved. (If you’d like to try out using branches in Git, go for it!)

There are lots of good resources on the nuts and bolts of implementing code reviews in different settings. Regardless of the technical details of the review, it’s important to remember that there is a person on the other side of the review, and to approach the exercise with respect and awareness of your own biases.

Starting with today’s class, course instructors will be doing a review of your team’s code. The purpose of this review is a bit different than the code reviews described above, in that we are not seeking to find every last tiny error in the code. Rather, we will focus on providing course corrections and high-level feedback that can help you shape your work over the final weeks of the project. As such, we’d like you to engage with the following steps to frame your code review.

1) Prepare your repository for external readers and code review:

Work through the exercises below to prepare your project repository for the review. You should:

2) Point us in the right direction:

Fill out the code review framing form to help us to give you the most useful feedback possible. Please take a look at the survey so that you have a sense of what information we are asking for.

Some ideas for choosing code sections:

Ensure that each code section has sufficient documentation for a reviewer to figure out when it’s called, what it does, and how it does it.

In the survey we ask you to point us to 2-3 specific sections of code. This might be a few lines, a function, a class, or an entire file depending on what you want to review and the questions you have. Consider making your selections reflect a range of these scales - some big picture, some detail. No matter what sections you choose, you must frame the review by explaining why you’d like us to look at that section and posing specific questions about it. Check out the instructions on the Recipes page to see how to create links to your work on GitHub.


Documentation

Your README is a critically important part of your project documentation, but code documentation matters too. We previously discussed documentation expectations and tools. Review that material with your final project code in mind.

As a general guideline, (in addition to your README) you should have:

Exercise:

Ensure that your code documentation meets the standards above. Autogenerate documentation for your project using pydoc:

pydoc path/to/my_project.py

This will open a help file based on your docstrings (use q to quit). Check that this help file would be adequate for someone using your code - try showing it to someone not on your team. Add to your documentation based on this feedback.

pydoc can also generate HTML documentation, which you can add to your project website if you like (not required). If you want to generate truly beautiful online documentation, check out Sphinx (the tool used to generate the Python documentation).

Style and Lint

We previously discussed good style and ‘lint’ tools. Review that material with your final project code in mind.

Exercise:

Run pylint or pycodestyle (formerly called pep8) on your project code and analyze the results. You don’t need to fix everything, but it’s best to know what rules you’re breaking and why.

Organization

We previously discussed strategies for organizing large Python projects on day 16. Review that material with your final project code in mind.

Exercise:

Review the current organization of your project code. Think about and sketch out how you intend to organize your work into modules grouping related code before the final submission. This should likely correspond strongly to your system architecture diagram.

As we previously noted, this type of major refactoring can create lots of merge conflicts if you are not careful. It is best to make sure everything is checked in first, do the exercise together as a team, and have test cases before and after the restructuring to make sure nothing breaks. Now might not be the right time to do the actual reorganization, and that’s OK.