Secure QA Process

Everything starts with a Merge Request

We expect and require all contributions to our products to go a merge request with a formal review. As such, we follow the Merge Request workflow and code review guidelines articulated in GitLab’s developer documentation. We would, however, like to highlight a few items from these documents and add a few additional considerations for reviewers and authors.

Additional considerations for Merge Request reviewers

  • The best way to unblock a peer or community member is to provide feedback in a timely manner. If you are at capacity and cannot facilitate a review in the SLO to which we aspire, please let folks know in the merge request so another reviewer may be found.

Additional considerations for Merge Request authors

  • Being a globally distributed organization can, and frequently does, add latency to back-and-forth communication between folks. Don’t take it personally if it’s taking longer than you expected to get feedback on your changes.

Secure QA Process

The secure analyzers verify merge requests by running a new commit against downstream test projects for their supported languages/frameworks (i.e. the gemnasium analyzer of Dependency Scanning will trigger tests against php, go, and several other test projects). The verification is done by comparing the generated report output against an expected report committed to the analyzer’s repository. If analyzer behavior has changed, then the pipeline will fail because the contents of the expected and generated reports will no longer match.

The expectations for the Dependency Scanning, SAST, and Secrets Detection analyzers are stored in the project’s qa/expect directory with a sub-directory for each particular framework/language type.

Test Projects

The test projects reside in the Secure tests subgroup and their use and best practices are found in the common README.

Changing Analyzer Behavior

If a change to an analyzer changes the report output, then the expected report must change as well.

In SAST, Dependency Scanning, Secret Detection the expected reports are stored with the analyzer in a path corresponding to the test project in a subdirectory for the language/framework. For example, the expected report for scanning the dependencies of java-maven is stored in gemnasium-maven/qa/expect. This way if an analyzer’s behavior changes, the expectation can be changed and packaged in the same commit.

For License Compliance, expectations are stored in the test project’s qa/expect directory (e.g. ruby-bundler/qa/expect).

More information about can be found in the Security Products test projects repository.

Testing on OpenShift

We currently do not have automated tests for OpenShift. If you want to see how a change affects the analyzer behavior on OpenShift, you can test it by setting up an OpenShift environment. There are two methods to do this:

1. Automated Script

The distribution team has shared an automated script for setting up an OpenShift cluster. While untested by our group, this method could potentially streamline the cluster creation process.

2. Manual Setup

You can setup an OpenShift cluster following the steps below assuming that you already have access to the GitLab Sandbox Cloud.

  1. Login to https://gitlabsandbox.cloud/.

  2. Create an AWS sandbox account and login to the AWS console by following steps 1 to 3 from Static Analysis Group EC2 development machine setup guide.

  3. Once you are logged into the AWS console, you can search for “OpenShift” in the search field in the upper left corner, which should show Red Hat OpenShift Service on AWS under the Services category. ROSA provides an integrated OpenShift experience with AWS. Click on this search result to proceed.

    openshift-service-on-aws-search-results

  4. You are redirected to the Red Hat OpenShift Service on AWS (ROSA) landing page. Click on the Get started link in the left sidebar, or the Get started orange button.

    openshift-service-on-aws-landing-page

  5. You will then be redirected to the Verify ROSA prerequisites page:

    verify-rosa-prerequisites

    Click on the Enable ROSA HCP and ROSA classic button in the ROSA enablement section, and keep the box I agree to share my AWS account number... checked. The ROSA enablement section will then explain Your request to enable ROSA is pending and may take several minutes to resolve. We recommend keeping this page open so that you can review any errors.

  6. After a few minutes, the ROSA enablement section will be updated and display the following messages:

    • You have agreed to share your AWS account number and email address with red hat.
    • You have enabled ROSA and HCP and ROSA classic.

    rosa-enabled

  7. Click on the Continue to Red Hat orange button in the bottom right corner. This will redirect you to https://sso.redhat.com and request you to Log in to your Red Hat account:

    login-to-your-redhat-account

  8. Click on Log in with Google and use your gitlab.com gmail account. You will be redirected to the Register for a Red Hat account page:

    register-for-red-hat-account

    Complete the required fields, using your gitlab.com gmail account for the Email address, then click on Create my account.

  9. You should now be redirected to a page to Complete your account connection. Check the I have read and agreed to the terms and conditions checkbox, then click on the Connect accounts button:

    complete-your-account-connection

  10. You’ll then be redirected to another page explaining We need a little more information. Complete the required fields, using your gitlab.com gmail account for the Email address, and select Personal for Account type:

    we-need-a-little-more-information

  11. The Terms and conditions box will now be displayed, click on View Terms and Conditions and accept them:

    terms-and-conditions

  12. You’ll now be redirected to the Red Hat Hybrid Cloud Console Overview screen, and can set up an OpenShift cluster by clicking the Create cluster in the Red Hat OpenShift Service on AWS (ROSA) dialog box:

    redhat-overview

    If you are only planning to use the cluster for testing, it is recommended to select the OSD Trial with a free trial period of 2 months. After this period, the cluster will be deleted. The free trial enables you to upgrade to a paid tier within time frame of two months.

  13. Once the cluster is set up, we have to create a user to login to the OpenShift cluster; you can select Cluster List > <your cluster> and select htpasswd for Identity Provider. Under Cluster Roles and Access you can create the user for accessing the OpenShift cluster. Make sure that this user belongs to the groups dedicated-admin and cluster-admins.

  14. Afterwards you can click on the Open console button and login with the cluster admin user you created in the previous step.

  15. Once you are logged into the OpenShift cluster, you can now install the GitLab Runner Operator by selecting Operators > Operator Hub. You can search GitLab Runner, click on the search result and then click on the Install button as explained here.

  16. In order to set up the runner in the OpenShift cluster, you can follow the instructions that are included in the README of the operator.

    Note that the runner token referenced in the gitlab-runner-operator README.md can be obtained by selecting CI/CD Settings > Runners > New Runner from a GitLab project.

    The runner setup requires the command line tool oc (OpenShift client) to be installed. Before using oc you have to authenticate against your cluster. You can find the authentication credentials by clicking on your OpenShift cluster admin user name and then selecting Copy login comand. Note, that the default runner setup allows containers to be executed with root privileges. In order to restrict access to non root users, you can provide the configuration below:

    [[runners]]
    name = "gitlab-runner"
    url = "https://gitlab.com"
    executor = "kubernetes"
    [runners.kubernetes]
        [runners.kubernetes.pod_security_context]
        run_as_non_root = true
        run_as_user = 1000
    

    After applying this configuration with oc create configmap my-runner-config --from-file=config.toml, you can update the runner config as illustrated below and apply it with oc appy -f gitlab-runner.yml.

    apiVersion: apps.gitlab.com/v1beta2
    kind: Runner
    metadata:
      name: gitlab-runner
    spec:
      gitlabUrl: https://gitlab.com
      buildImage: alpine
      token: gitlab-runner-secret
      tags: openshift
      config: my-runner-config
    
  17. The OpenShift runner should now appear green in your GitLab project settings CI/CD Settings > Runners.