-
Notifications
You must be signed in to change notification settings - Fork 171
Internal CI Jenkins
Note: CI is only internally accessible. It is not possible, at this time, to access build information externally.
ASC has a Jenkins CI server that runs in a local kubernetes cloud. All of the CI builds are executed inside of docker containers. As of 5.13.19, the CI is running internally, but is not being triggered from Github or pushing build results back to Github.
The CI server run at https://jenkins-dev.wr.usgs.gov
. It can take a minute or so for the server to respond the first time it is accessed. The server login is the standard login that is used for all internal accounts.
The CI project that stores ISIS3 is called docker-testing
.
ISIS3 CI is broken into X different processing steps for each operating system:
- The Jenkins manager launches one or more build containers that are isolated environments.
- The kernel makes a shallow checkout (-depth=50) of the Github repository
- The
environment.yml
file that is in the ISIS3 repository is used to create an environment that is used for the build and testing. - ISIS3 is built. (This takes ~20 minutes with
-j4
. The machines have 4 CPUs.) - ISIS3 tests are executed.
The build containers are all stored on GitHub in the jenkins. The /workers/isisdeps/<os>
directories contain the Dockerfile associated with each operating system. As of 5.13.19, the Ubuntu containers is functioning as desired.
When a container should be updated, we can simply push/merge the change to the jenkins repository. A web hook has already been set up to have the pushed changes built on Docker Hub. The CI will pull the newest version of the container that is available on Docker Hub at the start of each build.
As of 5.16.19: The jenkins repository has been restructured so that each container is located within its own branch. This allows containers to be built individually only when they are modified, rather than all containers being rebuilt when any of them are modified.
The containers all mount the standard path to the ISIS3 test data area. The ISISROOT
is set to the current build directory inside of the checked out repo.
5.13.19 - The web hook is currently a work in progress.
- Building
- Writing Tests
- Test Data
- Start Contributing
- Public Release Process
- Continuous Integration
- Updating Application Documentation
- Deprecating Functionality
- LTS Release Process and Support
- RFC1 - Documentation Delivery
- RFC2 - ISIS3 Release Policy
- RFC3 - SPICE Modularization
- RFC3 - Impact on Application Users
- RFC4 - Migration of ISIS Data to GitHub - Updated Information 2020-03-16
- RFC5 - Remove old LRO LOLA/GRAIL SPK files
- RFC6 - BLOB Redesign
- Introduction to ISIS
- Locating and Ingesting Image Data
- ISIS Cube Format
- Understanding Bit Types
- Core Base and Multiplier
- Special Pixels
- FAQ