GitLab Shell Runner. Docker Compose-rekin proba-zerbitzuak lehiakor exekutatzen dira

GitLab Shell Runner. Docker Compose-rekin proba-zerbitzuak lehiakor exekutatzen dira

Artikulu hau probatzaileentzat zein garatzaileentzat interesgarria izango da, baina gehiago zuzenduta dago GitLab CI/CD integrazio-probak egiteko azpiegitura baliabide nahikorik ezaren aurrean eta/edo edukiontzi-orkestraziorik ezaren aurrean GitLab CI/CD konfiguratzeko arazoa duten automatikoentzat. plataforma. Docker compose erabiliz proba-inguruneen hedapena nola konfiguratu esango dizut GitLab shell runner bakarrean eta, horrela, hainbat ingurune zabaltzean, abiarazitako zerbitzuek elkarren artean oztopatu ez dezaten.


Edukia

ezinbesteko baldintza

  1. Nire praktikan, askotan proiektuetan integrazio-probak "tratatzea" gertatzen zen. Eta askotan lehen eta esanguratsuena CI kanalizazioa da, zeinetan integrazio probak egiten dituena garatu zerbitzua(k) garapen/etapa ingurunean dago. Horrek arazo dezente sortu zituen:

    • Integrazio-probetan zerbitzu batean edo bestean akatsen ondorioz, proba-zirkuitua hautsitako datuek hondatu dezakete. JSON formatua hautsitako eskaera bat bidaltzeak zerbitzua zintzilikatzeko kasuak izan ziren, eta horrek stand-a guztiz ez funtzionatzen zuen.
    • Proba-zirkuituaren moteltzea proba-datuen hazkundearekin. Uste dut ez duela zentzurik datu-basea garbitu / atzera botatzeko adibide bat deskribatzeak. Nire praktikan, ez dut ezagutu prozedura hau ondo joango zen proiekturik.
    • Sistemaren ezarpen orokorrak probatzean proba-zirkuituaren errendimendua eteteko arriskua. Adibidez, erabiltzailea/taldea/pasahitza/aplikazio-politika.
    • Autotesten probetako datuek bizitza zailtzen diete eskuzko probatzaileei.

    Norbaitek esango du autotest onek datuak garbitu behar dituztela beren ondoren. Aurkako argudioak ditut:

    • Harmaila dinamikoak erabiltzeko oso erosoak dira.
    • Objektu guztiak ezin dira sistematik kendu APIaren bidez. Adibidez, objektu bat ezabatzeko deia ez da inplementatzen, negozioaren logikarekin kontraesanean dagoelako.
    • APIaren bidez objektu bat sortzean, kentzeko arazoak diren metadatu kopuru handi bat sor daiteke.
    • Probak elkarren menpekoak badira, probak egin ostean datuak garbitzeko prozesua buruhauste bihurtzen da.
    • APIrako dei osagarriak (eta, nire ustez, justifikatuak ez direnak).
    • Eta argudio nagusia: probako datuak datu-basetik zuzenean garbitzen hasten direnean. Hau benetako PK/FK zirku bat bihurtzen ari da! Garatzaileei entzuten diegu: "Gehitu/ezabatu/izendatu berri dut seinalea, zergatik erori ziren 100500 integrazio-proba?"

    Nire ustez, irtenbiderik egokiena ingurune dinamikoa da.

  2. Jende askok docker-compose erabiltzen du proba-ingurune bat exekutatzeko, baina jende gutxik erabiltzen du docker-compose CI/CD-n integrazio-probak egiterakoan. Eta hemen ez ditut kontuan hartzen kubernetak, swarm eta bestelako edukiontzien orkestrazio plataformak. Enpresa guztiek ez dituzte horiek. Polita litzateke docker-compose.yml unibertsala balitz.
  3. Gure QA korrikalaria badugu ere, nola ziurtatu docker-compose bidez abiarazitako zerbitzuak elkarren artean oztopatzen ez dutela?
  4. Nola bildu probatutako zerbitzuen erregistroak?
  5. Nola garbitu korrikalaria?

