If you are a student completing this project as part of a class at Allegheny College, please check the Proactive Programmers Discord server for the assignment's due date. You can learn more about this assignment by reading the Debugging Functions project description on the Proactive Programmers web site. Please note that the content provided in the README file for this GitHub repository is an overview of the project and thus does not include the details concerning all the steps needed to successfully complete the every project deliverable. Finally, it is important to point out that your repository for this project was created from the GitHub repository template called container-cloning-starter. You can check this repository for any updates to this project's documentation or source code.
Even though the course instructor will have covered all of the concepts central to this project before you start to work on it, please note that not every detail needed to successfully complete the assignment will have been covered during prior classroom sessions. This is by design as an important skill that you must practice as a proactive programmer is to search for and then understand and ultimately apply the technical content found in additional resources.
Emerging proactive programmers who have questions about this project are invited to ask them in either the GitHub discussions forum or the Proactive Programmers Discord server. Before you ask your question, please read the advice concerning how to best participate in the Proactive Programmers community. If you find a mistake in this project, please describe it and propose a solution by creating an issue in the GitHub Issue Tracker.
After cloning this repository to your computer, please take the following steps:
- Make sure that you have already installed and know how to use all of the programming tools that are mentioned in the description of the Proactive Skills.
- Follow the instructions on the Proactive Programmers web site for this project to take all of the needed steps and to complete all of the required deliverables.
- Use the
cd
command to change into the directory for this repository. - Change into the program source code directory by typing
cd source
. - Run the provided Python script by typing the following:
python perform-container-cloning.py
: perform duplicate removal with container cloning
- The program should initially produce the following output:
Expected output not correct for input lists: [1, 2, 3, 4] and [1, 2, 5, 6]
actual_list_one: [2, 3, 4]
actual_list_two: [2, 5, 6]
At least one test case did not pass!
- You need to fix the defects in the program so that it produces the correct output:
Expected output correct for input lists: [1, 2, 3, 4] and [1, 2, 5, 6]
All of the test cases passed!
- Again, please make sure that you fix the defects inside of these programs!
- Finally, please confirm that the programs are producing the expected output.
- Make sure that you can explain why the programs produce the output that they do.
- If you have already installed the
GatorGrade program that runs
the automated grading checks provided by
GatorGrader you can, from the
repository's base directory, run the automated grading checks by typing
gatorgrade --config config/gatorgrade.yml
. - You may also review the output from running GatorGrader in GitHub Actions.
- Don't forget to provide all of the required responses to the technical writing
prompts in the
writing/reflection.md
file. - Please make sure that you completely delete the
TODO
markers and their labels from all of the provided source code. This means that instead of only deleting theTODO
marker from the code you should instead delete theTODO
marker and the entire prompt and then add your own comments to demonstrate that you understand all of the source code in this project. - Please make sure that you also completely delete the
TODO
markers and their labels from every line of thewriting/reflection.md
file. This means that you should not simply delete theTODO
marker but instead delete the entire prompt so that your reflection is a document that contains polished technical writing that is suitable for publication on your professional web site.