Featured
- Get link
- X
- Other Apps
Week 10: Lab 8: Automated Testing and Continuous Integration
Lab 8
This lab was about introducing automated testing and continuous integration into are URL checker programs. Automated testing helps makes sure new code runs and doesn't break the current version of the program by running a variety of user defined tests. Using GitHub Actions we can add continuous integration to are programs. The purpose of this is to automatically run are tests when a PR is made to the project, before we had to run the tests manually. With both of these concepts put in place we can ensure new code introduced in a PR doesn't break the program.
Completing the Lab
I'm going to warn you now since this lab was so long, this will be a longer blog post then normal. Have fun.
The first steps for the lab had me researching how to add some basics unit tests to my project. Since I'm using GO, I used the "testing" package for this. My first test simply just checked what happens when the readFile function was supplied an empty file.
To test my branch I had to run "go test", this automatically searched for my defined testing functions and ran them giving me the output in the console.
After this I made two new unit tests to test my checkStatus function for when it is given a 200 and 404 error. Todo this I had to make a "mock" to simulate a URL that would respond with a 200 or 404. Todo this I used the "net/http" package. I'm still confused on the whole process of setting these mock responses up, but I understand the purpose for them.
Here's the 200 status code test I made. The WriteHeader() on line 4 was where I set which status code I wanted to receive, in this case it was set to "StatusOK".
Once this was done I added in code coverage analysis. The purpose of this is to see how much of the code is covered by unit testing. The higher the percentage the better, but it also depends on how complex the code is. To add this in I used GO's built in testing framework and added the "-cover" flag when using "go test". The output of this command gave me a percentage of how much of my code was covered. I also made a report using "go test -coverprofile=coverage.out". This made a .out file where I could view the coverage.
Once all these steps were done I squashed and merged my branch into master.
The next step was to add automatic testing when making a PR. Todo this I added in continuous integration via GitHub Actions. There was already a GO workflow made so I choose this one for the project. Doing this added a YAML file to the project. I made a new PR to test both passing and failing to see how it all worked.
Here's what the default GO workflow looked like:
After all this I added more information to the CONTRIBUTING doc about how to test and check the code coverage.
The last part of the lab was to add in a new unit test on someone else's project. For this I paired up with Michael Brackett who's project was made using Python. Setting up the project was pretty straight forward, but I had some issues running his tests. I think this was an issue with miss-matched versions of Python since I was using 3.9 and he was using 3.7, but in the end I got it working and made a PR that passed his CI.
Final Thoughts
I think this lab was very important for the future of my coding. Every major project has these systems in place and each language may differ but they all follow the same concepts. Overtime I hope to improve with unit testing since its such an important concept and skill to have as a developer.
Thanks,
-Matt
- Get link
- X
- Other Apps
Comments
Post a Comment