Nire GitLab korrikalaria daukat nire proiektuetarako eta arazo hauekin topo egin nuen garatzen ari nintzen bitartean Java bezeroa egiteko probako erraila. Zehazkiago, integrazio-probak exekutatzen direnean. Hemen arazo hauek konpontzen jarraituko dugu proiektu honetako adibideekin.

Edukira

GitLab Shell Runner

Korrikalari batentzat, Linux makina birtual bat gomendatzen dut 4 vCPU, 4 GB RAM, 50 GB HDD dituena.
Interneten gitlab-runner konfiguratzeko informazio asko dago, beraz, laburbilduz:

  • SSH bidez makinara joaten gara
  • 8 GB RAM baino gutxiago badituzu, gomendatzen dizut egin trukea 10 GBberaz, OOM hiltzailea ez dadin etorri eta zereginak hil ditzagun RAM faltagatik. Hau gerta daiteke 5 zeregin baino gehiago aldi berean exekutatzen ari direnean. Zereginak motelagoak izango dira, baina egonkorrak.

    Adibidea OOM killer-ekin

    Zereginen erregistroetan ikusten baduzu bash: line 82: 26474 Killed, gero exekutatu korrikalarian sudo dmesg | grep 26474

    [26474]  1002 26474  1061935   123806     339        0             0 java
    Out of memory: Kill process 26474 (java) score 127 or sacrifice child
    Killed process 26474 (java) total-vm:4247740kB, anon-rss:495224kB, file-rss:0kB, shmem-rss:0kB

    Eta irudiak horrelako zerbait badu, gehitu swap edo sartu RAM.

  • Ezarri gitlab-runner, Docker, Docker-idazteko, egin.
  • Erabiltzaile bat gehitzea gitlab-runner taldeari docker
    sudo groupadd docker
    sudo usermod -aG docker gitlab-runner
  • Izena eman gitlab-runner.
  • Ireki editatzeko /etc/gitlab-runner/config.toml eta gehitu

    concurrent=20
    [[runners]]
      request_concurrency = 10

    Honek zeregin paraleloak korrikalari berean egiteko aukera emango dizu. Irakurri gehiago Hemen.
    Makina indartsuagoa baduzu, adibidez, 8 vCPU, 16 GB RAM, orduan zenbaki hauek gutxienez 2 aldiz handiagoak izan daitezke. Baina dena da korrikalari honetan zer abiaraziko den eta zer kantitatetan.

Hau da nahikoa.

Edukira

Docker-compose.yml prestatzen

Zeregin nagusia docker-compose.yml unibertsala da, garatzaileek/probatzaileek lokalean zein CI kanalizazioan erabil dezaketena.

Lehenik eta behin, CI-rako zerbitzu-izen bereziak egiten ditugu. GitLab CI-ko aldagai berezietako bat aldagaia da CI_JOB_ID. Zehazten baduzu container_name esanahiarekin "service-${CI_JOB_ID:-local}", orduan kasuan:

  • bada CI_JOB_ID ingurune-aldagaietan definitu gabe,
    orduan zerbitzuaren izena izango da service-local
  • bada CI_JOB_ID ingurune-aldagaietan definituta (adibidez, 123),
    orduan zerbitzuaren izena izango da service-123

Bigarrenik, zerbitzuak martxan jartzeko sare komun bat egiten dugu. Horrek sare-mailako isolamendua ematen digu hainbat proba-ingurune exekutatzen ditugunean.

networks:
  default:
    external:
      name: service-network-${CI_JOB_ID:-local}

Egia esan, hau da arrakasta lortzeko lehen urratsa =)

Nire docker-compose.yml-ren adibide bat iruzkinekin

version: "3"

# Для ΠΊΠΎΡ€Ρ€Π΅ΠΊΡ‚Π½ΠΎΠΉ Ρ€Π°Π±ΠΎΡ‚Ρ‹ web (php) ΠΈ fmt Π½ΡƒΠΆΠ½ΠΎ, 
# Ρ‡Ρ‚ΠΎΠ±Ρ‹ ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€Ρ‹ ΠΈΠΌΠ΅Π»ΠΈ ΠΎΠ±Ρ‰ΠΈΠΉ исполняСмый ΠΊΠΎΠ½Ρ‚Π΅Π½Ρ‚.
# Π’ нашСм случаС, это дирСктория /var/www/testrail
volumes:
  static-content:

