Skip to content

clouden90/schedulecheck

Repository files navigation

Build Status

schedulecheck is a simple python app to check schedule conflict. The concepts of Regression testing CI pipeline, and auto-release are also implemented in this repo.

File structure

.
├── LICENSE
├── pyproject.toml
├── README.md
├── .gitignore
├── setup.cfg
├── example/
│   └── schedule.txt 
├── reference/
│   ├── method1_ref.txt  
│   └── method2_ref.txt 
├── src/                    
│   ├── schedulecheck/
│       ├── bin/
│           ├── __init__.py
│           └── schedulecheck.py 
│       ├── __init__.py  
│       ├── meetinglib.py  
│       └── test_meetinglib.py                
└── .circle/
  • example/schedule.txt - The example txt file contains meeting times.
  • reference/*_ref.txt - The reference answers based on example/schedule.txt (mainly for regression testing).
  • ./src/schedulecheck/bin/schedulecheck.py - Main driver that read input file and find conflicting schedule.
  • ./src/schedulecheck/meetinglib.py - Meetinglib library that contains algorithms of schedule-conflict check.
  • ./src/schedulecheck/test_meetinglib.py - automated tests(mainly for ci pipeline) for the conflicts_check functions in Meetinglib library.

Algorithms

Two algorithms are implemented:

  • Method1 (conflicts_check1): A simple algorithm is used to check the conflicts. First, the schedules are sorted by end time. Then for loops are used by checking the first meeting and comparing its end time to the start time of the second meeting. If they overlap, the pair will be added in conflict list and keep comparing the first schedule to third, forth ones until no more overlap. Then it continue by comparing the second schedule to the following meetings, and so on. This method could run close to O(nlogn) (sorting in python takes O(nlogn)) if there are only a few conflicting meetings and that they are of similar interval length. However, worst case for this method would be O(n^2) if there are too many confliciting events.

  • Method2 (conflicts_check2): A Interval Tree algorithm is used to slove the problem. First, a Interval Tree is created and initialized with the first schedule. For the rest of the appointments, it will check if the current appointment conflicts with any of the existing appointments in Interval Tree. If conflicts, the pair will be added in conflict list. Then the current appointment will be inserted in Interval Tree, and move to the next one and so on. The complexity of this method is O(nlogn).

Installation

Assuming you have python3 (>=3.6) already installed, schedulecheck can be downloaded and installed by running

# download source code
git clone https://github.com/clouden90/schedulecheck.git
cd schedulecheck

# Install
pip install .

Alternatively, you can try install with --user option (e.g. pip install --user .). Make sure to add your user bin directory to PATH environment. The 
defalut location is like: /home/YOUR_USERNAME/.local/bin/

Run the driver with simple test file

schedulecheck -f <path/schedlue_filename> -o {path/output_filename} -m {1:method1 or 2:method2} -t {Regression testing 0:off 1:on} -v {version info}

schedulecheck -h # provide some useful information about how to use the driver 
schedulecheck -f ./example/schedule.txt -o ./schedule_check.txt -m 1
or
/home/YOUR_USERNAME/.local/bin/schedulecheck -f ./example/schedule.txt -o ./schedule_check.txt -m 1

Then you can check the output `schedule_check.txt`, it should contain soemthing like this with method1:
10:15-10:30 and 10:00-11:00 conflict
11:30-11:45 and 11:00-13:00 conflict
11:00-13:00 and 12:00-13:00 conflict

or like this with method2:
10:15-10:30 and 10:00-11:00 conflict
12:00-13:00 and 11:00-13:00 conflict
11:30-11:45 and 11:00-13:00 conflict

For developer/contributer

If you would like to contribute/add a new function in meetinglib.py, you should also add an automated test associated to that function in test_meetinglib.py for ci test.

About

check conflicting appointments

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages