Setting the Scene
Figure 1
Section 1: Setting Up Environment For Collaborative Code Development
Figure 1
1.1 Introduction to Our Software Project
Figure 1
data:image/s3,"s3://crabby-images/8710a/8710a3acc32cceec3b4b8bc6da5ae77cc3fcbdf2" alt="Snapshot of the inflammation dataset"
Figure 2
data:image/s3,"s3://crabby-images/5460a/5460ad77bd998e9b09c788111472763bf761d390" alt="Software project fork repository in GitHub"
Figure 3
data:image/s3,"s3://crabby-images/de90f/de90fadb76659e142a0c13b3115842807afad966" alt="Making a fork of the software project repository in GitHub"
Figure 4
data:image/s3,"s3://crabby-images/52dc3/52dc3c7ef8668ac96f78282604d10b18f8577a84" alt="View of your own fork of the software repository in GitHub"
Figure 5
data:image/s3,"s3://crabby-images/b4d8f/b4d8f8fbddf5cdc79cbcb4f8efff42fbf1b77668" alt="URL to clone the repository in GitHub"
1.2 Virtual Environments For Software Development
Figure 1
data:image/s3,"s3://crabby-images/50a93/50a9373402b2411b194baf1c6222c187be3fb58d" alt="Python environment hell XKCD comic"
1.3 Integrated Software Development Environments
Figure 1
data:image/s3,"s3://crabby-images/0a27e/0a27e7d17f09d87d1ff87b322bc51af93063c4b2" alt="View of an opened project in PyCharm"
Figure 2
data:image/s3,"s3://crabby-images/c62c9/c62c9ce75f7dda2902f19231f4c23e2bee06486e" alt="Missing Python Interpreter Warning in PyCharm"
Figure 3
Virtualenv Environment
from the list on the left
and ensure that Existing environment
checkbox is selected
within the popup window. In the Interpreter
field point to
the Python 3 executable inside your virtual environment’s
bin
directory (make sure you navigate to it and select it
from the file browser rather than just accept the default offered by
PyCharm). Note that there is also an option to create a new virtual
environment, but we are not using that option as we want to reuse the
one we created from the command line in the previous episode. data:image/s3,"s3://crabby-images/6f66e/6f66ee1ab0e7620432ec8db499708b6a9e54a690" alt="Configuring Python Interpreter in PyCharm"
Figure 4
data:image/s3,"s3://crabby-images/98112/9811259f191ed297706dd7a93ceeef6881c50ac9" alt="Packages Currently Installed in a Virtual Environment in PyCharm"
Figure 5
+
icon at the top of the window. In the
window that appears, search for the name of the library
(pytest
), select it from the list, then select
Install Package
. Once it finishes installing, you can close
that window. data:image/s3,"s3://crabby-images/45f71/45f71f0d06dda0754f34b4186e3aa4b059293b18" alt="Installing a package in PyCharm"
Figure 6
Add new run configuration...
then
Python
. data:image/s3,"s3://crabby-images/50571/5057143cc00486f49290152e24b0a56304b4e08f" alt="Adding a Run Configuration in PyCharm"
Figure 7
Script path
field
select the folder button and find and select
inflammation-analysis.py
. This tells PyCharm which script
to run (i.e. what the main entry point to our application is). data:image/s3,"s3://crabby-images/1b3be/1b3be09658f8987203fe88171204426cacb3a6a2" alt="Run Configuration Popup in PyCharm"
Figure 8
data:image/s3,"s3://crabby-images/5c01a/5c01af7269e93890a182bb8b9c32849f650d0319" alt="Syntax Highlighting Functionality in PyCharm"
Figure 9
data:image/s3,"s3://crabby-images/4d98d/4d98d8324e20c99855af30c8d0f47366ce823f0a" alt="Code Completion Functionality in PyCharm"
Figure 10
data:image/s3,"s3://crabby-images/60711/6071198041b1a985b917b070eb10997f64e2d4b3" alt="Code References Functionality in PyCharm"
Figure 11
data:image/s3,"s3://crabby-images/4c041/4c041d17f4e2445f80ece3d9a4a82898e21315a6" alt="Code Search Functionality in PyCharm"
Figure 12
data:image/s3,"s3://crabby-images/b2d3d/b2d3dd938d68ff8c66592ad56065b52b246df3db" alt="Code Search Functionality in PyCharm"
Figure 13
data:image/s3,"s3://crabby-images/87554/87554c45b65b6b8b66052130e1d32aef7adc81d2" alt="Version Control Functionality in PyCharm"
Figure 14
data:image/s3,"s3://crabby-images/9019c/9019c075b2aec2dbf9b0b0987c81ce4cf40caddf" alt="Running a script from PyCharm"
1.4 Software Development Using Git and GitHub
Figure 1
Figure 2
data:image/s3,"s3://crabby-images/4e572/4e572e9c176946455e8ead171f85d4e23d0644bd" alt="git-distributed"
Figure 3
Figure 4
data:image/s3,"s3://crabby-images/6cf9f/6cf9f6cc947eee7ef144d23667144d7c7e820738" alt="Software project's main branch"
Figure 5
data:image/s3,"s3://crabby-images/170c2/170c2fde9eb93cc48b78ca86ee3309fc68c58375" alt="Software project's develop branch"
1.5 Python Code Style Conventions
Figure 1
data:image/s3,"s3://crabby-images/f5993/f59939ac2cc88d9e34384dd556120ef1f775bf8e" alt="Python code indentation settings in PyCharm"
Figure 2
data:image/s3,"s3://crabby-images/627b5/627b52aa8e6ec12d89672e552d8cccbed65fbc22" alt="Python code whitespace settings in PyCharm"
1.6 Verifying Code Style Using Linters
1.7 Optional Exercises for Section 1
Section 2: Ensuring Correctness of Software at Scale
Figure 1
2.1 Automatically Testing Software
2.2 Scaling Up Unit Testing
2.3 Continuous Integration for Automated Testing
Figure 1
data:image/s3,"s3://crabby-images/59cb9/59cb961eec28f20965c9e56087c4ac439251013f" alt="Continuous Integration with GitHub Actions - Initial Build"
Figure 2
data:image/s3,"s3://crabby-images/d7e5d/d7e5db8e2ce4373ac8e652c30e43800cebccb360" alt="Continuous Integration with GitHub Actions - Build Log"
Figure 3
data:image/s3,"s3://crabby-images/de522/de522c26973dac288f35203db39d3ac05740af37" alt="Continuous Integration with GitHub Actions - Build Details"
Figure 4
data:image/s3,"s3://crabby-images/358c1/358c178afee3fc9c869c00341796d0fd6c3d9e5e" alt="Continuous Integration with GitHub Actions - Build Matrix"
2.4 Diagnosing Issues and Improving Robustness
Figure 1
data:image/s3,"s3://crabby-images/fd13d/fd13d541f46812296de9e06191b01fea664fa6c5" alt="NumPy arrays of incompatible shapes"
Figure 2
data:image/s3,"s3://crabby-images/f6818/f68184489ad7f5963c8131f5cc63e70e826d2829" alt="NumPy arrays' shapes after adding a new_axis"
Figure 3
data:image/s3,"s3://crabby-images/a4912/a4912d8f74b180cf8d062292bbd07f406b783a6d" alt="NumPy arrays' shapes after broadcasting"
Figure 4
data:image/s3,"s3://crabby-images/a6eca/a6eca6027a27fab4f201d1109896b29bd3550963" alt="Setting up test framework in PyCharm"
Figure 5
data:image/s3,"s3://crabby-images/0ba4b/0ba4b36a47a07620f4cab0d017ccb7aee7533805" alt="Running pytest in PyCharm"
Figure 6
data:image/s3,"s3://crabby-images/f6184/f6184441d94bfeb2ccbf847d596eac01130a3b0c" alt="Ensuring testing configurations in PyCharm are correct"
Figure 7
data:image/s3,"s3://crabby-images/10a5d/10a5dc38fe7763d7d0a8ec314c56d47a482541ae" alt="Running a single test in PyCharm"
Figure 8
data:image/s3,"s3://crabby-images/7599a/7599a6f7782fa46ca00d3cc57f93d41636ff1690" alt="Setting a breakpoint in PyCharm"
Figure 9
data:image/s3,"s3://crabby-images/01ed3/01ed371f4b77e3670b4e173791f9e17d6e6e7875" alt="Debugging in PyCharm"
Figure 10
data:image/s3,"s3://crabby-images/08a62/08a62a8fe4b60814e1184a7e5447d66046848156" alt="Debugging in PyCharm"
Figure 11
data:image/s3,"s3://crabby-images/7df4c/7df4cbf4c2fb47fbed5be34dc786f9cbf34d3b8a" alt="All tests in PyCharm are successful"
2.5 Optional Exercises for Section 2
Section 3: Software Development as a Process
Figure 1
3.1 Software Requirements
3.2 Software Architecture and Design
Figure 1
data:image/s3,"s3://crabby-images/b6383/b6383c8b68272437e609e6964f5b923ee56ad11e" alt="Writing good code comic"
Figure 2
3.3 Code Decoupling & Abstractions
3.4 Code Refactoring
3.5 Software Architecture Revisited
Section 4: Collaborative Software Development for Reuse
Figure 1
4.1 Developing Software In a Team: Code Review
Figure 1
Figure 2
New pull request
button. data:image/s3,"s3://crabby-images/8f872/8f872c81afada6a7874a188d21f820bdd52feb50" alt="GitHub pull requests tab"
Figure 3
Create pull request
button to open the request.
data:image/s3,"s3://crabby-images/bdcc9/bdcc988aabd3504651ce7f093f3503af84f4e59b" alt="Creating a new pull request."
Figure 4
Create pull request
button
(in the new window). data:image/s3,"s3://crabby-images/9b21d/9b21dd83b08141d1848242a183d01dd67ad1254c" alt="Submitting a pull request."
Figure 5
data:image/s3,"s3://crabby-images/fefb9/fefb93e1859bdb0bf255ca5803170aaf321e0b42" alt="Adding a collaborator in GitHub"
Figure 6
Locate up the pull request from the GitHub’s
Pull Requests
tab on the home page of your fellow learner’s
software repository, then head to the Files changed
tab on
the pull request.
Figure 7
When you find a line that you want to add a comment to, click on
the blue plus (+) button next to the line. This will bring up a “Write”
box to add your comment. You can
also add comments referring to multiple lines by clicking the plus and
dragging down over the relevant lines. If you want to make a concrete
suggestion or a change to the code directly, such as renaming a
variable, you can click the
Add a suggestion
button (which
looks like a document with a plus and a minus in it). This will populate
the comment with the existing code, and you can edit it to be what you
think the code should be.
Figure 8
Note: you can only make direct code suggestions
if you are a collaborator on a repository. Otherwise, you can add
comments only. GitHub will then provide a button for the code author to
apply your changes directly.
Figure 9
Finish your review
button at the
top of the Files changed
tab. data:image/s3,"s3://crabby-images/2df44/2df44ef8680d811e983a34517dc47128101b2ef1" alt="Using the finishing your review dialog"
Figure 10
Comment
,
Approve
or Request changes
. data:image/s3,"s3://crabby-images/6367a/6367a6cccbee98f0e790d91bd2af594ce632d889" alt="Using the finishing your review dialog"
Figure 11
data:image/s3,"s3://crabby-images/09f36/09f369e36777a98cb1c0ba05dd9c795ef4485d5b" alt="Responding to a review comment with an emoji"
data:image/s3,"s3://crabby-images/77f79/77f79f642b25548f22040098a7d32f2066d03015" alt="Responding to a review comment with a link to commit"
Figure 12
data:image/s3,"s3://crabby-images/9f31b/9f31bae4745959b5045ca1c9b62ff21ca4c166bb" alt="Merging a pull request in GitHub"
4.2 Preparing Software for Reuse and Release
4.3 Packaging Code for Release and Distribution
Section 5: Managing and Improving Software Over Its Lifetime
Figure 1
5.1 Managing a Collaborative Software Project
Figure 1
data:image/s3,"s3://crabby-images/e897d/e897d310d47445ff7d85105a65cc207b6adaeea5" alt="List of project issues in GitHub"
Figure 2
data:image/s3,"s3://crabby-images/4e9da/4e9daaff94ec19b5ad9fc2cd76eccf4faaa1f40d" alt="Creating a new issue in GitHub"
Figure 3
data:image/s3,"s3://crabby-images/58ed4/58ed48eebb1bd9ff8537ea90e79eda70728078ad" alt="Referencing comments and commits in GitHub"
Figure 4
data:image/s3,"s3://crabby-images/8ddd2/8ddd2cfb40e220b4fdc755b9017bd8282d40fd5b" alt="Adding a new project board in GitHub"
Figure 5
data:image/s3,"s3://crabby-images/07272/07272d514560bdb13420db3f8329f0c7ffcf6f05" alt="Selecting a project board template in GitHub"
Figure 6
After it is created, you should also populate the description of
the project from the project’s Settings, which can be found by clicking
the ...
button in the top right corner of the project.
After adding a description, select
Save
.
Figure 7
data:image/s3,"s3://crabby-images/f640f/f640f047f2032134c1f8344cb4c0ae5973c7c28c" alt="Default card board in GitHub"
Figure 8
data:image/s3,"s3://crabby-images/5ce6a/5ce6a8f2c2ae58ef71b9bc1d68255d80fd0c6dc8" alt="Adding issues and notes to a project board in GitHub"
Figure 9
data:image/s3,"s3://crabby-images/04e33/04e33cee9fe3e13261caf9fcf11b5b743febca4c" alt="Converting a task to issue"
Figure 10
Finally, you can change the way you view your project by adding
another view. For example, we can add a Table view to our Board view by
clicking the New button
and selecting it from the drop down
menu.
5.2 Assessing Software for Suitability and Improvement
5.3 Software Improvement Through Feedback
Figure 1
data:image/s3,"s3://crabby-images/05221/052213654ec70b1550dd9f92b6db7442beeb042a" alt="Milestones in GitHub"
Figure 2
data:image/s3,"s3://crabby-images/153d4/153d41f11093ed342178ca7030ac0dfde2b717d0" alt="Create a milestone in GitHub"
Figure 3
data:image/s3,"s3://crabby-images/b047d/b047dfc1e605083ce3fd04946faa9d1367478f0f" alt="Create a milestone in GitHub"
Figure 4
data:image/s3,"s3://crabby-images/126bd/126bdd1b9fcc1ec1b7543a0d03218ade7d65ad73" alt="Milestones in GitHub"
Wrap-up
Figure 1
data:image/s3,"s3://crabby-images/5caa7/5caa76d645b9058df14b751914fdd98ddf870bef" alt="Usefulness versus time to master grid"
Figure 2
data:image/s3,"s3://crabby-images/5060c/5060c094a75146b25798537f7cff7122789e2ce7" alt="Overview of tools and techniques covered in the course"
Figure 3
data:image/s3,"s3://crabby-images/ad269/ad26980bc42fc23c9962a5fa05435449ed4744bc" alt="Overview of topics covered in the course based on level of difficulty"