# Π˜Π·ΠΎΠ»ΠΈΡ€ΡƒΠ΅ΠΌ ΠΎΠΊΡ€ΡƒΠΆΠ΅Π½ΠΈΠ΅ Π½Π° сСтСвом ΡƒΡ€ΠΎΠ²Π½Π΅
networks:
  default:
    external:
      name: testrail-network-${CI_JOB_ID:-local}

services:
  db:
    image: mysql:5.7.22
    # ΠšΠ°ΠΆΠ΄Ρ‹ΠΉ container_name содСрТит ${CI_JOB_ID:-local}
    container_name: "testrail-mysql-${CI_JOB_ID:-local}"
    environment:
      MYSQL_HOST: db
      MYSQL_DATABASE: mydb
      MYSQL_ROOT_PASSWORD: 1234
      SKIP_GRANT_TABLES: 1
      SKIP_NETWORKING: 1
      SERVICE_TAGS: dev
      SERVICE_NAME: mysql
    networks:
    - default

  migration:
    image: registry.gitlab.com/touchbit/image/testrail/migration:latest
    container_name: "testrail-migration-${CI_JOB_ID:-local}"
    links:
    - db
    depends_on:
    - db
    networks:
    - default

  fpm:
    image: registry.gitlab.com/touchbit/image/testrail/fpm:latest
    container_name: "testrail-fpm-${CI_JOB_ID:-local}"
    volumes:
    - static-content:/var/www/testrail
    links:
    - db
    networks:
    - default

  web:
    image: registry.gitlab.com/touchbit/image/testrail/web:latest
    container_name: "testrail-web-${CI_JOB_ID:-local}"
    # Если ΠΏΠ΅Ρ€Π΅ΠΌΠ΅Π½Π½Ρ‹Π΅ TR_HTTP_PORT ΠΈΠ»ΠΈ TR_HTTPS_PORTS Π½Π΅ ΠΎΠΏΡ€Π΅Π΄Π΅Π»Π΅Π½Ρ‹,
    # Ρ‚ΠΎ сСрвис поднимаСтся Π½Π° 80 ΠΈ 443 ΠΏΠΎΡ€Ρ‚Ρƒ соотвСтствСнно.
    ports:
      - ${TR_HTTP_PORT:-80}:80
      - ${TR_HTTPS_PORT:-443}:443
    volumes:
      - static-content:/var/www/testrail
    links:
      - db
      - fpm
    networks:
      - default

Exekuzio lokalaren adibidea

docker-compose -f docker-compose.yml up -d
Starting   testrail-mysql-local     ... done
Starting   testrail-migration-local ... done
Starting   testrail-fpm-local       ... done
Recreating testrail-web-local       ... done

Baina dena ez da hain erraza CI-n abiarazteko.

Edukira

Makefile prestatzen

Makefile erabiltzen dut nahiko erabilgarria baita tokiko ingurunearen kudeaketarako eta CIrako. Sareko iruzkin gehiago

# Π£ мСня Π² ΠΏΡ€ΠΎΠ΅ΠΊΡ‚Π°Ρ… всС Π²ΡΠΏΠΎΠΌΠΎΠ³Π°Ρ‚Π΅Π»ΡŒΠ½Ρ‹Π΅ Π²Π΅Ρ‰ΠΈ Π»Π΅ΠΆΠ°Ρ‚ Π² Π΄ΠΈΡ€Π΅ΠΊΡ‚ΠΎΡ€ΠΈΠΈ `.indirect`,
# Π² Ρ‚ΠΎΠΌ числС ΠΈ `docker-compose.yml`

# Π˜ΡΠΏΠΎΠ»ΡŒΠ·ΠΎΠ²Π°Ρ‚ΡŒ bash с ΠΎΠΏΡ†ΠΈΠ΅ΠΉ pipefail 
# pipefail - Ρ„Π΅ΠΉΠ»ΠΈΡ‚ Π²Ρ‹ΠΏΠΎΠ»Π½Π΅Π½ΠΈΠ΅ ΠΏΠ°ΠΉΠΏΠ°, Ссли ΠΊΠΎΠΌΠ°Π½Π΄Π° Π²Ρ‹ΠΏΠΎΠ»Π½ΠΈΠ»Π°ΡΡŒ с ошибкой
SHELL=/bin/bash -o pipefail

