Skip to content
Snippets Groups Projects
test_synapse_port_db.sh 2.98 KiB
Newer Older
  • Learn to ignore specific revisions
  • # Test script for 'synapse_port_db'.
    
    #   - configures synapse and a postgres server.
    
    #   - runs the port script on a prepopulated test sqlite db. Checks that the
    #     return code is zero.
    #   - reruns the port script on the same sqlite db, targetting the same postgres db.
    #     Checks that the return code is zero.
    #   - runs the port script against a new sqlite db. Checks the return code is zero.
    
    #
    # Expects Synapse to have been already installed with `poetry install --extras postgres`.
    # Expects `poetry` to be available on the `PATH`.
    
    cd "$(dirname "$0")/../.."
    
    echo "--- Generate the signing key"
    
    poetry run synapse_homeserver --generate-keys -c .ci/sqlite-config.yaml
    
    echo "--- Prepare test database"
    
    # Make sure the SQLite3 database is using the latest schema and has no pending background updates.
    
    poetry run update_synapse_database --database-config .ci/sqlite-config.yaml --run-background-updates
    
    
    # Create the PostgreSQL database.
    
    psql -c "CREATE DATABASE synapse"
    
    
    echo "+++ Run synapse_port_db against test database"
    
    # TODO: this invocation of synapse_port_db (and others below) used to be prepended with `coverage run`,
    # but coverage seems unable to find the entrypoints installed by `pip install -e .`.
    
    poetry run synapse_port_db --sqlite-database .ci/test_db.db --postgres-config .ci/postgres-config.yaml
    
    # We should be able to run twice against the same database.
    echo "+++ Run synapse_port_db a second time"
    
    poetry run synapse_port_db --sqlite-database .ci/test_db.db --postgres-config .ci/postgres-config.yaml
    
    #####
    
    # 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.
    
    David Robertson's avatar
    David Robertson committed
    rm .ci/test_db.db
    
    poetry run update_synapse_database --database-config .ci/sqlite-config.yaml --run-background-updates
    
    # re-create the PostgreSQL database.
    
    psql \
      -c "DROP DATABASE synapse" \
      -c "CREATE DATABASE synapse"
    
    echo "+++ Run synapse_port_db against empty database"
    
    poetry run synapse_port_db --sqlite-database .ci/test_db.db --postgres-config .ci/postgres-config.yaml
    
    
    echo "--- Create a brand new postgres database from schema"
    cp .ci/postgres-config.yaml .ci/postgres-config-unported.yaml
    sed -i -e 's/database: synapse/database: synapse_unported/' .ci/postgres-config-unported.yaml
    psql -c "CREATE DATABASE synapse_unported"
    poetry run update_synapse_database --database-config .ci/postgres-config-unported.yaml --run-background-updates
    
    echo "+++ Comparing ported schema with unported schema"
    # Ignore the tables that portdb creates. (Should it tidy them up when the porting is completed?)
    psql synapse -c "DROP TABLE port_from_sqlite3;"
    pg_dump --format=plain --schema-only --no-tablespaces --no-acl --no-owner synapse_unported > unported.sql
    pg_dump --format=plain --schema-only --no-tablespaces --no-acl --no-owner synapse          >   ported.sql
    # By default, `diff` returns zero if there are no changes and nonzero otherwise
    diff -u unported.sql ported.sql | tee schema_diff