CircleCI Swift с проблемами подключения Postgres - PullRequest
0 голосов
/ 09 апреля 2019

Я работаю с моим репо , чтобы создать тестовое приложение для swift с circleCI и postgres, но когда дело доходит до тестирования, я не могу понять, как соединить два изображения на этапе тестирования.

Я работаю

circleci local execute --job build

, который должен создавать изображения как swift, так и postgres.Я даю им одинаковые переменные env, указанные в приложении.Однако я получаю эту ошибку при попытке запустить его.По моему опыту, при попытке настроить два Docker-контейнера с помощью compose эта ошибка обнаруживалась, когда моему API не удалось подключиться к контейнеру db по сети.

Test Case 'AppTests.RemoveUserTest' started at 2019-04-09 19:46:15.380
Fatal error: 'try!' expression unexpectedly raised an error: NIO.ChannelError.connectFailed(NIO.NIOConnectionError(host: "db", port: 5432, dnsAError: Optional(NIO.SocketAddressError.unknown(host: "db", port: 5432)), dnsAAAAError: Optional(NIO.SocketAddressError.unknown(host: "db", port: 5432)), connectionErrors: [])): file /home/buildnode/jenkins/workspace/oss-swift-4.2-package-linux-ubuntu-16_04/swift/stdlib/public/core/ErrorType.swift, line 184

Я знаю, что это говорит о сбое из-заоператор try, но этот оператор try не выполняется, поскольку он запрашивает действия у Postgres, которого там нет.Есть идеи?

Мой текущий config.yml для circleci

version: 2

jobs:
  build:
    docker:
      - image: swift:4.2
        environment:
          POSTGRES_USER: test
          POSTGRES_PASSWORD: test
          POSTGRES_DB: test
          DB_HOSTNAME: db
          PORT: 5432
      - image: postgres:11.2-alpine
        environment:
          POSTGRES_USER: test
          POSTGRES_PASSWORD: test
          POSTGRES_DB: test
    steps:
      - checkout
      - run: apt-get update -qq
      - run: apt-get install -yq libssl-dev pkg-config wget
      - run: apt-get install -y postgresql-client || true
      - run:
          name: install dockerize
          command: wget https://github.com/jwilder/dockerize/releases/download/$DOCKERIZE_VERSION/dockerize-linux-amd64-$DOCKERIZE_VERSION.tar.gz && tar -C /usr/local/bin -xzvf dockerize-linux-amd64-$DOCKERIZE_VERSION.tar.gz && rm dockerize-linux-amd64-$DOCKERIZE_VERSION.tar.gz
          environment:
            DOCKERIZE_VERSION: v0.3.0
      - run:
          name: Wait for db
          command: dockerize -wait tcp://localhost:5432 -timeout 1m
      - run: 
          name: Compile code
          command: swift build
      - run: 
          name: Run unit tests
          command: swift test

  release:
    docker:
      - image: swift:4.2
    steps:
      - checkout
      - run: 
          name: Compile code with optimizations
          command: swift build -c release
  push-to-docker-hub:
    docker:
      - image: docker:latest
    steps:
      - checkout
      - setup_remote_docker
      - run:
          name: Install dependencies
          command: |
            apk add --update --no-cache curl jq python py-pip
      - run:
          name: Build Docker Image
          command: |
            docker build -t api .
            docker tag api <>/repo:latest
            docker tag api <>/repo:$CIRCLE_SHA1
            docker login -u $DOCKER_USER -p $DOCKER_PASS
            docker push <>/repo:latest
            docker push <>/repo:$CIRCLE_SHA1
#      - persist_to_workspace:
#          root: ./
#          paths:
#            - k8s-*.yml

workflows:
  version: 2
  tests:
    jobs:
      - build
      - push-to-docker-hub:
          requires:
            - build
          context: dockerhub
          filters:
            branches:
              only: master
      #- linux-release

1 Ответ

1 голос
/ 10 апреля 2019

Вы устанавливаете имя хоста для базы данных на db, но нигде не определяете это.Вам необходимо присвоить контейнеру Docker имя, соответствующее переменной окружения DB_HOSTNAME, например https://github.com/vapor/postgresql/blob/master/circle.yml#L8

...