# ΠžΡΡ‚Π°Π½Π°Π²Π»ΠΈΠ²Π°Π΅ΠΌ ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€Ρ‹ ΠΈ удаляСм ΡΠ΅Ρ‚ΡŒ
docker-kill:
    docker-compose -f $${CI_JOB_ID:-.indirect}/docker-compose.yml kill
    docker network rm network-$${CI_JOB_ID:-testrail} || true

# ΠŸΡ€Π΅Π΄Π²Π°Ρ€ΠΈΡ‚Π΅Π»ΡŒΠ½ΠΎ выполняСм docker-kill 
docker-up: docker-kill
    # Π‘ΠΎΠ·Π΄Π°Π΅ΠΌ ΡΠ΅Ρ‚ΡŒ для окруТСния 
    docker network create network-$${CI_JOB_ID:-testrail}
    # Π—Π°Π±ΠΈΡ€Π°Π΅ΠΌ послСдниС ΠΎΠ±Ρ€Π°Π·Ρ‹ ΠΈΠ· docker-registry
    docker-compose -f $${CI_JOB_ID:-.indirect}/docker-compose.yml pull
    # ЗапускаСм ΠΎΠΊΡ€ΡƒΠΆΠ΅Π½ΠΈΠ΅
    # force-recreate - ΠΏΡ€ΠΈΠ½ΡƒΠ΄ΠΈΡ‚Π΅Π»ΡŒΠ½ΠΎΠ΅ пСрСсозданиС ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€ΠΎΠ²
    # renew-anon-volumes - Π½Π΅ ΠΈΡΠΏΠΎΠ»ΡŒΠ·ΠΎΠ²Π°Ρ‚ΡŒ volumes ΠΏΡ€Π΅Π΄Ρ‹Π΄ΡƒΡ‰ΠΈΡ… ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€ΠΎΠ²
    docker-compose -f $${CI_JOB_ID:-.indirect}/docker-compose.yml up --force-recreate --renew-anon-volumes -d
    # Ну ΠΈ, Π½Π° всякий случай, вывСсти Ρ‡Ρ‚ΠΎ Ρ‚Π°ΠΌ Ρƒ нас Π² ΠΏΡ€ΠΈΠ½Ρ†ΠΈΠΏΠ΅ Π·Π°ΠΏΡƒΡ‰Π΅Π½ΠΎ Π½Π° машинкС
    docker ps

# ΠšΠΎΠ»Π»Π΅ΠΊΡ‚ΠΈΠΌ Π»ΠΎΠ³ΠΈ сСрвисов
docker-logs:
    mkdir ./logs || true
    docker logs testrail-web-$${CI_JOB_ID:-local}       >& logs/testrail-web.log
    docker logs testrail-fpm-$${CI_JOB_ID:-local}       >& logs/testrail-fpm.log
    docker logs testrail-migration-$${CI_JOB_ID:-local} >& logs/testrail-migration.log
    docker logs testrail-mysql-$${CI_JOB_ID:-local}     >& logs/testrail-mysql.log

# ΠžΡ‡ΠΈΡΡ‚ΠΊΠ° Ρ€Π°Π½Π½Π΅Ρ€Π°
docker-clean:
    @echo ΠžΡΡ‚Π°Π½Π°Π²Π»ΠΈΠ²Π°Π΅ΠΌ всС testrail-ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€Ρ‹
    docker kill $$(docker ps --filter=name=testrail -q) || true
    @echo ΠžΡ‡ΠΈΡΡ‚ΠΊΠ° Π΄ΠΎΠΊΠ΅Ρ€ ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€ΠΎΠ²
    docker rm -f $$(docker ps -a -f --filter=name=testrail status=exited -q) || true
    @echo ΠžΡ‡ΠΈΡΡ‚ΠΊΠ° dangling ΠΎΠ±Ρ€Π°Π·ΠΎΠ²
    docker rmi -f $$(docker images -f "dangling=true" -q) || true
    @echo ΠžΡ‡ΠΈΡΡ‚ΠΊΠ° testrail ΠΎΠ±Ρ€Π°Π·ΠΎΠ²
    docker rmi -f $$(docker images --filter=reference='registry.gitlab.com/touchbit/image/testrail/*' -q) || true
    @echo ΠžΡ‡ΠΈΡΡ‚ΠΊΠ° всСх Π½Π΅ΠΈΡΠΏΠΎΠ»ΡŒΠ·ΡƒΠ΅ΠΌΡ‹Ρ… volume
    docker volume rm -f $$(docker volume ls -q) || true
    @echo ΠžΡ‡ΠΈΡΡ‚ΠΊΠ° всСх testrail сСтСй
    docker network rm $(docker network ls --filter=name=testrail -q) || true
    docker ps

