When stashing changes, what happens to the staged and unstaged modifications in Git?
- Staged changes are preserved, unstaged changes are discarded
- Both staged and unstaged changes are preserved
- Staged changes are discarded, unstaged changes are preserved
- Both staged and unstaged changes are discarded
When you stash changes, Git saves both staged and unstaged changes. This allows you to switch branches without committing changes, and later apply the stash to continue working on the changes.
To delete a tag in Git, use the command git tag -d ________.
- tag-name
- git-delete
- tag-delete
- git-rm
The correct option is a) tag-name. This command deletes the specified tag by providing the tag name after the -d option. It helps in removing unnecessary or incorrect tags from the repository.
A Git Subtree allows you to keep a copy of an external repository in a subdirectory, treating it as a __________ project.
- separate
- nested
- linked
- subtree
The correct answer is subtree. Git subtree is a merging strategy that allows you to insert the contents of a repository into another one, but unlike submodules, the external repository becomes part of the history of the main repository. It is treated as a subtree within the main project.
How should a distributed team structure their Git branches to optimize collaboration?
- Use feature branches for each team member
- Have a central repository with a single branch
- Implement a Git branching strategy, such as Gitflow
- Allow each team member to have their own repository
Distributed Team Branching
To save changes in a new stash, you would use git stash ______.
- save
- create
- push
- store
The command to stash changes is git stash save, which saves the changes in the stash without committing them to the repository. This is useful when you need to switch to a different branch or address an urgent issue.
How can you combine multiple commits into one using Git?
- Use the git merge command with the --squash option to condense multiple commits into one before merging.
- Execute git commit --combine for the commits you want to merge, specifying the commit range.
- Use the git rebase command with the -i (interactive) option to squash, fixup, or reword commits interactively.
- Create a new branch, cherry-pick the desired commits onto it, and then merge the new branch.
Git rebase with the -i option allows for interactive rebasing, including the ability to squash commits together, providing a cleaner history.
What is the importance of Git hooks in automating tasks in CI/CD pipelines?
- Code Deployment
- Code Review
- Automated Testing
- Task Automation
Git hooks are scripts triggered by Git events, such as pre-commit or post-merge. They play a vital role in CI/CD pipelines by automating tasks like code testing and deployment, ensuring a seamless development workflow.
You're working on a feature in a separate branch and want to include recent changes from the main branch. What Git strategy should you use?
- Merge
- Rebase
- Cherry-pick
- Reset
When working on a separate branch and wanting to include recent changes from the main branch, the recommended Git strategy is to rebase. Rebasing incorporates changes from one branch into another and results in a cleaner, linear project history. Merging is another option, but it can create unnecessary merge commits. Cherry-pick and reset are not typically used for this scenario.
To remove a file from the staging area without deleting the file itself, use the command git _______.
- reset
- unstage
- rm
- discard
The correct option is unstage. This command is used to remove a file from the staging area, leaving the working directory unchanged. It allows you to unstage changes that you previously staged with git add.
What is an essential step in ensuring a smooth transition from a centralized VCS to Git?
- Train team members on Git fundamentals and best practices.
- Avoid training and let the team adapt on their own.
- Perform the migration without informing the team to minimize resistance.
- Hire external consultants to handle the transition.
Training team members on Git fundamentals and best practices is essential for a smooth transition. Avoiding training may lead to confusion, and informing and involving the team in the process helps mitigate resistance. Hiring external consultants may not address the internal team's needs effectively.