From Fedora Project Wiki

Revision as of 15:32, 25 November 2024 by Sumenon (talk | contribs) (→‎In between tests)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

IPA MIGRATE TOOL

Date 2024-12-09
Time all day

Website QA/Test Days
Matrix #test-day:fedoraproject.org(other clients|?)
Mailing list test


Can't make the date?
If you come to this page after the test day is completed, your testing is still valuable, and you can use the information on this page to test, file any bugs you find, and add your results to the results section. If this page is more than a month old when you arrive here, please check the current schedule and see if a similar but more recent Test Day is planned or has already happened.

What to test?

This Test Day will focus on FreeIPA ipa-migrate tool

Who's available

The following cast of characters will be available testing, workarounds, bug fixes, and general discussion:

You can chat with me on Matrix. See the infobox on top of the page to learn where to join.

Prerequisite for Test Day

  • A virtual machine or a bare metal machine
  • An installation of Fedora 41 (ideally Server). Make sure to fully update your system. If installing a fresh system, it's recommended to use the latest nightly image.

What to test

Prerequisites

You must install IPA on the new system (local server), and the domain/suffix must be the final expected values. The remote data will be converted to match the new local server. Typically it is expected that this installation be bare. The tool was not designed to merge two different installations (although it might work). IPA to IPA migration design

  • IPA-to-IPA migration will be implemented as an AdminTool standalone client tool: /usr/sbin/ipa-migrate
Migration will consist of three areas:
  • Schema - the LDAP schema (objectclasses and attributes)
  • Config - the LDAP configuration under cn=config (dse.ldif)
  • Database - the main LDAP database

Allow online (LDAP over the network) or offline (LDIF file) migration. You can mix and match LDIF (offline) with LDAP (online)

Online migration

Online migration consists of contacting the remote server over the network and pulling in all the required information. With very large databases this could impact the tool’s performance

Offline migration

Offline migration consists of using LDIF files from the remote server

  • Config - the DS config file: /etc/dirsrv/slapd-YOUR_LDAP_INSTANCE/dse.ldif
  • Schema - all the schema files found under /etc/dirsrv/schema/ and /etc/dirsrv/slapd-YOUR_LDAP_INSTANCE/schema/
  • Database - You need to export the userroot database to an ldif file

Then copy these LDIF files to the new local server

How to test?

  1. Install Remote IPA server on Fedora41 [remote.testrelm.test]
  2. Add users, groups, hbacrule, sudorules, selinuxusermaps etc on the Remote IPA server
  3. Install Local IPA server on Fedora 41 [local.testrelm.test]
  4. Ensure local and remote servers can ping each other.
  5. . Now Run ipa-migrate tool with various options i.e ipa-migrate --help
  # ipa-migrate stage-mode <remote.testrelm.test> -w <password>
  1. Check for logs in /var/log/ipa-migrate.log

[Note: The log file gets appended for each time the command ipa-migrate is run]

Install freeIPA packages

  1. dnf -y install freeipa-server freeipa-server-dns

Set up environment variables on each machine/VM

 # export ADMIN_PASSWORD=password
 # export DM_PASSWORD=password

In between tests

To re-use test machines in between installations for correct results.

On local system.

 # ipa-server-install --setup-dns --forwarder=<ip-address> -n testrelm.test -r TESTRELM.TEST --no-dnssec-validation -a <password> -p <password> -U
 # ipa-server-install –uninstall -U

On the remote IPA server

 # ipa-server-install --setup-dns --forwarder=<ip-address> -n testrelm.test -r TESTRELM.TEST --no-dnssec-validation -a <password> -p <password> -U
 # ipa-server-install –uninstall -U


Visit the results page and click on the column title links to see the tests that need to be run: most column titles are links to a specific test case. Follow the instructions there, then enter your results by clicking the Enter result button for the test.

Reporting bugs

Perhaps you've found an already-reported bug. Please look at:

All new bugs should be reported into the upstream bug tracker. A less-preferred alternative is to file them into Red Hat JIRA, in most cases against the ipa component.

We really need bug reports!
Please note that just mentioning your problem into the comments section on the results page is not very helpful. Very often those problems only happen in specific circumstances, or with specific steps taken. We need the logs and screenshots, and we need to be able to ask you followup questions. Please file bug reports, it's much more useful than a short comment. Thank you!

When filing the bug, it's very helpful to include:

  • exact steps you've performed (and whether you can reproduce it again)
  • screenshots or videos, if applicable
  • system journal (log), which you can retrieve by journalctl -b > journal.txt
  • all output in a terminal, if started from a terminal
  • your system description

If you are unsure about exactly how to file the report or what other information to include, just ask us.

Please make sure to link to the bug when submitting your test result, thanks!

Test Results

Visit the results page and click on the column title links to see the tests that need to be run: most column titles are links to a specific test case. Follow the instructions there, then enter your results by clicking the Enter result button for the test.