version: 2.1 jobs: Installation: docker: - image: circleci/node:12.9-browsers steps: - checkout - restore_cache: keys: - yarn-packages-{{ checksum "yarn.lock" }}-{{ .Environment.CACHE_VERSION }} - yarn-packages - run: yarn global add node-gyp && yarn install - save_cache: key: yarn-packages-{{ checksum "yarn.lock" }}-{{ .Environment.CACHE_VERSION }} paths: - node_modules Test: docker: - image: circleci/node:12.9-browsers steps: - checkout - restore_cache: keys: - yarn-packages-{{ checksum "yarn.lock" }}-{{ .Environment.CACHE_VERSION }} - run: name: Test command: yarn test Build : docker: - image: circleci/node:12.9-browsers steps: - checkout - restore_cache: keys: - yarn-packages-{{ checksum "yarn.lock" }}-{{ .Environment.CACHE_VERSION }} - run: name: Build command : yarn run build - run: name: Copy to worspace command: | cp dist/ /tmp/dist -r - store_artifacts: path: /tmp/dist - persist_to_workspace: root: /tmp paths: - dist Netlify: docker: - image: circleci/node:12.9-browsers working_directory: ~/netlfify steps: - attach_workspace: at: /tmp - run: name: Deploy on Netlify command: | sudo npm install -g --silent netlify-cli netlify deploy --prod --auth $NETLIFY_AUTH_TOKEN --dir=/tmp/dist --site $NETLIFY_SITE_ID Docker: working_directory: /dockerapp docker: - image: circleci/buildpack-deps:stretch steps: - checkout - setup_remote_docker - run: name: Dockerize the app command: | docker build --cache-from=app -t app . - run: name: Publish app to docker hub command: | docker login -u $DOCKER_HUB_USERNAME -p $DOCKER_HUB_PASSWORD docker tag app $DOCKER_HUB_USERNAME/tp-devops-front:$CIRCLE_BUILD_NUM docker tag app $DOCKER_HUB_USERNAME/tp-devops-front:latest docker push $DOCKER_HUB_USERNAME/tp-devops-front:$CIRCLE_BUILD_NUM docker push $DOCKER_HUB_USERNAME/tp-devops-front:latest workflows: Build_Test_N_Deploy_FRONT: jobs: - Installation - Test - Build : requires: - Installation - Netlify: context: Netlify requires: - Build - Docker: context: Docker requires: - Build