Fix gerrit upgrade config diff checking
There were two problems with our gerrit upgrade config diff checking. The first is that we were comparing using command exit codes after pipeing diff to tee without setting pipefail. This meant that even if the diff failed we got an exit code of 0 from tee and everything passed happily. Second we were not checking our pre gerrit state diff state. If the old gerrit version also updated the config on disk we wouldn't get a diff after upgrading to the new version. I think that is ultimately what broke for us here because the 3.6 and 3.7 config diffs are empty, but they differ from what we initially write to disk. As for explaining why this might happen I can only assume some update to 3.6 made the changes we saw after we had deployed 3.6. As a result of checking things more thoroughly we need to update our config to remove any delta. This removes some extraneous quoting around gitweb config entries to do that. Change-Id: I9c7e73d5f64546fb57a21a249b29e2aca9229ac7
This commit is contained in:
parent
7273c26332
commit
91ab316142
@ -144,17 +144,17 @@
|
|||||||
allowTopMenu = false
|
allowTopMenu = false
|
||||||
# Custom code browser linking for Gitea.
|
# Custom code browser linking for Gitea.
|
||||||
[gitweb]
|
[gitweb]
|
||||||
branch = "${project}/src/branch/${branch}"
|
branch = ${project}/src/branch/${branch}
|
||||||
file = "${project}/src/commit/${hash}/${file}"
|
file = ${project}/src/commit/${hash}/${file}
|
||||||
filehistory = "${project}/commits/branch/${branch}/${file}"
|
filehistory = ${project}/commits/branch/${branch}/${file}
|
||||||
linkname = gitea
|
linkname = gitea
|
||||||
project = "${project}"
|
project = ${project}
|
||||||
revision = "${project}/commit/${commit}"
|
revision = ${project}/commit/${commit}
|
||||||
roottree = "${project}/src/commit/${commit}"
|
roottree = ${project}/src/commit/${commit}
|
||||||
type = custom
|
type = custom
|
||||||
urlEncode = false
|
urlEncode = false
|
||||||
tag = "${project}/src/tag/${tag}"
|
tag = ${project}/src/tag/${tag}
|
||||||
url = "https://opendev.org/"
|
url = https://opendev.org/
|
||||||
[index]
|
[index]
|
||||||
type = LUCENE
|
type = LUCENE
|
||||||
threads = 8
|
threads = 8
|
||||||
|
@ -4,7 +4,35 @@
|
|||||||
#
|
#
|
||||||
# In particular it bootstraps users and test changes assuming a test env.
|
# In particular it bootstraps users and test changes assuming a test env.
|
||||||
|
|
||||||
- name: Ensure initial gerrit state
|
- name: Ensure initial gerrit state without starting Gerrit
|
||||||
|
import_playbook: ../service-review.yaml
|
||||||
|
vars:
|
||||||
|
gerrit_container_image: docker.io/opendevorg/gerrit:3.6
|
||||||
|
gerrit_run_init: false
|
||||||
|
gerrit_run_reindex: false
|
||||||
|
gerrit_run_compose_up: false
|
||||||
|
|
||||||
|
- hosts: "review:!disabled"
|
||||||
|
name: "Record pre Gerrit deployment configuration state"
|
||||||
|
tasks:
|
||||||
|
# This allows us to check that our config file isn't modified by newer
|
||||||
|
# Gerrit versions.
|
||||||
|
- name: Backup config files pre deploy
|
||||||
|
block:
|
||||||
|
- name: Find .config files
|
||||||
|
find:
|
||||||
|
paths: /home/gerrit2/review_site/etc
|
||||||
|
patterns: '*.config'
|
||||||
|
register: _config_files_pre_deploy
|
||||||
|
|
||||||
|
- name: 'Backup config file'
|
||||||
|
copy:
|
||||||
|
src: '{{ item }}'
|
||||||
|
dest: '{{ item }}.pre-deploy'
|
||||||
|
remote_src: true
|
||||||
|
loop: "{{ _config_files_pre_deploy.files | map(attribute='path') | list }}"
|
||||||
|
|
||||||
|
- name: Start Gerrit on the old version of Gerrit
|
||||||
import_playbook: ../service-review.yaml
|
import_playbook: ../service-review.yaml
|
||||||
vars:
|
vars:
|
||||||
gerrit_container_image: docker.io/opendevorg/gerrit:3.6
|
gerrit_container_image: docker.io/opendevorg/gerrit:3.6
|
||||||
@ -30,20 +58,20 @@
|
|||||||
|
|
||||||
# This allows us to check that our config file isn't modified by newer
|
# This allows us to check that our config file isn't modified by newer
|
||||||
# Gerrit versions.
|
# Gerrit versions.
|
||||||
- name: Backup config files
|
- name: Backup config files pre upgrade
|
||||||
block:
|
block:
|
||||||
- name: Find .config files
|
- name: Find .config files
|
||||||
find:
|
find:
|
||||||
paths: /home/gerrit2/review_site/etc
|
paths: /home/gerrit2/review_site/etc
|
||||||
patterns: '*.config'
|
patterns: '*.config'
|
||||||
register: _config_files
|
register: _config_files_pre_upgrade
|
||||||
|
|
||||||
- name: 'Backup config file'
|
- name: 'Backup config file'
|
||||||
copy:
|
copy:
|
||||||
src: '{{ item }}'
|
src: '{{ item }}'
|
||||||
dest: '{{ item }}.pre-upgrade'
|
dest: '{{ item }}.pre-upgrade'
|
||||||
remote_src: true
|
remote_src: true
|
||||||
loop: "{{ _config_files.files | map(attribute='path') | list }}"
|
loop: "{{ _config_files_pre_upgrade.files | map(attribute='path') | list }}"
|
||||||
|
|
||||||
# Record h2 cache files. We will use this to highlight any new caches
|
# Record h2 cache files. We will use this to highlight any new caches
|
||||||
# under the new Gerrit version.
|
# under the new Gerrit version.
|
||||||
@ -64,17 +92,35 @@
|
|||||||
- hosts: "review:!disabled"
|
- hosts: "review:!disabled"
|
||||||
name: "Post upgrade config check"
|
name: "Post upgrade config check"
|
||||||
tasks:
|
tasks:
|
||||||
- name: Diff config files
|
- name: Diff config files pre deploy to pre upgrade
|
||||||
shell: |
|
shell: |
|
||||||
diff -u {{ item }}.pre-upgrade {{ item }} | tee {{ item }}.diff
|
set -o pipefail
|
||||||
loop: "{{ _config_files.files | map(attribute='path') | list }}"
|
diff -u {{ item }}.pre-deploy {{ item }}.pre-upgrade | tee {{ item }}.deploy.diff
|
||||||
register: _diff_output
|
args:
|
||||||
|
executable: /bin/bash
|
||||||
|
loop: "{{ _config_files_pre_upgrade.files | map(attribute='path') | list }}"
|
||||||
|
register: _diff_output_deploy
|
||||||
|
|
||||||
- name: Check config diffs
|
- name: Diff config files pre upgrade to post upgrade
|
||||||
|
shell: |
|
||||||
|
set -o pipefail
|
||||||
|
diff -u {{ item }}.pre-upgrade {{ item }} | tee {{ item }}.upgrade.diff
|
||||||
|
args:
|
||||||
|
executable: /bin/bash
|
||||||
|
loop: "{{ _config_files_pre_upgrade.files | map(attribute='path') | list }}"
|
||||||
|
register: _diff_output_upgrade
|
||||||
|
|
||||||
|
- name: Check the config diffs after deployment
|
||||||
fail:
|
fail:
|
||||||
msg: 'Difference detected in file {{ item.item }} '
|
msg: 'Difference detected in file {{ item.item }} '
|
||||||
when: item.rc != 0
|
when: item.rc != 0
|
||||||
loop: '{{ _diff_output.results }}'
|
loop: '{{ _diff_output_deploy.results }}'
|
||||||
|
|
||||||
|
- name: Check the config diffs after upgrade
|
||||||
|
fail:
|
||||||
|
msg: 'Difference detected in file {{ item.item }} '
|
||||||
|
when: item.rc != 0
|
||||||
|
loop: '{{ _diff_output_upgrade.results }}'
|
||||||
|
|
||||||
- name: Record Gerrit new cache files
|
- name: Record Gerrit new cache files
|
||||||
find:
|
find:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user