mirror of
https://github.com/element-hq/synapse.git
synced 2024-11-22 09:35:45 +03:00
parent
6c84778549
commit
51065c44bb
6 changed files with 70 additions and 55 deletions
|
@ -1,36 +0,0 @@
|
||||||
#!/usr/bin/env python
|
|
||||||
# Copyright 2019 The Matrix.org Foundation C.I.C.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
import logging
|
|
||||||
|
|
||||||
from synapse.storage.engines import create_engine
|
|
||||||
|
|
||||||
logger = logging.getLogger("create_postgres_db")
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
# Create a PostgresEngine.
|
|
||||||
db_engine = create_engine({"name": "psycopg2", "args": {}})
|
|
||||||
|
|
||||||
# Connect to postgres to create the base database.
|
|
||||||
# We use "postgres" as a database because it's bound to exist and the "synapse" one
|
|
||||||
# doesn't exist yet.
|
|
||||||
db_conn = db_engine.module.connect(
|
|
||||||
user="postgres", host="postgres", password="postgres", dbname="postgres"
|
|
||||||
)
|
|
||||||
db_conn.autocommit = True
|
|
||||||
cur = db_conn.cursor()
|
|
||||||
cur.execute("CREATE DATABASE synapse;")
|
|
||||||
cur.close()
|
|
||||||
db_conn.close()
|
|
31
.buildkite/scripts/postgres_exec.py
Executable file
31
.buildkite/scripts/postgres_exec.py
Executable file
|
@ -0,0 +1,31 @@
|
||||||
|
#!/usr/bin/env python
|
||||||
|
# Copyright 2019 The Matrix.org Foundation C.I.C.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
import sys
|
||||||
|
|
||||||
|
import psycopg2
|
||||||
|
|
||||||
|
# a very simple replacment for `psql`, to make up for the lack of the postgres client
|
||||||
|
# libraries in the synapse docker image.
|
||||||
|
|
||||||
|
# We use "postgres" as a database because it's bound to exist and the "synapse" one
|
||||||
|
# doesn't exist yet.
|
||||||
|
db_conn = psycopg2.connect(
|
||||||
|
user="postgres", host="postgres", password="postgres", dbname="postgres"
|
||||||
|
)
|
||||||
|
db_conn.autocommit = True
|
||||||
|
cur = db_conn.cursor()
|
||||||
|
for c in sys.argv[1:]:
|
||||||
|
cur.execute(c)
|
|
@ -1,10 +1,10 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
#
|
#
|
||||||
# Test script for 'synapse_port_db', which creates a virtualenv, installs Synapse along
|
# Test script for 'synapse_port_db'.
|
||||||
# with additional dependencies needed for the test (such as coverage or the PostgreSQL
|
# - sets up synapse and deps
|
||||||
# driver), update the schema of the test SQLite database and run background updates on it,
|
# - runs the port script on a prepopulated test sqlite db
|
||||||
# create an empty test database in PostgreSQL, then run the 'synapse_port_db' script to
|
# - also runs it against an new sqlite db
|
||||||
# test porting the SQLite database to the PostgreSQL database (with coverage).
|
|
||||||
|
|
||||||
set -xe
|
set -xe
|
||||||
cd `dirname $0`/../..
|
cd `dirname $0`/../..
|
||||||
|
@ -22,15 +22,32 @@ echo "--- Generate the signing key"
|
||||||
# Generate the server's signing key.
|
# Generate the server's signing key.
|
||||||
python -m synapse.app.homeserver --generate-keys -c .buildkite/sqlite-config.yaml
|
python -m synapse.app.homeserver --generate-keys -c .buildkite/sqlite-config.yaml
|
||||||
|
|
||||||
echo "--- Prepare the databases"
|
echo "--- Prepare test database"
|
||||||
|
|
||||||
# Make sure the SQLite3 database is using the latest schema and has no pending background update.
|
# Make sure the SQLite3 database is using the latest schema and has no pending background update.
|
||||||
scripts-dev/update_database --database-config .buildkite/sqlite-config.yaml
|
scripts-dev/update_database --database-config .buildkite/sqlite-config.yaml
|
||||||
|
|
||||||
# Create the PostgreSQL database.
|
# Create the PostgreSQL database.
|
||||||
./.buildkite/scripts/create_postgres_db.py
|
./.buildkite/scripts/postgres_exec.py "CREATE DATABASE synapse"
|
||||||
|
|
||||||
echo "+++ Run synapse_port_db"
|
echo "+++ Run synapse_port_db against test database"
|
||||||
|
coverage run scripts/synapse_port_db --sqlite-database .buildkite/test_db.db --postgres-config .buildkite/postgres-config.yaml
|
||||||
# Run the script
|
|
||||||
|
#####
|
||||||
|
|
||||||
|
# Now do the same again, on an empty database.
|
||||||
|
|
||||||
|
echo "--- Prepare empty SQLite database"
|
||||||
|
|
||||||
|
# we do this by deleting the sqlite db, and then doing the same again.
|
||||||
|
rm .buildkite/test_db.db
|
||||||
|
|
||||||
|
scripts-dev/update_database --database-config .buildkite/sqlite-config.yaml
|
||||||
|
|
||||||
|
# re-create the PostgreSQL database.
|
||||||
|
./.buildkite/scripts/postgres_exec.py \
|
||||||
|
"DROP DATABASE synapse" \
|
||||||
|
"CREATE DATABASE synapse"
|
||||||
|
|
||||||
|
echo "+++ Run synapse_port_db against empty database"
|
||||||
coverage run scripts/synapse_port_db --sqlite-database .buildkite/test_db.db --postgres-config .buildkite/postgres-config.yaml
|
coverage run scripts/synapse_port_db --sqlite-database .buildkite/test_db.db --postgres-config .buildkite/postgres-config.yaml
|
||||||
|
|
2
.github/workflows/tests.yml
vendored
2
.github/workflows/tests.yml
vendored
|
@ -273,7 +273,7 @@ jobs:
|
||||||
python-version: ${{ matrix.python-version }}
|
python-version: ${{ matrix.python-version }}
|
||||||
- name: Patch Buildkite-specific test scripts
|
- name: Patch Buildkite-specific test scripts
|
||||||
run: |
|
run: |
|
||||||
sed -i -e 's/host="postgres"/host="localhost"/' .buildkite/scripts/create_postgres_db.py
|
sed -i -e 's/host="postgres"/host="localhost"/' .buildkite/scripts/postgres_exec.py
|
||||||
sed -i -e 's/host: postgres/host: localhost/' .buildkite/postgres-config.yaml
|
sed -i -e 's/host: postgres/host: localhost/' .buildkite/postgres-config.yaml
|
||||||
sed -i -e 's|/src/||' .buildkite/{sqlite,postgres}-config.yaml
|
sed -i -e 's|/src/||' .buildkite/{sqlite,postgres}-config.yaml
|
||||||
sed -i -e 's/\$TOP/\$GITHUB_WORKSPACE/' .coveragerc
|
sed -i -e 's/\$TOP/\$GITHUB_WORKSPACE/' .coveragerc
|
||||||
|
|
1
changelog.d/9930.bugfix
Normal file
1
changelog.d/9930.bugfix
Normal file
|
@ -0,0 +1 @@
|
||||||
|
Fix bugs introduced in v1.23.0 which made the PostgreSQL port script fail when run with a newly-created SQLite database.
|
|
@ -913,10 +913,11 @@ class Porter(object):
|
||||||
(curr_forward_id + 1,),
|
(curr_forward_id + 1,),
|
||||||
)
|
)
|
||||||
|
|
||||||
txn.execute(
|
if curr_backward_id:
|
||||||
"ALTER SEQUENCE events_backfill_stream_seq RESTART WITH %s",
|
txn.execute(
|
||||||
(curr_backward_id + 1,),
|
"ALTER SEQUENCE events_backfill_stream_seq RESTART WITH %s",
|
||||||
)
|
(curr_backward_id + 1,),
|
||||||
|
)
|
||||||
|
|
||||||
await self.postgres_store.db_pool.runInteraction(
|
await self.postgres_store.db_pool.runInteraction(
|
||||||
"_setup_events_stream_seqs", _setup_events_stream_seqs_set_pos,
|
"_setup_events_stream_seqs", _setup_events_stream_seqs_set_pos,
|
||||||
|
@ -954,10 +955,11 @@ class Porter(object):
|
||||||
(curr_chain_id,),
|
(curr_chain_id,),
|
||||||
)
|
)
|
||||||
|
|
||||||
await self.postgres_store.db_pool.runInteraction(
|
if curr_chain_id is not None:
|
||||||
"_setup_event_auth_chain_id", r,
|
await self.postgres_store.db_pool.runInteraction(
|
||||||
)
|
"_setup_event_auth_chain_id",
|
||||||
|
r,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
##############################################
|
##############################################
|
||||||
|
|
Loading…
Reference in a new issue