Skip to content

Files

Latest commit

 

History

History
87 lines (68 loc) · 3.25 KB

File metadata and controls

87 lines (68 loc) · 3.25 KB

ELUNA 2019 DevDay+: Advanced Development Workshop

Presentation slide show on GoogleDocs

Day 0 Preparation:

Initial setup

  1. Fork this repostory to your Github account
  2. Download and Install Docker Community Edition for your machine platform.
  3. Clone this repository: git clone https://github.com/[myuser]/eluna-2019-devday-advanced-workshop.

Pull Docker images

To speed up the setup of your docker image, you can pull prebuilt versions the images to your computer. This is highly recommended since docker images can take a long time to build, and we cannot guarrantee that these large images will be fast to download in the convention center.

docker pull quay.io/nyulibraries/eluna-2019-devday-advanced-workshop:latest
docker pull quay.io/nyulibraries/eluna-2019-devday-advanced-workshop:e2e

Getting started in Docker

  1. With the Docker daemon running, build the Docker image.
    docker-compose build
  2. Run the container service
    # The 'up' command will deploy any dependent services,
    # and run with the service's ports enabled and mapped to the host.
    docker-compose up web
  3. Navigate to http://localhost:8003/primo-explore/search?vid=NYU to see the basic VIEW up and running!

Making changes using volumes

Notice that in docker-compose.yml there is a volumes section defined for the web service. Here, your local directory is being mounted as a 'volume' to the container at the specified directory:

services:
  web:
    #...
    volumes:
    - ./primo-explore/custom:/app/primo-explore/custom/

The gulp process will therefore dynamically respond to changes in the files in the local filesystem, which are reflected in the container and re-run there. To test that this is working, change some files and watch the page refresh and reflect those changes. For example:

NYU/main.js

app.run(() => {
  console.log('hello from the main.js!');
});

NYU/scss/main.scss

p {
  color: red;
}

Create a Primo frontend package

Now, creating a Primo frontend package is as simple. And Docker containers will help guarrantee that your output is not going to be effected by variations in environment!

VIEW=[VIEW] docker-compose run create-package

For now, the VIEW value can be either NYU or CENTRAL_PACKAGE. You will see the package output in the packages directory as [VIEW].zip.

Other requirements

Install:

  • Node (>= version 8)
  • Node Version Manager for handling multiple versions of Node on your local machine (or, nvm-windows)
  • yarn for node dependency management
  • Google Chrome (latest version)
  • Cypress:
yarn global add cypress
cypress verify
cypress open
  • Create an account at circleci.com using your Github account.

More resources