- Prerequisites
- Quick Start Guide
- Docker Development Setup
- Install Camerata
- Update Camerata
- General Use
- Troubleshooting
- Pulling or Building Docker Images
- When Installing a New Gem
- Deploy an individual branch
- Test coverage
This is one of the microservices applications that form the Yale digital library.
- Download Docker Desktop and log in
- To start the application without VPN and without management:
git clone [email protected]:yalelibrary/yul-dc-camerata.git
cd yul-dc-camerata
bundle install
rake install
cd back into your main directory.
git clone [email protected]:yalelibrary/yul-dc-blacklight.git
cd yul-dc-blacklight
cam build
VPN=false cam up blacklight --without management
access at localhost:3000
If you get a bundle gem issue, open a new terminal window or tab and with the running blacklight server, run:
cam bundle blacklight
- To bash into containers and run specs:
With the application already started:
cam sh blacklight
bundle exec rspec spec/file/path
git clone https://github.com/yalelibrary/yul-dc-blacklight.git
cd ./yul-dc-blacklight
touch .secrets
If this is your first time working in this repo or the Dockerfile has been updated you will need to pull your services
docker-compose pull blacklight
Clone the yul-dc-camerata repo and install the gem.
git clone [email protected]:yalelibrary/yul-dc-camerata.git
cd yul-dc-camerata
bundle install
rake install
- You can get the latest version at any point by updating the code and reinstalling
cd yul-dc-camerata
git pull origin main
bundle install
rake install
- We've integrated Dynatrace OneAgent for monitoring our Docker container environments.
- Instructions on configuring OneAgent can be found here
Once camerata is installed on your system, interactions happen through the camerata command-line tool or through its alias cam
. The camerata tool can be used to bring the development stack up and down locally, interact with the docker containers, deploy, run the smoke tests and otherwise do development tasks common to the various applications in the yul-dc application stack.
All buildin commands can be listed with cam help
and individual usage information is available with cam help COMMAND
. Please note that deployment commands (found in the ./bin
directory) are passed through and are therefore not listed by the help command. See the usage for those below.
To start the application stack, run cam up
in the blacklight directory. This starts all of the applications as they are all dependencies of yul-blacklight. Camerata is smart. If you start cam up
from a blacklight code check out it will mount that code for local development (changes to the outside code will affect the inside container). If you start the cam up
from the blacklight application you will get the blacklight code mounted for local development and the blacklight code will run as it is in the downloaded image. You can also start the two applications both mounted for development by starting the blacklight application with --without management
and the managment application --without solr --withouth db
each from their respective code checkouts.
-
Access the blacklight app at
http://localhost:3000
-
Access the solr instance at
http://localhost:8983
-
Access the image instance at
http://localhost:8182
-
Access the manifests instance at
http://localhost
-
Access the management app at
http://localhost:3001/management
- If you cannot access this url, try the troubleshooting steps
- See the wiki for further information on troubleshooting.
-
In a separate terminal window or tab than the running blacklight server, run:
cam bundle blacklight
- See the wiki for further information on containers.
- See the wiki for information on indexing data.
Any time you pull a branch with a Gemfile change you need to pull or build a new Docker image. If you change the Dockerfile, you need to build a new Docker image. If you change a file in ./ops you need to build a new Docker image. These are the primary times in which you need to pull or build.
For the most part images are created and maintained by the CI process. However, if you change the Gemfile you need to take a few extra steps. Make sure the application is running before you make your Gemfile change. Once you've updated the Gemfile, inside the container, run bundle && nginx -s reload
. The next time you stop your running containers you need to rebuild.
In order to prevent search engine crawling of the system before it's ready to launch, we use HTTP password protection. This is set via environment variables. Set HTTP_PASSWORD_PROTECT='true'
to enable this feature. Set HTTP_PASSWORD_PROTECT='false'
to disable this feature. Set the log in and password via environment variables HTTP_USERNAME
and HTTP_PASSWORD
in the .secrets file
For the image instance to properly access images, you must also create a .secrets file with valid S3 credentials and basic auth credentials; see secrets-template for the correct format.
Refer to the steps in the Camerata repo
Refer to the steps in the Camerata repo
-
Go to the yul-dc-camerata repository on Github and check the latest release number in the .env file.
-
Edit your .env file to match
-
Run
docker-compose up blacklight
Integration tests run without styling by default. This allows for more stable tests involving Capybara and loads the pages faster.
If styling is needed for a test to pass, tag the test with style:true
We use simplecov to measure test coverage. More details here.
By default, when running locally, your IP will not be considered "On Campus," so you will not be able to view Yale Community Only items unless you log in.
To test having an IP which is considered "On Campus" so that you can view Yale Community Only items without logging in, start with YALE_NETWORK_IPS=10.0.0.0/8,172.16.0.0/12,192.168.0.0/16,127.0.0.1 cam up
.