Hands-on Demo – Managing Inner Source with Forks


LearnAzureDevOps-O5

Hands-on Demo – Managing Inner Source with Forks

In this demonstration, we’ll explore how Inner Source can be effectively managed using forks within a Git-based workflow. Forking allows contributors from different teams or departments to work independently on their own copies of a repository while collaborating on shared projects.

Scenario:

Inner Source with Forks

Goal:

Enable cross-team collaboration while maintaining separate, yet connected, repositories for innovation and integration.

Steps to Demonstrate Inner Source with Forks

1. Create a Fork for Collaboration

  1. Fork the Repository:

Team A needs to work on a specific feature (e.g., a new reporting dashboard). They create a fork of the main repository:

and create their fork:

  1. Clone the Fork Locally:

Team A clones their forked repository for feature development:

2. Feature Development in the Fork

  1. Develop New Feature:

Team A develops the feature (feature-x branch) independently:

  1. Add Changes:

Work on the changes and commit them:

  1. Push Changes:

Push the changes to the fork:

3. Sharing Changes with Other Teams

  1. Pull Request:

Team A creates a pull request (PR) to propose their changes:

This initiates a PR with reviewers from Team B and main repository maintainers.

  1. Review and Feedback:

Team B and other collaborators review and provide feedback on the PR.

4. Merging Changes Back to Upstream

  1. Merge PR:

Once reviewed and approved, Team A’s changes are merged into the main repository:

  1. Sync Fork:

Team A’s fork is now updated with the latest changes:

5. Continuing Collaboration

Ongoing Collaboration:

Teams can continue to create branches, propose changes, and maintain their own forks while contributing to the collective codebase.

Benefits of Inner Source with Forks

  1. Isolation: Teams can work independently on features while ensuring minimal disruption to the main repository.

  2. Collaboration: PRs and shared reviews allow teams to contribute seamlessly.

  3. Version Control: Each team maintains their own version of the codebase, syncing changes only when needed.

Related Articles


Rajnish, MCT

Leave a Reply

Your email address will not be published. Required fields are marked *


SUBSCRIBE

My newsletter for exclusive content and offers. Type email and hit Enter.

No spam ever. Unsubscribe anytime.
Read the Privacy Policy.