Integrate GitHub with Jenkins

Integrate GitHub with Jenkins

Integrate GitHub with Jenkins

Integrating GitHub with Jenkins automates your development process. Here’s how to set it up:

Prerequisites

Steps to Integrate GitHub with Jenkins

1. Install GitHub Plugin in Jenkins

  1. Go to Jenkins Dashboard.
  2. Click on "Manage Jenkins".
  3. Click on "Manage Plugins".
  4. Search for the following plugins in the Available tab:

    • GitHub Plugin
    • Git client
    • GitHub API
    • GitHub Authentication
    • GitHub Branch Source
    • GitHub Integration
    • GitHub Issues
    • Pipeline: GitHub
    • Pipeline: GitHub Groovy Libraries
    • Pipeline: Groovy
    • Pipeline: Groovy Libraries
    • Pipeline: Input Step
    • Pipeline: Job
    • Credentials Plugin
    • OAuth Credentials
  5. Install the plugins and restart Jenkins if needed.

3. Create a Jenkins Job

  1. Go to Jenkins Dashboard.
  2. Click on "New Item".
  3. Enter the job name and select "Freestyle project".
  4. Click "OK".

4. Configure the Job to Use GitHub

  1. In the job configuration, go to the "Source Code Management" section.
  2. Select "Git".
  3. Enter your GitHub repository URL.
  4. Add credentials if needed.

5. Set Up Build Triggers

  1. Scroll to the "Build Triggers" section.
  2. Check "GitHub hook trigger for GITScm polling".

6. Configure GitHub Webhook

  1. Go to your GitHub repository.
  2. Click on "Settings".
  3. Click on "Webhooks".
  4. Click "Add webhook".
  5. Enter the Payload URL (your Jenkins URL + /github-webhook/).
  6. Select "application/json" as the content type.
  7. Choose events to trigger the webhook (e.g., "push").
  8. Save the webhook.

7. Test the Integration

  1. Make a change in your GitHub repository and push it.
  2. Check if the Jenkins job is triggered automatically.
  3. Verify the build status in Jenkins.

Example Pipeline


  pipeline {
      agent any

      stages {
          stage('Checkout Code') {
              steps {
                  git 'https://github.com/your-username/your-repository.git'
              }
          }

          stage('Install Dependencies') {
              steps {
                  sh 'npm install'
              }
          }

          stage('Run Tests') {
              steps {
                  sh 'npm test'
              }
          }

          stage('Build') {
              steps {
                  sh 'npm build'
              }
          }

          stage('Deploy') {
              steps {
                  sh 'npm deploy'
              }
          }
      }
  }

Steps to Configure GitHub with Jenkins

Registering a GitHub App

To improve security and control, convert your GitHub repository into a GitHub App. See herefor more details.

  1. Navigate to your GitHub profile settings.
  2. Under "Developer settings", click GitHub Apps.
  3. Click the "New GitHub App" button and follow the prompts to create the app.
  4. Generate a private key and store it securely.

Set GitHub Permissions for Pipeline

Ensure your GitHub App has the necessary permissions to interact with Jenkins:

Repository Permissions:

  1. Contents: Set to Read & Write. This allows the pipeline to read and write files in the repository, essential for Jenkins to check out the code, make changes, and push updates if needed.
  2. Metadata: Set to Read-only. Necessary to access repository metadata, such as information about the repository.
  3. Issues: Set to Read & Write. If your pipeline automates issue management, such as creating or closing issues, this permission is required.
  4. Pull Requests: Set to Read & Write. This is necessary if the pipeline interacts with pull requests, such as triggering builds or adding comments.
  5. Commit Statuses: Set to Read & Write. This allows Jenkins to update the status of commits, indicating whether a build has passed or failed.
  6. Deployments: Set to Read & Write. If your Jenkins pipeline handles deployments, this permission allows the pipeline to create, modify, or view deployment statuses.

Organization Permissions:

  1. Members: Set to Read-only. If your Jenkins setup interacts with organization members, this permission might be needed.

Webhook Permissions:

  1. Events: Enable Push, Pull Request, and Issue Comment events. Ensure Jenkins is notified of relevant events like code pushes, pull requests, and issue comments, allowing it to trigger builds automatically.

Administration Permissions: (Use with caution)

  1. Repository Administration: Read & Write (Optional). Allows Jenkins to perform administrative tasks on the repository, such as renaming the repository or modifying settings.

Additional Considerations:

  1. Install the App: Ensure the GitHub App is installed on the correct repositories or the entire organization where your pipeline will be operating.
  2. Webhook Secret: If using webhooks, ensure that the webhook secret configured in GitHub matches the one configured in Jenkins.

Conclusion

Integrating GitHub with Jenkins automates your CI/CD process. Follow these steps to set up the integration and streamline your development workflow.