Подключение к службе из задания Gitlab CI - PullRequest
1 голос
/ 18 июня 2020

Я пытаюсь запустить тесты e2e в gitlab ci, которые используют фронтенд React, Java бэкэнд * Spring и PostgreSQL.

Соответствующие части .gitlab-ci -config следующие:

variables:
  IMAGE_NAME: $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
  FF_NETWORK_PER_BUILD: 1

docker-backend-build:
  image: docker:latest
  services:
    - docker:dind
  stage: package
  dependencies:
    - backend-build
  script:
  - docker build -t registry.gitlab.com/repo-name .
  - docker tag registry.gitlab.com/repo-name $IMAGE_NAME
  - docker login -u gitlab-ci-token -p $CI_BUILD_TOKEN registry.gitlab.com
  - docker push $IMAGE_NAME

end-to-end-test:
  stage: integration-test
  image: node:latest
  services:
    - name: postgres:9.6
    - name: $IMAGE_NAME
      alias: backend
  variables:
    DB_USERNAME: postgres
    DB_PASSWORD: postgres
    JDBC_CONNECTION_STRING: 'jdbc:postgresql://postgres:5432/database?stringtype=unspecified'
  dependencies:
    - frontend-build
  script:
    - cd frontend
    - yarn start:ci & ./node_modules/wait-on/bin/wait-on http://backend:9070/api/health http://localhost:3000
    - yarn run cy:run
  artifacts:
    when: always
    paths:
      - frontend/cypress/videos/*.mp4
      - frontend/cypress/screenshots/**/*.png
    expire_in: 1 day

Dockerfile для бэкэнда выглядит следующим образом:

FROM tomcat:latest
ADD backend/target/server.war /usr/local/tomcat/webapps/
RUN sed -i 's/port="8080"/port="9070"/' /usr/local/tomcat/conf/server.xml
EXPOSE 9070
CMD ["catalina.sh", "run"]

server.war создается на более ранней стадии в конвейере CI.

server.war настроен на прослушивание порта 9070, и Dockerfile также успешно изменяет порт Tomcat на 9070. Экземпляр Tomcat может подключиться к экземпляру postgres через postgres:5432 из-за флага FF_NETWORK_PER_BUILD, но по какой-то причине этот скрипт навсегда зависает от команды wait-on http://backend:9070/api/health. Он не может подключиться к backend: 9070, даже если сервер включен и работает. (и конечная точка работоспособности существует). Сервер не получает никаких указаний на то, что он пытается подключиться.

Что я делаю не так? Я также пытался подключиться к http://localhost:9070/api/health, но это тоже не помогло.

1 Ответ

0 голосов
/ 23 июля 2020

Ответом для меня было просто изменить Dockerfile следующим образом:

- ADD backend/target/server.war /usr/local/tomcat/webapps/
+ ADD backend/target/server.war /usr/local/tomcat/webapps/ROOT.war

, потому что без этого сервер фактически прослушивал http://backend:9070/api/health/server. Глупый я.

...