Which Git command is used to undo the last commit while keeping the changes in the working directory?

  • git reset HEAD~1
  • git revert HEAD
  • git commit --amend
  • git checkout -- .
The correct option is git reset HEAD~1. This command resets the last commit while keeping the changes in the working directory. The HEAD~1 refers to the commit before the last one.

In Git, a '_______ merge' is used to integrate changes from one branch into another, creating a new commit even if a fast-forward merge is possible.

  • Fast-forward
  • Recursive
  • Squash
  • Three-way
In Git, a 'Three-way merge' is used to integrate changes from one branch into another, creating a new commit even if a fast-forward merge is possible. This merge strategy involves comparing the changes in three branches—the two branch tips and their common ancestor. It is particularly useful when there are conflicting changes on both branches.

A developer needs to temporarily switch context to another task without committing their current, incomplete work. What Git feature is most appropriate for this scenario?

  • Git Reset
  • Git Stash
  • Git Checkout
  • Git Revert
The suitable option is Git Stash. It allows the developer to save changes in a stack, switch to another task, and then come back to the original changes without committing them.

How can branch management in Git optimize the CI/CD process?

  • Reduced Conflicts
  • Parallel Development
  • Stash Changes
  • Annotated Tags
Branching in Git is crucial for parallel development. It allows multiple developers to work on different features simultaneously, optimizing the CI/CD process by avoiding conflicts and enabling efficient collaboration.

In CI/CD, the practice of automatically deploying all code changes to a _________ environment is common.

  • Staging
  • Development
  • Production
  • Testing
In CI/CD, the final deployment is often done to the Production environment, ensuring that the changes are applied to the live system. This helps in delivering new features or bug fixes to end-users.

How does the git reflog command assist in recovering lost commits?

  • Lists all remote branches
  • Shows a log of changes to branch references
  • Deletes the commit history
  • Resets the working directory
The git reflog command displays a log of changes to branch references, including commits that may not be part of the current branch. It's useful for recovering lost commits or undoing changes.

In a case study of a successful enterprise, what Git practice was found to be key in managing their large-scale projects efficiently?

  • Git Flow Workflow
  • Forking Workflow
  • Feature Branch Workflow
  • Centralized Workflow
The Feature Branch Workflow was found to be key in managing large-scale projects efficiently. It involves creating separate branches for each feature, allowing parallel development without affecting the main codebase until features are thoroughly tested and ready for integration.

What impact does Git have on continuous integration and continuous deployment in Agile teams?

  • Improved collaboration and parallel development
  • Faster integration and deployment pipelines
  • Better tracking of changes and versioning
  • Increased code conflicts
Git positively impacts continuous integration and continuous deployment in Agile teams by enabling faster integration and deployment pipelines, improving collaboration through parallel development, and ensuring better tracking of changes and versioning.

How does Git ensure data integrity in large repositories?

  • Periodic manual checks by administrators
  • Automatic garbage collection
  • Ignoring large files during commits
  • Disabling history tracking for certain files
Git ensures data integrity in large repositories through automatic garbage collection. This process identifies and removes unnecessary or unreferenced objects, maintaining the integrity and efficiency of the repository over time.

The command git _______ is used to create a new branch and switch to it in one step.

  • branch
  • checkout -b
  • newbranch
  • switchbranch
The correct command is git checkout -b . This command creates a new branch and switches to it in one step, saving you from the need to create a branch and then switch to it separately.

In Git, the __________ file can be used to enforce code quality standards across all project contributors.

  • .gitignore
  • .gitattributes
  • .gitconfig
  • .gitkeep
The .gitattributes file is used to enforce code quality standards across all project contributors by specifying attributes for files in the repository. It helps in maintaining consistency and best practices.

A developer accidentally commits a large binary file. What Git feature should they use to remove this file from history while retaining current changes?

  • rebase
  • reset
  • filter-branch
  • reflog
The correct option is filter-branch. This Git command allows the modification of the repository's commit history, including the removal of sensitive or large files. It's crucial to be cautious when using this command as it can rewrite history, impacting collaborators.