Chrome недоступен в докерной сети - PullRequest
0 голосов
/ 15 ноября 2018

У меня есть веб-приложение, которое я пытаюсь протестировать в Gitlab-CI с помощью Protractor.

Я использую docker-in-docker в Gitlab-CI для сборки и тестирования приложения.

Все мои сервисы упакованы в Docker (сервер Nginx для размещения статических файлов, API-интерфейс Nodejs, DB Postgresql и обратный прокси-сервер Nginx, «указывающий» на сервер nginx статических файлов и API-интерфейс nodejs).

Вчера при запуске испытаний транспортира все было в порядке. Затем я слил свою ветку git с другой, чтобы добавить новые тесты. В середине процесса слияния я потерял свою конфигурацию обратного прокси-сервера nginx (я удалил ее по ошибке), которую мне пришлось переделать. Я не думаю, что новая конфигурация обратного прокси-сервера является проблемой, но в то же время это единственное, что изменилось. Каждый тест не проходит сейчас с ошибкой:

WebDriverError: chrome not reachable
e2e_1_511616c9d3bd  |       (Session info: headless chrome=68.0.3440.106)
e2e_1_511616c9d3bd  |       (Driver info: chromedriver=2.38 (05121428cd0fc129e40a3694cf5405698236ad14),platform=Linux 4.14.48-coreos-r2 x86_64)
e2e_1_511616c9d3bd  |         at Object.checkLegacyResponse (/usr/lib/node_modules/protractor/node_modules/selenium-webdriver/lib/error.js:546:15)
e2e_1_511616c9d3bd  |         at parseHttpResponse (/usr/lib/node_modules/protractor/node_modules/selenium-webdriver/lib/http.js:509:13)
e2e_1_511616c9d3bd  |         at doSend.then.response (/usr/lib/node_modules/protractor/node_modules/selenium-webdriver/lib/http.js:441:30)
e2e_1_511616c9d3bd  |         at process._tickCallback (internal/process/next_tick.js:68:7)
e2e_1_511616c9d3bd  |     From: Task: Protractor.get(https://reverseproxy.xyz/) - get url
...

В консоли gitlab-ci я вижу, что при запуске тестов браузер делает несколько успешных запросов к API-интерфейсу nodejs.

Моя конфигурация обратного прокси nginx:

worker_processes  auto;

events {
    worker_connections  1024;
}

http {

    upstream docker-web {
        server web:4200;
    }

    upstream docker-api {
        server api:8443;
    }

    proxy_redirect      off;
    proxy_set_header    Host        $host;
    proxy_set_header    X-Real-IP   $remote_addr;
    proxy_ssl_session_reuse off;

    server {

        server_name localhost;

        location / {
            proxy_pass https://docker-web;
        }

        location /api/ {
            proxy_pass https://docker-api/;
        }
        listen 443 ssl;
        listen [::]:443 ssl ipv6only=on;
        ssl_certificate /etc/nginx/proxy.crt;
        ssl_certificate_key /etc/nginx/proxy.key;
        ssl_session_cache shared:le_nginx_SSL:1m;
        ssl_session_timeout 1440m;

        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_prefer_server_ciphers on;

        ssl_ciphers "ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA256:ECDHE-ECDSA-AES128-SHA:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES128-SHA:ECDHE-ECDSA-AES256-SHA384:ECDHE-ECDSA-AES256-SHA:ECDHE-RSA-AES256-SHA:DHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA:DHE-RSA-AES256-SHA256:DHE-RSA-AES256-SHA:ECDHE-ECDSA-DES-CBC3-SHA:ECDHE-RSA-DES-CBC3-SHA:EDH-RSA-DES-CBC3-SHA:AES128-GCM-SHA256:AES256-GCM-SHA384:AES128-SHA256:AES256-SHA256:AES128-SHA:AES256-SHA:DES-CBC3-SHA:!DSS";
    }
}

Мои тесты выполняются в альпийском контейнере со следующим Dockerfile:

FROM alpine:latest

RUN sed -i -e 's/v[[:digit:]]\.[[:digit:]]/edge/g' /etc/apk/repositories
RUN apk upgrade --update-cache --available

RUN apk add npm
RUN npm install -g protractor

# chromium dependencies
RUN apk add openjdk8-jre-base
RUN apk add nss
RUN apk add chromium
RUN apk add chromium-chromedriver
RUN apk upgrade --no-cache --available
ENV CHROME_BIN /usr/bin/chromium-browser

RUN mkdir /e2e
COPY . /e2e
CMD protractor /e2e/ci-conf.js

Это мой ci-conf.js

exports.config = {
  framework: 'jasmine',
  chromeOnly: true,
  directConnect: true,
  specs: ['src/e2e-spec.js'],
  chromeDriver: '/usr/bin/chrome',
  baseUrl: 'https://reverseproxy.xyz', // reverseproxy.xyz is the name of my reverse proxy docker-compose service
  capabilities: {
    browserName: 'chrome',
    acceptInsecureCerts: true, // I'm currently using self-signed certificates in the reverse-proxy
    chromeOptions: {
      args: ['headless','no-sandbox', 'disable-gpu', '--window-size=1920,1080']
    }
  }
}

Мой docker-compose, который я использую для инициализации приложения и запуска тестов:

version: '3.7'

services:
  reverseproxy.xyz:
    image: registry.gitlab.com/projectname/reverseproxy:latest
    depends_on:
      - web
    ports:
      - 443:443
  web:
    image: registry.gitlab.com/projectname/web:42-ci
    depends_on:
      - api
  db:
    image: registry.gitlab.com/projectname/db:42-ci
    volumes:
      - postgres:/var/lib/postgresql/data
  api:
    image: registry.gitlab.com/projectname/api:42-ci
    depends_on:
      - db
  e2e:
    image: e2e:latest
    depends_on:
      - reverseproxy.xyz
volumes:
  postgres:

Мой этап тестирования gitlab-ci:

web_integration_tests:
  stage: test
  script:
    - docker-compose pull
    - docker-compose up -d db
    - docker-compose up -d api
    - docker-compose up -d web
    - docker-compose up -d reverseproxy.xyz
    - sleep 5
    - docker-compose up --exit-code-from 

Пример теста, который я пытаюсь запустить внутри e2e-spec.js:

describe('Be logged in', function() {
  let showAddAccounts = element(by.id('accountIconList'));
  let fbLoginBtn = element(by.id('fbLoginBtn'));

  beforeEach(function() {
    browser.get('');
  });

  it('Should Login in facebook', function() {
    browser.sleep(500);
    showAddAccounts.click();
    fbLoginBtn.isPresent().then((isPresent) => {
      if (isPresent) { // does not appear if already logged in
        fbLoginBtn.click().then( () => {
          browser.waitForAngularEnabled(false);
          browser.getCurrentUrl().then(url => {
            browser.driver.findElement(by.id('email')).sendKeys(test_email);
            browser.driver.findElement(by.id('pass')).sendKeys(test_pass);
            browser.driver.findElement(by.id('loginbutton')).click();
            browser.waitForAngularEnabled(true);
          });
        })
      }
    });
    expect(browser.getCurrentUrl()).toContain(`manage-accounts`);
  });
});

Этот точно такой же тест прошел хорошо 1 день назад.

Я много раз искал эту проблему, и почти все решения указывают на понижение уровня хрома или хромедрайвера. Но так как мои тесты были запущены вчера с точно такими же версиями Chrome и Chromedriver, я не думаю, что это проблема.

Я также пытался использовать другой образ докера для запуска тестов, основанных на растяжке узла 10 с chrome v70.0.3538.67 и chromedriver v2.43.600233, и с той же ошибкой.

Когда я запускаю эти тесты на моей машине с Win10 без использования докера, все тесты становятся зелеными.

Любая помощь будет принята с благодарностью.

1 Ответ

0 голосов
/ 18 ноября 2018

Я нашел решение. Мне пришлось установить размер раздела / dev / shm равным 2 ГБ в моем сервисе docker-compose e2e, используя аргумент shm_size: '2gb'.

...