mirror of https://github.com/jacekkow/keycloak-protocol-cas

Matthias Piepkorn
2018-09-08 9532f1b237bbd5f74f6a4ef137dbdcbd1c58d0ba
add travis script to check for Keycloak updates + PR them automatically
1 files added
1 files modified
82 ■■■■ changed files
.travis.yml 29 ●●●●● patch | view | raw | blame | history
update.sh 53 ●●●●● patch | view | raw | blame | history
.travis.yml
@@ -16,21 +16,24 @@
  - KEYCLOAK_VERSION=4.1.0.Final
before_install:
  - docker pull jboss/keycloak:$KEYCLOAK_VERSION
  - if [ "$TRAVIS_EVENT_TYPE" != "cron" ]; then docker pull jboss/keycloak:$KEYCLOAK_VERSION; fi
script:
  - mvn test package -B &&
    mkdir target/docker &&
    cp target/*.jar target/docker/keycloak-protocol-cas.jar &&
    echo "FROM jboss/keycloak:$KEYCLOAK_VERSION" > target/docker/Dockerfile &&
    echo "ADD keycloak-protocol-cas.jar /opt/jboss/keycloak/standalone/deployments/" >> target/docker/Dockerfile &&
    cd target/docker && docker build -t doccrazy/keycloak-cas . && cd ../.. &&
    docker run -d -p 127.0.0.1:8080:8080 --name keycloak -e KEYCLOAK_USER=admin -e KEYCLOAK_PASSWORD=admin doccrazy/keycloak-cas && sleep 30 &&
    docker logs keycloak &&
    docker exec -t keycloak /opt/jboss/keycloak/bin/kcadm.sh config credentials --server http://localhost:8080/auth --realm master --user admin --password admin &&
    docker exec -t keycloak /opt/jboss/keycloak/bin/kcadm.sh create clients -r master -s clientId=test -s protocol=cas -s enabled=true -s publicClient=true -s 'redirectUris=["http://localhost/*"]' -s baseUrl=http://localhost -s adminUrl=http://localhost &&
    docker exec -t keycloak /opt/jboss/keycloak/bin/kcadm.sh get serverinfo -r master --fields "providers(login-protocol(providers(cas)))" | grep cas &&
    integrationTest/suite.sh
  - if [ "$TRAVIS_EVENT_TYPE" != "cron" ]; then
      mvn test package -B &&
      mkdir target/docker &&
      cp target/*.jar target/docker/keycloak-protocol-cas.jar &&
      echo "FROM jboss/keycloak:$KEYCLOAK_VERSION" > target/docker/Dockerfile &&
      echo "ADD keycloak-protocol-cas.jar /opt/jboss/keycloak/standalone/deployments/" >> target/docker/Dockerfile &&
      cd target/docker && docker build -t doccrazy/keycloak-cas . && cd ../.. &&
      docker run -d -p 127.0.0.1:8080:8080 --name keycloak -e KEYCLOAK_USER=admin -e KEYCLOAK_PASSWORD=admin doccrazy/keycloak-cas && sleep 30 &&
      docker logs keycloak &&
      docker exec -t keycloak /opt/jboss/keycloak/bin/kcadm.sh config credentials --server http://localhost:8080/auth --realm master --user admin --password admin &&
      docker exec -t keycloak /opt/jboss/keycloak/bin/kcadm.sh create clients -r master -s clientId=test -s protocol=cas -s enabled=true -s publicClient=true -s 'redirectUris=["http://localhost/*"]' -s baseUrl=http://localhost -s adminUrl=http://localhost &&
      docker exec -t keycloak /opt/jboss/keycloak/bin/kcadm.sh get serverinfo -r master --fields "providers(login-protocol(providers(cas)))" | grep cas &&
      integrationTest/suite.sh
    ; fi
  - if [ "$TRAVIS_EVENT_TYPE" = "cron" ]; then ./update.sh; fi
before_deploy:
  - "mvn -DskipTests package"
update.sh
New file
@@ -0,0 +1,53 @@
#!/bin/bash
set -e
function docker_tag_exists() {
    TOKEN=$(curl --silent -f "https://auth.docker.io/token?service=registry.docker.io&scope=repository:$1:pull" | sed 's/.*"token":"\([^"]*\)".*/\1/')
    REGISTRY_URL="https://registry-1.docker.io/v2/$1/manifests/$2"
    curl -fsSLI -H "Authorization: Bearer $TOKEN" "$REGISTRY_URL" > /dev/null
}
setup_git() {
    git config --global user.email "updater@travis-ci.org"
    git config --global user.name "Updater Bot"
    git remote add origin-auth https://${GH_TOKEN}@github.com/${TRAVIS_REPO_SLUG}.git > /dev/null 2>&1
}
pull_request() {
    curl -fsSL -H "Authorization: token ${GH_TOKEN}" -X POST -d "{\"head\":\"$1\",\"base\":\"master\",\"title\":\"$2\",\"body\":\"$3\"}" "https://api.github.com/repos/${TRAVIS_REPO_SLUG}/pulls"
}
KEYCLOAK_VERSION=$(mvn versions:display-property-updates -DincludeProperties=keycloak.version | grep "keycloak.version" | sed -n "s/.*->\s*\(.*\)\.Final$/\1/p")
KEYCLOAK_VERSION_FULL=$KEYCLOAK_VERSION.Final
if [ -z "$KEYCLOAK_VERSION" ]; then
    echo "No Keycloak update found."
    exit
fi
echo "Keycloak version $KEYCLOAK_VERSION available; updating..."
BRANCH=feature/keycloak-update-$KEYCLOAK_VERSION
if git ls-remote -q --exit-code origin $BRANCH; then
    echo "Branch $BRANCH already exists."
    exit
fi
if ! docker_tag_exists jboss/keycloak $KEYCLOAK_VERSION_FULL; then
    echo "Docker image for Keycloak $KEYCLOAK_VERSION_FULL not found, not updating."
    exit
fi
echo "Found updated docker image, proceeding"
mvn versions:set -DnewVersion=$KEYCLOAK_VERSION -DgenerateBackupPoms=false
sed -i "s/KEYCLOAK_VERSION=.*/KEYCLOAK_VERSION=$KEYCLOAK_VERSION_FULL/" .travis.yml
setup_git
git checkout -b $BRANCH
git add pom.xml .travis.yml
git commit -m "Update to Keycloak $KEYCLOAK_VERSION_FULL"
git push --quiet --set-upstream origin-auth $BRANCH
PR_TITLE="Update to Keycloak $KEYCLOAK_VERSION_FULL"
PR_BODY="Updates Keycloak dependency, CI test image and project version for Keycloak release $KEYCLOAK_VERSION_FULL\\n\\n*(automated pull request after upstream release)*"
pull_request $BRANCH "$PR_TITLE" "$PR_BODY"
echo "Created pull request '$PR_TITLE'"