-
Notifications
You must be signed in to change notification settings - Fork 3
Scholar@UC App Workflow
-
Clone the ucrate repo
git clone [email protected]:uclibs/ucrate.git
cd ucrate
-
Create a new feature branch based on the develop branch
git checkout develop
git pull
git checkout -b feature/#issuenum-branch-name
-
Run bundler. (if bundler fails with mysql errors, comment out
gem 'mysql2'
in the Gemfile and run bundler again)bundle install
-
Start Solr and Fedora.
-
Run the database migrations.
bundle exec rake db:migrate
-
Start the rails server.
rails server
-
Make sure the app is up and running.
http://localhost:3000 -
Make your changes.
-
Commit your changes to local Git repository.
-
Run spec tests locally. Make sure they all pass.
bundle exec rake spec
-
Push changes to remote feature branch.
git push origin feature/#issuenum-branch-name
-
On github.com, open a new pull request for your feature branch.
-
Make sure CircleCI passes.
-
After someone else has merged the pull request, delete the feature branch. Do not merge your own pull requests.
-
Close the resolved issue.
-
Deploy to Development: (Scholar@UC-Environment-Deployment-Procedure)
-
Create a release branch based on the develop branch.
git checkout -b release
-
Make any changes and commits needed.
-
Push the release branch to GitHub
git push origin release
-
[Deploy to QA server] https://git.uc.edu/UCLIBS/private_documentation/blob/master/Capistrano_Deploy.md
-
Complete the Change Management Form.
-
If a security scan is needed wipe content, create a scanning account, and request a scan
-
Run through the manual test script on the QA or dev server
-
Update the CHANGELOG.md with changes for this release
-
Merge the release branch into the master branch AND the develop branch.
git checkout release
git pull
git checkout master
git pull
git merge release
git checkout develop
git pull
git merge release
-
Push the master and develop branches to GitHub
git checkout develop
git push origin develop
git checkout master
git push origin master
-
In the master branch, tag a new release in Git and push it to the remote
git checkout master
ex.git tag -a v1.4.0 -m '10-01-2014'
git push --tags
-
[Deploy to production server] (Scholar@UC-App-Deployment-Procedures) (after change request has been approved)
-
Make any needed changes to the server environment (cron jobs, etc.)
-
Post announcement to ScholarBlog
-
Delete the local and remote release branches.
git branch -d release
git push origin :release
-
The person that submitted the change request should provide an outcome on the change management website.