Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
Getting started with grouper
Jim Van Fleet
committed
Aug 25, 2016
1 parent
3bf5c8f
commit 40533b3
Showing
8 changed files
with
201 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
# util | ||
|
||
This repository is intended to be downloaded into a container repository during development for convenience purposes. Since the major mechanisms of developing to the Docker container construction lifecycle are identical across container images, this repository allows for consistency and additional ease of use across all container images. | ||
|
||
## Install | ||
|
||
If you are reading this file in BINSCRIPTS.md, your container project is likely to be util-enabled. | ||
|
||
To use these scripts yourself, issue this command: | ||
|
||
``` | ||
curl "https://github.internet2.edu/raw/docker/util/master/bin/install.sh?token=AAAAETsVKUnOEAMM8TvUUZccPYi13wsnks5Xq46jwA%3D%3D" | bash | ||
``` | ||
|
||
### common.bash | ||
|
||
The installation process will create a common.bash file. This file should be the central, canonical authority for management of environment variables. While a subprocess may override them, the files in common.bash should be treated as authoritative defaults. Processes (e.g. `docker build`, `bats`, inside `Jenkinsfile`) can read this file and process the results therein. | ||
|
||
You should edit this file to change the image name, and add any other helpful environment variables. | ||
|
||
### Jenkinsfile | ||
|
||
This will also install a Jenkinsfile to your repository, if it doesn't have one. This will ensure that your Jenkins pipeline can leverage these scripts in the way intended. Ensuring the commands that you issue on your laptop match the commands issued by the build pipeline is critical to ensure predictable, reliable results. | ||
|
||
## Use | ||
|
||
|
||
### Building | ||
|
||
#### build.sh | ||
`bin/build.sh ` | ||
#### destroy.sh | ||
#### rebuild.sh | ||
|
||
### Running | ||
### rerun.sh | ||
### run.sh | ||
|
||
|
||
### Testing | ||
#### test.sh |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
FROM bigfleet/centos7base | ||
|
||
# Define args and set a default value | ||
ARG maintainer=tier | ||
ARG imagename=shibboleth_sp | ||
ARG version=2.3.0 | ||
|
||
MAINTAINER $maintainer | ||
LABEL Vendor="Internet2" | ||
LABEL ImageType="Base" | ||
LABEL ImageName=$imagename | ||
LABEL ImageOS=centos7 | ||
LABEL Version=$version | ||
|
||
LABEL Build docker build --rm --tag $maintainer/$imagename . | ||
|
||
RUN curl -o /etc/yum.repos.d/security:shibboleth.repo \ | ||
http://download.opensuse.org/repositories/security://shibboleth/CentOS_7/security:shibboleth.repo \ | ||
&& yum -y update \ | ||
&& yum -y install \ | ||
dos2unix \ | ||
httpd \ | ||
java-1.8.0-openjdk \ | ||
java-1.8.0-openjdk-devel \ | ||
mlocate \ | ||
mod_ssl \ | ||
shibboleth.x86_64 \ | ||
&& yum clean all \ | ||
&& rm /etc/httpd/conf.d/autoindex.conf \ | ||
&& rm /etc/httpd/conf.d/ssl.conf \ | ||
&& rm /etc/httpd/conf.d/userdir.conf \ | ||
&& rm /etc/httpd/conf.d/welcome.conf \ | ||
&& mkdir -p /opt/grouper \ | ||
&& curl -o /opt/grouper/grouperInstaller.jar http://software.internet2.edu/grouper/release/$version/grouperInstaller.jar | ||
|
||
COPY httpd-shib-foreground /usr/local/bin/ | ||
|
||
EXPOSE 80 443 | ||
CMD ["httpd-shib-foreground"] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
node('docker') { | ||
|
||
stage 'Checkout' | ||
|
||
checkout scm | ||
|
||
stage 'Acquire util' | ||
|
||
sh 'mkdir -p tmp' | ||
dir('tmp'){ | ||
git([ url: "https://github.internet2.edu/docker/util.git", | ||
credentialsId: "jenkins-github-access-token" ]) | ||
sh 'ls' | ||
sh 'mv bin/* ../bin/.' | ||
} | ||
stage 'Environment' | ||
|
||
def maintainer = maintainer() | ||
def imagename = imagename() | ||
def tag = env.BRANCH_NAME | ||
if(!imagename){ | ||
echo "You must define an imagename in common.bash" | ||
currentBuild.result = 'FAILURE' | ||
} | ||
if(maintainer){ | ||
echo "Building ${maintainer}:${tag} for ${maintainer}" | ||
} | ||
|
||
stage 'Build' | ||
try{ | ||
sh 'bin/build.sh &> debug' | ||
} catch(error) { | ||
def error_details = readFile('./debug'); | ||
def message = "BUILD ERROR: There was a problem building the Base Image. \n\n ${error_details}" | ||
sh "rm -f ./debug" | ||
handleError(message) | ||
} | ||
stage 'Start container' | ||
|
||
sh 'bin/ci-run.sh' | ||
|
||
stage 'Tests' | ||
|
||
sh 'bin/test.sh' | ||
// should build a finally construct here | ||
stage 'Stop container' | ||
|
||
sh 'bin/ci-stop.sh' | ||
|
||
stage 'Push' | ||
docker.withRegistry('https://registry.hub.docker.com/', "dockerhub-$maintainer") { | ||
def baseImg = docker.build("$maintainer/$imagename") | ||
baseImg.push("$tag") | ||
} | ||
|
||
|
||
} | ||
|
||
def maintainer() { | ||
def matcher = readFile('common.bash') =~ 'maintainer="(.+)"' | ||
matcher ? matcher[0][1] : 'tier' | ||
} | ||
|
||
def imagename() { | ||
def matcher = readFile('common.bash') =~ 'imagename="(.+)"' | ||
matcher ? matcher[0][1] : null | ||
} | ||
|
||
def handleError(String message){ | ||
echo "${message}" | ||
currentBuild.setResult("FAILED") | ||
slackSend color: 'danger', message: "${message}" | ||
sh 'exit 1' | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
#!/bin/bash | ||
|
||
# This file will run a container in the background | ||
source common.bash . | ||
|
||
docker run -d --name=$imagename -p 80:80 -p 443:443 $maintainer/$imagename |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
#!/bin/bash | ||
|
||
# This file will run a container in the background | ||
source common.bash . | ||
|
||
echo "Cleaning up Docker image($maintainer/$imagename)" | ||
docker stop $imagename >> /dev/null | ||
docker rm $imagename |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
maintainer="bigfleet" | ||
imagename="grouper" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
#!/usr/bin/env bats | ||
|
||
load ../common | ||
|
||
@test "Shibd binary available" { | ||
docker run -i $maintainer/$imagename find /usr/sbin/shibd | ||
} | ||
|
||
@test "Shibboleth root available" { | ||
docker run -i $maintainer/$imagename find /etc/shibboleth | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
#!/usr/bin/env bats | ||
|
||
load ../common | ||
|
||
# These tests assume the pipeline will start and stop the container. | ||
|
||
@test "Leaves running process" { | ||
result="$(docker ps | grep $imagename)" | ||
[ "$result" != '' ] | ||
} | ||
|
||
@test "Exposes running HTTP service" { | ||
result="$(docker exec -i $imagename curl http://localhost/)" | ||
[ "$result" != '' ] | ||
} | ||
|
||
@test "Exposes running SSO process" { | ||
result="$(docker exec -i $imagename curl http://localhost/Shibboleth.sso/Status)" | ||
[ "$result" != '' ] | ||
} |