Skip to content

aki0501/topo-ordered-commits-test-suite

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Project from CS 35L Software Construction Laboratory at UCLA, taught by Professor Paul Eggert in Winter 2023. Assignment link: https://web.cs.ucla.edu/classes/winter23/cs35L/assign/assign6.html

My code implementation is in topo_order_commits.py, and my results are in test_results.py.

Instructions for running tests from the TA:

topo-ordered-commits-test-suite

This test suite provides some test cases to help you get on the right track.

However, passing all the test cases here does not guarantee a completely correct implementation.

The real test cases might have similar structures but will not have the same hashes.

Please do the following in order to run the test cases.

git clone https://github.com/Rustinante/topo-ordered-commits-test-suite.git
cd topo-ordered-commits-test-suite
python3 -m venv venv
source venv/bin/activate
pip3 install -U -r requirements.txt

The command source venv/bin/activate sets up a virtual environment for Python, which you should do every time you open up a shell to run this test suite.

Then, repalce the body of the function def topo_order_commits(): with your implementation, i.e., topo_order_commits should be the top level function to kick-start the entire program. This is so that we can expose the function signature topo_order_commits to the test suite.

In order to run the tests, simply type

pytest

To check for PEP8 coding style violations:

flake8 topo_order_commits.py

You can exit the virtual environment by typing deactivate.

Individual Test Cases

After running pytest once, which will unzip the *.tar.gz files in tests/repo_fixture, you can manually examine each of the test repositories inside the tests/repo_fixture directory as a way to debug your implementation. The example-repo-1 will be the first test repository, etc. After cd into the test repository, you can run your topo_order_commits.py script to see the output of your implementation on that repository.

In the pytest output, if test_topo_order_constraint[1] shows up as a failure, the [1] means the test case is based on example-repo-1, etc.

About

topologically ordered git commits

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%