check

egin docker-up

$ make docker-up 
docker-compose -f ${CI_JOB_ID:-.indirect}/docker-compose.yml kill
Killing testrail-web-local   ... done
Killing testrail-fpm-local   ... done
Killing testrail-mysql-local ... done
docker network rm network-${CI_JOB_ID:-testrail} || true
network-testrail
docker network create network-${CI_JOB_ID:-testrail}
d2ec063324081c8bbc1b08fd92242c2ea59d70cf4025fab8efcbc5c6360f083f
docker-compose -f ${CI_JOB_ID:-.indirect}/docker-compose.yml pull
Pulling db        ... done
Pulling migration ... done
Pulling fpm       ... done
Pulling web       ... done
docker-compose -f ${CI_JOB_ID:-.indirect}/docker-compose.yml up --force-recreate --renew-anon-volumes -d
Recreating testrail-mysql-local ... done
Recreating testrail-fpm-local       ... done
Recreating testrail-migration-local ... done
Recreating testrail-web-local       ... done
docker ps
CONTAINER ID  PORTS                                     NAMES
a845d3cb0e5a  0.0.0.0:80->80/tcp, 0.0.0.0:443->443/tcp  testrail-web-local
19d8ef001398  9000/tcp                                  testrail-fpm-local
e28840a2369c  3306/tcp, 33060/tcp                       testrail-migration-local
0e7900c23f37  3306/tcp                                  testrail-mysql-local

egin docker-erregistroak

$ make docker-logs
mkdir ./logs || true
mkdir: cannot create directory β€˜./logs’: File exists
docker logs testrail-web-${CI_JOB_ID:-local}       >& logs/testrail-web.log
docker logs testrail-fpm-${CI_JOB_ID:-local}       >& logs/testrail-fpm.log
docker logs testrail-migration-${CI_JOB_ID:-local} >& logs/testrail-migration.log
docker logs testrail-mysql-${CI_JOB_ID:-local}     >& logs/testrail-mysql.log

GitLab Shell Runner. Docker Compose-rekin proba-zerbitzuak lehiakor exekutatzen dira

Edukira

.gitlab-ci.yml prestatzen

Integrazio-probak egitea

