123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- #!/usr/bin/env bash
- # Test for the export-data admin command against sqlite and postgres
- set -xe
- cd "$(dirname "$0")/../.."
- echo "--- Install dependencies"
- # Install dependencies for this test.
- pip install psycopg2
- # Install Synapse itself. This won't update any libraries.
- pip install -e .
- echo "--- Generate the signing key"
- # Generate the server's signing key.
- python -m synapse.app.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 update.
- scripts/update_synapse_database --database-config .ci/sqlite-config.yaml --run-background-updates
- # Run the export-data command on the sqlite test database
- python -m synapse.app.admin_cmd -c .ci/sqlite-config.yaml export-data @anon-20191002_181700-832:localhost:8800 \
- --output-directory /tmp/export_data
- # Test that the output directory exists and contains the rooms directory
- dir="/tmp/export_data/rooms"
- if [ -d "$dir" ]; then
- echo "Command successful, this test passes"
- else
- echo "No output directories found, the command fails against a sqlite database."
- exit 1
- fi
- # Create the PostgreSQL database.
- .ci/scripts/postgres_exec.py "CREATE DATABASE synapse"
- # Port the SQLite databse to postgres so we can check command works against postgres
- echo "+++ Port SQLite3 databse to postgres"
- scripts/synapse_port_db --sqlite-database .ci/test_db.db --postgres-config .ci/postgres-config.yaml
- # Run the export-data command on postgres database
- python -m synapse.app.admin_cmd -c .ci/postgres-config.yaml export-data @anon-20191002_181700-832:localhost:8800 \
- --output-directory /tmp/export_data2
- # Test that the output directory exists and contains the rooms directory
- dir2="/tmp/export_data2/rooms"
- if [ -d "$dir2" ]; then
- echo "Command successful, this test passes"
- else
- echo "No output directories found, the command fails against a postgres database."
- exit 1
- fi
|