fleet/tools/percona/test/README.md
Lucas Manuel Rodriguez 1afb015f6c
Test DB migrations with Percona XtraDB MySQL server 5.7.25 (#16320)
#15881

This PR adds a script to test DB migrations with Percona XtraDB 5.7.25.

PS: To run this test before we merge this PR to `main` you will need to
change step 2 (`Make sure to be on latest main`), instead of `main` use
this branch `15881-test-migrations-with-percona`.
2024-01-29 14:21:37 -03:00

1.4 KiB

Test migrations with Percona Server XtraDB 5.7.25

IMPORTANT:

  • The test performed here will clear your local database.
  • This test was developed and tested on a macOS Intel device.

Following are the instructions to test Fleet DB migrations with a specific version of Percona Server XtraDB (5.7.25). We need to run this specific test for users running this specific version of Percona Server. The test will run migrations with pxc_strict_mode=PERMISSIVE up until fleet-v4.42.0 and then run the remaining migrations with pxc_strict_mode=ENFORCING (default) because starting in fleet-v4.44.0 we will attempt to make every migration compatible with running this specific version of Percona Server with the default setting.

Dependencies:

  • Docker for Mac.
  • mysql client (brew install mysql-client).

Everything should be executed at the root of the repository.

  1. Backup first by running make db-backup.
  2. Make sure to be on latest main:
git checkout main
git pull origin main
  1. Run the upgrade test script: ./tools/percona/test/upgrade.sh.
  2. Once the script finishes (you should see Migrations completed. at the very end), run fleet serve and perform smoke tests as usual.
  3. Restore your previous setup by running the following:
docker compose down
docker volume rm fleet_mysql-persistent-volume
docker compose up
make db-restore