Welcome to the Code Drift Challenge! This challenge simulates the common real-world problem of code drift, where different versions of code diverge in functionality, leading to potential conflicts, bugs, and misunderstandings.
Your task is to recognize areas of code drift, reconcile the differences across branches, and produce a unified, functional version of the application.
- Identify areas where code has drifted across branches.
- Merge features and changes from all branches (dev,staging, andproduction) into a new unified branch.
- Resolve any conflicts that arise.
- Ensure the final code runs without errors and has all intended features.
- Update documentation to reflect the reconciled code's actual behavior.
Clone this repository:
git clone https://github.com/Chaos-Camp/code-drift-challenge-python.git
cd code-drift-challenge-pythonNavigate through the branches to understand the unique features or changes each branch introduces:
git checkout dev
# Review changes
git checkout staging
# Review changes
git checkout production
# Review changesCreate a new branch for your unified code:
git checkout -b unified_codeMerge features from dev, staging, and production into unified_code. You'll likely encounter merge conflicts, which you'll need to resolve manually.
Run the application to ensure that it's working as intended. All features from the separate branches should be present in your unified code without any errors.
Based on the final version of your code, update the README.md to accurately describe the application's behavior and features.
- Review the commit history of each branch to understand the evolution of the code.
- Make sure to test the application after merging each branch to catch and rectify any issues early on.
- While resolving merge conflicts, understand the intent behind each change instead of choosing one change over another arbitrarily.
- Successful identification and reconciliation of all areas of drift.
- Merged code runs without errors.
- Documentation accurately describes the application's behavior and features.
Once completed, you'll have a better understanding of code drift, its implications, and how to tackle it in a real-world scenario. Good luck, and happy coding!