Integration:
  stage: test
  tags:
    - my-shell-runner
  before_script:
    # АутСнтифицируСмся Π² registry
    - docker login -u gitlab-ci-token -p ${CI_JOB_TOKEN} ${CI_REGISTRY}
    # Π“Π΅Π½Π΅Ρ€ΠΈΡ€ΡƒΠ΅ΠΌ ΠΏΡΠ΅Π²Π΄ΠΎΡƒΠ½ΠΈΠΊΠ°Π»ΡŒΠ½Ρ‹Π΅ TR_HTTP_PORT ΠΈ TR_HTTPS_PORT
    - export TR_HTTP_PORT=$(shuf -i10000-60000 -n1)
    - export TR_HTTPS_PORT=$(shuf -i10000-60000 -n1)
    # создаСм Π΄ΠΈΡ€Π΅ΠΊΡ‚ΠΎΡ€ΠΈΡŽ с ΠΈΠ΄Π΅Π½Ρ‚ΠΈΡ„ΠΈΠΊΠ°Ρ‚ΠΎΡ€ΠΎΠΌ Π·Π°Π΄Π°Ρ‡ΠΈ
    - mkdir ${CI_JOB_ID}
    # ΠΊΠΎΠΏΠΈΡ€ΡƒΠ΅ΠΌ Π² ΡΠΎΠ·Π΄Π°Π½Π½ΡƒΡŽ Π΄ΠΈΡ€Π΅ΠΊΡ‚ΠΎΡ€ΠΈΡŽ наш docker-compose.yml
    # Ρ‡Ρ‚ΠΎΠ±Ρ‹ контСкст Π±Ρ‹Π» Ρ€Π°Π·Π½Ρ‹ΠΉ для ΠΊΠ°ΠΆΠ΄ΠΎΠΉ Π·Π°Π΄Π°Ρ‡ΠΈ
    - cp .indirect/docker-compose.yml ${CI_JOB_ID}/docker-compose.yml
  script:
    # ΠΏΠΎΠ΄Π½ΠΈΠΌΠ°Π΅ΠΌ нашС ΠΎΠΊΡ€ΡƒΠΆΠ΅Π½ΠΈΠ΅
    - make docker-up
    # запускаСм тСсты исполняСмым jar (Ρƒ мСня Ρ‚Π°ΠΊ)
    - java -jar itest.jar --http-port ${TR_HTTP_PORT} --https-port ${TR_HTTPS_PORT}
    # ΠΈΠ»ΠΈ Π² ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€Π΅
    - docker run --network=testrail-network-${CI_JOB_ID:-local} --rm itest
  after_script:
    # собираСм Π»ΠΎΠ³ΠΈ
    - make docker-logs
    # останавливаСм ΠΎΠΊΡ€ΡƒΠΆΠ΅Π½ΠΈΠ΅
    - make docker-kill
  artifacts:
    # сохраняСм Π»ΠΎΠ³ΠΈ
    when: always
    paths:
      - logs
    expire_in: 30 days

Zeregin hori exekutatzearen ondorioz, artefaktuen erregistroen direktorioak zerbitzuen eta proben erregistroak izango ditu. Oso erabilgarria da akatsen kasuan. Proba bakoitzak paraleloki bere erregistroa idazten du, baina honetaz aparte hitz egingo dut.

GitLab Shell Runner. Docker Compose-rekin proba-zerbitzuak lehiakor exekutatzen dira

Edukira

Korrikalariaren garbiketa

Zereginak egutegiaren arabera bakarrik egingo du.

stages:
- clean
- build
- test

Clean runner:
  stage: clean
  only:
    - schedules
  tags:
    - my-shell-runner
  script:
    - make docker-clean

Ondoren, joan gure GitLab proiektura -> CI/CD -> Ordutegiak -> Ordutegi berria eta gehitu ordutegi berri bat

GitLab Shell Runner. Docker Compose-rekin proba-zerbitzuak lehiakor exekutatzen dira

Edukira

Emaitza

Exekutatu 4 zeregin GitLab CI-n
GitLab Shell Runner. Docker Compose-rekin proba-zerbitzuak lehiakor exekutatzen dira

Integrazio proben azken zereginaren erregistroetan, zeregin ezberdinetako edukiontziak ikusten ditugu

CONTAINER ID  NAMES
c6b76f9135ed  testrail-web-204645172
01d303262d8e  testrail-fpm-204645172
2cdab1edbf6a  testrail-migration-204645172
826aaf7c0a29  testrail-mysql-204645172
6dbb3fae0322  testrail-web-204645084
3540f8d448ce  testrail-fpm-204645084
70fea72aa10d  testrail-mysql-204645084
d8aa24b2892d  testrail-web-204644881
6d4ccd910fad  testrail-fpm-204644881
685d8023a3ec  testrail-mysql-204644881
1cdfc692003a  testrail-web-204644793
6f26dfb2683e  testrail-fpm-204644793
029e16b26201  testrail-mysql-204644793
c10443222ac6  testrail-web-204567103
04339229397e  testrail-fpm-204567103
6ae0accab28d  testrail-mysql-204567103
b66b60d79e43  testrail-web-204553690
033b1f46afa9  testrail-fpm-204553690
a8879c5ef941  testrail-mysql-204553690
069954ba6010  testrail-web-204553539
ed6b17d911a5  testrail-fpm-204553539
1a1eed057ea0  testrail-mysql-204553539

Erregistro zehatzagoa

$ docker login -u gitlab-ci-token -p ${CI_JOB_TOKEN} ${CI_REGISTRY}
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/gitlab-runner/.docker/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store
Login Succeeded
$ export TR_HTTP_PORT=$(shuf -i10000-60000 -n1)
$ export TR_HTTPS_PORT=$(shuf -i10000-60000 -n1)
$ mkdir ${CI_JOB_ID}
$ cp .indirect/docker-compose.yml ${CI_JOB_ID}/docker-compose.yml
$ make docker-up
docker-compose -f ${CI_JOB_ID:-.indirect}/docker-compose.yml kill
docker network rm testrail-network-${CI_JOB_ID:-local} || true
Error: No such network: testrail-network-204645172
docker network create testrail-network-${CI_JOB_ID:-local}
0a59552b4464b8ab484de6ae5054f3d5752902910bacb0a7b5eca698766d0331
docker-compose -f ${CI_JOB_ID:-.indirect}/docker-compose.yml pull
Pulling web       ... done
Pulling fpm       ... done
Pulling migration ... done
Pulling db        ... done
docker-compose -f ${CI_JOB_ID:-.indirect}/docker-compose.yml up --force-recreate --renew-anon-volumes -d
Creating volume "204645172_static-content" with default driver
Creating testrail-mysql-204645172 ... 
Creating testrail-mysql-204645172 ... done
Creating testrail-migration-204645172 ... done
Creating testrail-fpm-204645172       ... done
Creating testrail-web-204645172       ... done
docker ps
CONTAINER ID        IMAGE                                                          COMMAND                  CREATED              STATUS              PORTS                                           NAMES
c6b76f9135ed        registry.gitlab.com/touchbit/image/testrail/web:latest         "nginx -g 'daemon of…"   13 seconds ago       Up 1 second         0.0.0.0:51148->80/tcp, 0.0.0.0:25426->443/tcp   testrail-web-204645172
01d303262d8e        registry.gitlab.com/touchbit/image/testrail/fpm:latest         "docker-php-entrypoi…"   16 seconds ago       Up 13 seconds       9000/tcp                                        testrail-fpm-204645172
2cdab1edbf6a        registry.gitlab.com/touchbit/image/testrail/migration:latest   "docker-entrypoint.s…"   16 seconds ago       Up 13 seconds       3306/tcp, 33060/tcp                             testrail-migration-204645172
826aaf7c0a29        mysql:5.7.22                                                   "docker-entrypoint.s…"   18 seconds ago       Up 16 seconds       3306/tcp                                        testrail-mysql-204645172
6dbb3fae0322        registry.gitlab.com/touchbit/image/testrail/web:latest         "nginx -g 'daemon of…"   36 seconds ago       Up 22 seconds       0.0.0.0:44202->80/tcp, 0.0.0.0:20151->443/tcp   testrail-web-204645084
3540f8d448ce        registry.gitlab.com/touchbit/image/testrail/fpm:latest         "docker-php-entrypoi…"   38 seconds ago       Up 35 seconds       9000/tcp                                        testrail-fpm-204645084
70fea72aa10d        mysql:5.7.22                                                   "docker-entrypoint.s…"   40 seconds ago       Up 37 seconds       3306/tcp                                        testrail-mysql-204645084
d8aa24b2892d        registry.gitlab.com/touchbit/image/testrail/web:latest         "nginx -g 'daemon of…"   About a minute ago   Up 53 seconds       0.0.0.0:31103->80/tcp, 0.0.0.0:43872->443/tcp   testrail-web-204644881
6d4ccd910fad        registry.gitlab.com/touchbit/image/testrail/fpm:latest         "docker-php-entrypoi…"   About a minute ago   Up About a minute   9000/tcp                                        testrail-fpm-204644881
685d8023a3ec        mysql:5.7.22                                                   "docker-entrypoint.s…"   About a minute ago   Up About a minute   3306/tcp                                        testrail-mysql-204644881
1cdfc692003a        registry.gitlab.com/touchbit/image/testrail/web:latest         "nginx -g 'daemon of…"   About a minute ago   Up About a minute   0.0.0.0:44752->80/tcp, 0.0.0.0:23540->443/tcp   testrail-web-204644793
6f26dfb2683e        registry.gitlab.com/touchbit/image/testrail/fpm:latest         "docker-php-entrypoi…"   About a minute ago   Up About a minute   9000/tcp                                        testrail-fpm-204644793
029e16b26201        mysql:5.7.22                                                   "docker-entrypoint.s…"   About a minute ago   Up About a minute   3306/tcp                                        testrail-mysql-204644793
c10443222ac6        registry.gitlab.com/touchbit/image/testrail/web:latest         "nginx -g 'daemon of…"   5 hours ago          Up 5 hours          0.0.0.0:57123->80/tcp, 0.0.0.0:31657->443/tcp   testrail-web-204567103
04339229397e        registry.gitlab.com/touchbit/image/testrail/fpm:latest         "docker-php-entrypoi…"   5 hours ago          Up 5 hours          9000/tcp                                        testrail-fpm-204567103
6ae0accab28d        mysql:5.7.22                                                   "docker-entrypoint.s…"   5 hours ago          Up 5 hours          3306/tcp                                        testrail-mysql-204567103
b66b60d79e43        registry.gitlab.com/touchbit/image/testrail/web:latest         "nginx -g 'daemon of…"   5 hours ago          Up 5 hours          0.0.0.0:56321->80/tcp, 0.0.0.0:58749->443/tcp   testrail-web-204553690
033b1f46afa9        registry.gitlab.com/touchbit/image/testrail/fpm:latest         "docker-php-entrypoi…"   5 hours ago          Up 5 hours          9000/tcp                                        testrail-fpm-204553690
a8879c5ef941        mysql:5.7.22                                                   "docker-entrypoint.s…"   5 hours ago          Up 5 hours          3306/tcp                                        testrail-mysql-204553690
069954ba6010        registry.gitlab.com/touchbit/image/testrail/web:latest         "nginx -g 'daemon of…"   5 hours ago          Up 5 hours          0.0.0.0:32869->80/tcp, 0.0.0.0:16066->443/tcp   testrail-web-204553539
ed6b17d911a5        registry.gitlab.com/touchbit/image/testrail/fpm:latest         "docker-php-entrypoi…"   5 hours ago          Up 5 hours          9000/tcp                                        testrail-fpm-204553539
1a1eed057ea0        mysql:5.7.22                                                   "docker-entrypoint.s…"   5 hours ago          Up 5 hours          3306/tcp                                        testrail-mysql-204553539

Zeregin guztiak behar bezala burutu dira

Zereginen artefaktuek zerbitzuen eta proben erregistroak dituzte
GitLab Shell Runner. Docker Compose-rekin proba-zerbitzuak lehiakor exekutatzen dira

GitLab Shell Runner. Docker Compose-rekin proba-zerbitzuak lehiakor exekutatzen dira

Dena ederra omen da, baina badago Γ±abardura bat. Hodibide bat indarrez bertan behera utzi daiteke integrazio-probak martxan dauden bitartean, eta kasu horretan, edukiontziak ez dira geldituko. Noizean behin korrikalaria garbitu behar duzu. Zoritxarrez, GitLab CE-n berrikusteko zeregina egoeran dago oraindik Ireki

Baina programatutako zereginen abiarazte bat gehitu dugu, eta inork ez digu eskuz abiaraztea debekatzen.
Joan gure proiektua -> CI/CD -> Ordutegiak eta exekutatu zeregina Clean runner

GitLab Shell Runner. Docker Compose-rekin proba-zerbitzuak lehiakor exekutatzen dira

Guztira:

  • Maskor korrikalari bat dugu.
  • Ez dago zereginen eta ingurunearen arteko gatazkarik.
  • Integrazio testekin zereginen abiarazte paralelo bat dugu.
  • Integrazio probak exekutatu ditzakezu bai lokalean bai edukiontzi batean.
  • Zerbitzuen eta probaren erregistroak bildu eta kanalizazio-zereginari eransten zaizkio.
  • Posible da korrikalaria docker irudi zaharretatik garbitzea.

Konfigurazio-denbora ~ 2 ordu da.
Hori da, hain zuzen ere, dena. Pozik erantzungo dut.

Edukira

Iturria: www.habr.com

Gehitu iruzkin berria