 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Overview ¶
Package build contains the OpenShift build system.
It defines a Build resource type, along with associated storage and a controller that executes builds and manages states of existing builds.
For newly created builds, the BuildController will assign a pod ID to the build and set the build’s state to pending. This way, the assignment of the pod ID and pending status is idempotent and won’t result in two BuildControllers potentially scheduling two different pods for the same build.
For pending builds, the BuildController will attempt to create a pod to perform the build. If the creation succeeds, it sets the build’s status to pending. If the pod already exists, that means another BuildController already processed this build in a pending state, resulting in a no-op. Any other pod creation error would result in the build’s status being set to failed.
For running builds, the BuildController will monitor the status of the pod. If the pod is still running and the build has exceeded its allotted execution time, the BuildController will consider it failed. If the pod is terminated, the BuildController will examine the exit codes for each of the pod’s containers. If any exit code is non-zero, the build is marked as failed. Otherwise, it is considered complete (successful).
Once the build has reached a terminal state (complete or failed), the BuildController will delete the pod associated with the build. In the future, it will be desirable to keep a record of the pod’s containers’ logs.
       Source Files
      ¶
      Source Files
      ¶
    
- doc.go
       Directories
      ¶
      Directories
      ¶
    
    | Path | Synopsis | 
|---|---|
| Package admission contains admission control plugins that work with builds or pods that are running builds. | Package admission contains admission control plugins that work with builds or pods that are running builds. | 
| 
          
            defaults
            
            
          
           Package defaults contains the BuildDefaults admission control plugin. | Package defaults contains the BuildDefaults admission control plugin. | 
| 
          
            overrides
            
            
          
           Package overrides contains the BuildOverrides admission control plugin. | Package overrides contains the BuildOverrides admission control plugin. | 
| Package builder contains builders for STI and Docker in OpenShift Origin | Package builder contains builders for STI and Docker in OpenShift Origin | 
| 
          
            cmd
            
            
          
           Package cmd contains the main entry point for the docker and STI builders | Package cmd contains the main entry point for the docker and STI builders | 
| 
          
            cmd/dockercfg
            
            
          
           Package dockercfg contains a command helper to read .dockercfg files | Package dockercfg contains a command helper to read .dockercfg files | 
| 
          
            cmd/scmauth
            
            
          
           Package scmauth provides SCM authentication methods based on secret files | Package scmauth provides SCM authentication methods based on secret files | 
| Package generator contains the code to generate Build from BuildConfig as well as REST support to help expose the generator from an API. | Package generator contains the code to generate Build from BuildConfig as well as REST support to help expose the generator from an API. | 
| Package reaper implements the Reaper interface for buildConfigs | Package reaper implements the Reaper interface for buildConfigs | 
| Package util contains common functions that are used by the rest of the OpenShift build system. | Package util contains common functions that are used by the rest of the OpenShift build system. | 
| Package webhook contains code for managing and serving webhook services, providing post push events to trigger builds. | Package webhook contains code for managing and serving webhook services, providing post push events to trigger builds. | 
| 
          
            generic
            
            
          
           Package generic contains webhook.Plugin implementation of a generic webhooks for use in testing and/or other ad/hoc usage | Package generic contains webhook.Plugin implementation of a generic webhooks for use in testing and/or other ad/hoc usage | 
| 
          
            github
            
            
          
           Package github contains webhook.Plugin implementation of github webhooks according to https://developer.github.com/webhooks/ | Package github contains webhook.Plugin implementation of github webhooks according to https://developer.github.com/webhooks/ |