-
Notifications
You must be signed in to change notification settings - Fork 74
Hootenanny Release Process
- C2S Account and AWS Keys
- Smoke Test Documentation
- Jenkins Account
- .gpu data
- OSM account
- software packages: make, docker, vagrant, git
The release process conducts RPM installs of the Hootenanny source code on a EC2 instance. Therefore, the user installing the RPMs will need a C2S account with EC2 and S3 privileges. A C2S account for unclassified and classified (govcloud) can be provided by Tim O'leary and AWS keys are generated using gimme-aws-creds.
The steps to perform the smoke test are documented in a shared word document. That file can be found here
Jenkins is the CI/CD tool used to run checks and validations against changes to source code. An account is needed on the unclassified Jenkins instance and the classified Jenkins instance in govcloud. A POC for obtaining a Jenkins account is Seth Putnam. In order to see the Jenkins landing page, the user's public IP must be whitelisted in the security group attach to each instance.
The .gpu data enables the user to sign the built RPMs. This data isn't stored anywhere publicly for security reasons and shared among co-works. A POC for the .gpu data is Seth Putname or Justin Bronn.
Hootenanny oauth authenticates a user account from OSM to access Hootenanny and perform the smoke test. To create a user account go here.
The are a number of jenkins jobs that must have succeed before building the RPMs. The Jobs are listed below, and if any show a failure alert the nome-ui, hootenanny, and/or hoot-core team via slack.
unclassified Jenkins Instance
Hootenanny
Hootenanny-rpms
Hootenanny-ui
hootenanny_valgrind
classified Jenkins Instance
hoot-tests
- Confirm with Hootenanny team that the source code master branch is in a good state to cut a release tag
- Check that the Jenkins jobs have successfully passed
- After confirming Jenkins jobs passed cut a tag from the master branch. Use this as a template to fill out the tag data. Before clicking publish release, toggle the check box that this tag is a pre-release.
- Build the RPMs. Documentation on how to do so can be found here. Go up to step 4 on this page. If issues occur when building the RPMs reach out to Seth Putnam or Justin Bronn
- Create an EC2 instance (shown below)
- Provision the instance to install the built RPMs (shown below)
- Install the RPMs on the EC2 instance
yum -y install hootenanny-autostart
- Update Tomcat8 hoot-services.conf file installed from the RPMs
sed -i 's,oauthRedirectURL=http://localhost:8080/login.html,oauthRedirectURL=http://[EC2 public ip]:8080/hootenanny-id/login.html,' /var/lib/tomcat8/webapps/hoot-services/WEB-INF/classes/conf/hoot-services.conf
- Restart the Tomcat service
systemctl restart tomcat8
- Go to the hootenanny landing page and confirm you can login using OSM credentials
http://[EC2 public ip]:8080/hootenanny-id/login.html
- Perform the smoke test using the documentation and alert the hootenanny team of success or failures
- After smoke test passes continue on the RPM build documentation at step 5. Note: signing RPMs require a password shared among co-workers. That password can be obtained by Seth Putnam.
- Inform Hootenanny team the RPMs have been signed and uploaded to S3
- Upload the hootenanny source tar to the release page on github. The tar is generated from step 2 in the RPM build documentation
- Edit the release page, toggle that it's not a pre-release and click 'publish release'
- log into C2S
- select EC2 microservice
- click 'Launch Instance'
- select AMI 'ami-06cf02a98a61f9f5e' under the Community AMIs tab
- select instance size m5.2xlarge
- select network 'nome-dev' then click 'Next: add storage'
- change Size (GiB) to 40 then click 'Next: add tags'
- add tags (Name: hootenanny-release-candidate-[version], user: [person doing smoke test], env: testing, group: hootenanny) then click 'Next: Configure Security Group'
- select security group that grants access to user doing the smoke test and person provisioning the EC2 instance then click 'Review and Launch'
- review instance details and after confirming the correct details click 'Launch'
- select a ssh key the user that provisions the EC2 instance holds then click 'launch instance'
- ssh to the created EC2 instance
ssh -i [key] centos@[public ip address]
- run the following commands in order
sudo su
yum -y install epel-release & yum -y update
yum -y install createrepo vim wget
cd /etc/yum.repos.d/
wget https://hoot-repo.s3.amazonaws.com/el7/pgdg95.repo
wget https://hoot-repo.s3.amazonaws.com/el7/deps/release/hoot-deps.repo
cat <<EOF > hoot.repo
[hoot]
name = Hootenanny RPMs
baseurl = file:///usr/src/hoot
enabled = 1
gpgcheck = 0
EOF
mkdir /usr/src/hoot/
- locally scp built rpms to the EC2 instance
scp -i [key] centos@[public ip address]:/tmp/
- on the EC2 machine move the built rpms to the /usr/src/hoot directory
sudo mv /tmp/hoot*.rpm /usr/src/hoot/
- create the repository metadata
cd /usr/src/hoot && createrepo .
- run the following commands and confirm the hootenanny-autostart package is found
yum clean all
yum makecache
yum info hootenanny-autostart