Skip to content

Rustinante/topo-ordered-commits-test-suite

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

26 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages