Мне нужно настроить серию перехватчиков Gitlab в образе Docker, которые будут запускаться при предварительной фиксации. У меня есть файл Docker и pre-commit-config.yaml, который успешно создается, за исключением одного крючка, который, похоже, не работает.
.pre-commit-config.yaml
---
repos:
- repo: local
hooks:
- id: check-merge-conflict
name: Check for merge conflicts
description: Check for files that contain merge conflict strings.
entry: check-merge-conflict
language: python
types: [text]
- id: epp-validate
additional_dependencies: ['puppet']
description: Validate syntax of Puppet EPP templates
entry: /puppet-pre-commit-hooks/epp-validate
files: \.epp$
language: ruby
name: Validate EPP templates
- id: erb-validate
description: Validate syntax of Ruby ERB templates
entry: /puppet-pre-commit-hooks/erb-validate
files: \.erb$
language: ruby
name: Validate ERB templates
- id: puppet-lint
additional_dependencies: ['puppet-lint']
description: Check Puppet manifests for stylistic problems
entry: /puppet-pre-commit-hooks/puppet-lint
files: \.pp$
language: ruby
name: puppet-lint
args:
- --fail-on-warnings
- id: puppet-validate
additional_dependencies: ['puppet']
description: Validate syntax of Puppet manifests
entry: /puppet-pre-commit-hooks/puppet-validate
files: \.pp$
language: ruby
name: Validate Puppet manifests
- id: r10k-validate
additional_dependencies: ['r10k']
description: Validate syntax of Puppetfile using r10k
entry: /puppet-pre-commit-hooks/r10k-validate
files: ^Puppetfile$
language: ruby
name: Validate r10k Puppetfile
- id: ruby-validate
additional_dependencies: ['ruby']
description: Validate syntax of ruby code
entry: /puppet-pre-commit-hooks/ruby-validate
files: \.rb$
language: ruby
name: Validate ruby syntax
Мне пришлось настроить хуки как локальные, потому что среда, в которой это используется, имеет воздушный зазор, который предотвращает доступ к Интернету. Чтобы преодолеть это, я клонировал несколько репозиториев с соответствующими хуками.
Сборка выполняется успешно, за исключением ловушки check-merge-конфликт, которую не удается найти. В контейнере докера код Python для этого хука находится в /pre-commit-hooks/pre_commit_hooks/check_merge_commit.py.
Я попытался изменить запись: значение на '' '/ pre-commit-hooks / pre_commit_hooks / check_merge_commit pre_commit_hooks / check-merge-commit check_merge_commit' ''
... но ничего из этого не сработало.
Файл Docker
FROM ruby:2.5.0
SHELL ["/bin/bash", "-o", "pipefail", "-c"]
RUN source ~/.profile
RUN curl https://pre-commit.com/install-local.py | python -
COPY pre-commit/.pre-commit-config.yaml .
RUN git clone https://github.com/pre-commit/pre-commit-hooks.git
RUN git clone https://github.com/chriskuehl/puppet-pre-commit-hooks.git
RUN git clone https://github.com/adrienverge/yamllint.git
WORKDIR /jumanjihouse
RUN git clone https://github.com/jumanjihouse/pre-commit-hooks.git
RUN rm -rf /jumanjihouse/pre-commit-hooks/.git* /yamllint/.git* /puppet-pre-commit-hooks/.git* /pre-commit-hooks/.git* /usr/local/lib/ruby/gems/2.5.0/gems/*/.git*
WORKDIR /
RUN git init
RUN /root/bin/pre-commit run -a
Кто-нибудь знает, что я упускаю / делаю не так?
Хук взят из Github.
pre-commit install-hooks
снаружи с любой нормальной конфигурацией - во время выполнения он вообще не будет использовать сеть - person Anthony Sottile   schedule 30.01.2020RUN /root/bin/pre-commit install-hooks
Это должно сработать? Извините, если это базовые вещи, но я новичок в написании конвейеров. - person MmmmDonuts   schedule 30.01.2020local
или ручного клонирования) - person Anthony Sottile   schedule 30.01.2020