Skip to content
This repository has been archived by the owner on Apr 26, 2024. It is now read-only.

Merge the Complement testing Docker images into a single, multi-purpose image. #12881

Merged
merged 28 commits into from
Jun 8, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
e4137c1
Mutiny: oust the monolith image and replace with the workers image
reivilibre May 24, 2022
865fa26
Update references in Dockerfile
reivilibre May 24, 2022
edc7fcd
Update complement.sh to use the unified image
reivilibre May 24, 2022
15215bd
Make it possible to disable Redis with an env var
reivilibre May 26, 2022
97699e3
Require START_POSTGRES=1 to start Postgres
reivilibre May 26, 2022
9cd96d2
Make the Complement Synapse launcher able to handle all 3 scenarios
reivilibre May 26, 2022
3a588a0
Don't enable Redis for the monolith case
reivilibre May 26, 2022
7bc03a6
Burn env vars into the image (sad and hopefully temporary)
reivilibre May 26, 2022
bf37bf3
Newsfile
reivilibre May 26, 2022
facccd0
Bring back the experimental features
reivilibre May 26, 2022
7e9884a
Apply suggestions from Rich
reivilibre May 30, 2022
423e212
Remove mention of 'worker' from entrypoint
reivilibre May 30, 2022
470fabe
Pass the environment variables straight through, with no burning!
reivilibre May 30, 2022
b0241e7
Add back SYNAPSE_VERSION build arguments
reivilibre May 30, 2022
3537762
Automatically disable Redis only for no-worker instances
reivilibre May 31, 2022
8ae3da7
Improve Complement documentation about 'Stuff' :)
reivilibre May 31, 2022
33aeb67
Update the contributing guide
reivilibre May 31, 2022
9f8d317
Update README-testing.md
reivilibre May 31, 2022
9531da6
Fix sentence that dropped off
reivilibre May 31, 2022
2beae8f
Update docker/README-testing.md
reivilibre May 31, 2022
bc5d529
Apply suggestions from code review
reivilibre May 31, 2022
166b046
Remove obsolete START_REDIS
reivilibre May 31, 2022
4a739ca
Fix comment explaining the overwritten config file
reivilibre May 31, 2022
1af38ef
Convert workers-shared.yaml to Jinja2 and import the original file ra…
reivilibre Jun 1, 2022
6daac8a
Add comment about how it fits in
reivilibre Jun 6, 2022
6c01955
Merge branch 'develop' into rei/one_complement_image
reivilibre Jun 6, 2022
2fd415b
Update docker/configure_workers_and_start.py
reivilibre Jun 8, 2022
b548132
Move comment to top of file and rephrase slightly
reivilibre Jun 8, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 deletions docker/complement/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -38,3 +38,11 @@ ENTRYPOINT ["/start-complement-synapse-workers.sh"]
# Update the healthcheck to have a shorter check interval
HEALTHCHECK --start-period=5s --interval=1s --timeout=1s \
CMD /bin/sh /healthcheck.sh

# TODO Ideally we should be able to pass env vars straight in via Complement
# but for now we burn them in to the image.
# See https://github.com/matrix-org/complement/issues/6.
ARG use_workers=true
ENV SYNAPSE_COMPLEMENT_USE_WORKERS $use_workers
ARG database=postgres
ENV SYNAPSE_COMPLEMENT_DATABASE $database
reivilibre marked this conversation as resolved.
Show resolved Hide resolved
16 changes: 12 additions & 4 deletions scripts-dev/complement.sh
Original file line number Diff line number Diff line change
Expand Up @@ -46,9 +46,6 @@ docker build -t matrixdotorg/synapse -f "docker/Dockerfile" .
# Build the workers docker image (from the base Synapse image we just built).
docker build -t matrixdotorg/synapse-workers -f "docker/Dockerfile-workers" .

# Build the Complement image (from the worker Synapse image we just built).
docker build -t complement-synapse -f "docker/complement/Dockerfile" "docker/complement"

export COMPLEMENT_BASE_IMAGE=complement-synapse

extra_test_args=()
Expand All @@ -57,7 +54,7 @@ test_tags="synapse_blacklist,msc2716,msc3030"

if [[ -n "$WORKERS" ]]; then
# Use workers.
export SYNAPSE_COMPLEMENT_USE_WORKERS=1
export SYNAPSE_COMPLEMENT_USE_WORKERS=true

# Workers can only use Postgres as a database.
export SYNAPSE_COMPLEMENT_DATABASE=postgres
Expand All @@ -72,6 +69,7 @@ if [[ -n "$WORKERS" ]]; then
# ... and it takes longer than 10m to run the whole suite.
extra_test_args+=("-timeout=60m")
else
export SYNAPSE_COMPLEMENT_USE_WORKERS=
if [[ -n "$POSTGRES" ]]; then
export SYNAPSE_COMPLEMENT_DATABASE=postgres
else
Expand All @@ -83,6 +81,16 @@ else
test_tags="$test_tags,faster_joins"
fi

# TODO Since we can't pass env vars through Complement
# (see https://github.com/matrix-org/complement/issues/6),
# we burn them in to the image for now.

# Build the Complement image (from the worker Synapse image we just built).
docker build -t complement-synapse \
--build-arg "use_workers=$SYNAPSE_COMPLEMENT_USE_WORKERS" \
--build-arg "database=$SYNAPSE_COMPLEMENT_DATABASE" \
-f "docker/complement/Dockerfile" "docker/complement"


# Run the tests!
echo "Images built; running complement"
Expand Down